2011-11-04 10:09:27 +01:00
|
|
|
Kakoune
|
|
|
|
=======
|
|
|
|
|
|
|
|
Introduction:
|
|
|
|
-------------
|
|
|
|
|
2011-11-04 15:05:05 +01:00
|
|
|
Kakoune is a code editor heavily inspired by vim, as such most of it's
|
2011-11-04 10:09:27 +01:00
|
|
|
commands are similar to vi's ones.
|
|
|
|
|
|
|
|
Kakoune can operate in two modes, normal and insertion. In insertion mode,
|
|
|
|
keys are directly inserted into the current buffer. In normal mode, keys
|
|
|
|
are used to manipulate the current selection and to enter insertion mode.
|
|
|
|
|
|
|
|
There is no concept of cursor in kakoune, only selections, a single character
|
2011-12-28 20:04:57 +01:00
|
|
|
selection can be seen as a cursor but there is no difference internally.
|
2011-11-04 10:09:27 +01:00
|
|
|
|
2011-11-04 15:05:05 +01:00
|
|
|
Building
|
|
|
|
--------
|
|
|
|
|
|
|
|
Kakoune dependencies are:
|
2011-11-04 15:28:29 +01:00
|
|
|
|
2011-11-04 15:05:05 +01:00
|
|
|
* GCC >= 4.6
|
|
|
|
* boost
|
|
|
|
* ncurses
|
|
|
|
|
|
|
|
To build, just type *make* in the src directory
|
2011-11-04 10:09:27 +01:00
|
|
|
|
|
|
|
Basic Movement
|
|
|
|
--------------
|
|
|
|
|
|
|
|
* _space_: select the character under selection end
|
|
|
|
|
|
|
|
* _h_: select the character on the right of selection end
|
|
|
|
* _j_: select the character below the selection end
|
|
|
|
* _k_: select the character above the selection end
|
|
|
|
* _l_: select the character on the left of selection end
|
|
|
|
|
2011-12-28 20:04:57 +01:00
|
|
|
* _w_: select the word and following whitespaces on the right of selection end
|
2011-11-04 10:09:27 +01:00
|
|
|
* _b_: select preceding whitespaces and the word on the left of selection end
|
|
|
|
* _e_: select preceding whitespaces and the word on the right of selection end
|
|
|
|
|
2011-11-22 15:32:05 +01:00
|
|
|
* _x_: select line on which selection end lies (or next line when end lies on
|
|
|
|
an end-of-line)
|
|
|
|
* _alt-x_: expand selections to contain full lines (including end-of-lines)
|
|
|
|
|
2011-11-04 10:09:27 +01:00
|
|
|
* _%_: select whole buffer
|
|
|
|
|
2012-05-29 13:32:29 +02:00
|
|
|
* _gh_, _alt-H_: select to line begin
|
|
|
|
* _gl_, _alt-L_: select to line end
|
|
|
|
|
|
|
|
* _gg_, _gt_: go to the first line
|
|
|
|
* _gb_: go to the last line
|
2011-11-04 10:09:27 +01:00
|
|
|
|
|
|
|
Appending
|
|
|
|
---------
|
|
|
|
|
|
|
|
for most selection commands, using shift permits to add to current selection
|
|
|
|
instead of replacing it. for example, _wWW_ selects 3 consecutive words
|
|
|
|
|
|
|
|
Using Counts
|
|
|
|
------------
|
|
|
|
|
|
|
|
Most selection commands also support counts, which are entered before the
|
|
|
|
command itself.
|
|
|
|
|
|
|
|
for example, _3W_ selects 3 consecutive words and _3w_ select the third word on
|
|
|
|
the right of selection end.
|
|
|
|
|
2012-05-29 13:32:29 +02:00
|
|
|
* _space_: when used with count, keep only the counth selection
|
|
|
|
* _alt-space_: when used with count, remove the counth selection
|
|
|
|
|
2011-11-04 10:09:27 +01:00
|
|
|
Changes
|
|
|
|
-------
|
|
|
|
|
|
|
|
* _i_: insert before current selection
|
|
|
|
* _a_: insert after current selection
|
|
|
|
* _d_: yank and delete current selection
|
|
|
|
* _c_: yank and delete current selection and insert
|
|
|
|
|
|
|
|
* _I_: insert at current selection begin line start
|
|
|
|
* _A_: insert at current selection end line end
|
|
|
|
* _o_: insert in a new line below current selection end
|
|
|
|
* _O_: insert in a new line above current selection begin
|
|
|
|
|
|
|
|
* _p_: paste after current selection end
|
|
|
|
* _P_: paste before current selection begin
|
|
|
|
|
2011-11-22 15:32:05 +01:00
|
|
|
* _alt-j_: join selected lines
|
|
|
|
|
2011-12-28 20:09:54 +01:00
|
|
|
* _|_: pipe each selections through the given external filter program
|
|
|
|
and replace with it's output.
|
|
|
|
|
2011-11-16 15:15:40 +01:00
|
|
|
Multi Selection
|
|
|
|
---------------
|
|
|
|
|
|
|
|
Kak was designed from the start to handle multiple selections.
|
|
|
|
On way to get a multiselection is via the _s_ key.
|
|
|
|
|
|
|
|
For example, to change all occurences of word 'roger' to word 'marcel'
|
|
|
|
in a paragraph, here is what can be done:
|
|
|
|
|
|
|
|
select the paragraph with enough _x_. press _s_ and enter roger then enter.
|
|
|
|
now paragraph selection was replaced with multiselection of each roger in
|
|
|
|
the paragraph. press _c_ and marcel<esc> to replace rogers with marcels.
|
|
|
|
|
2011-11-21 20:35:02 +01:00
|
|
|
A multiselection can also be obtained with _Alt-s_, which splits the current
|
|
|
|
selection according to the regex entered. To split a comma separated list,
|
|
|
|
use _alt-s_ then ', *'
|
|
|
|
|
2012-05-04 06:34:48 +02:00
|
|
|
To clear multiple selections, use _space_. To keep only the nth selection
|
|
|
|
use _n_ followed by _space_.
|
2012-01-25 22:26:41 +01:00
|
|
|
|
2012-05-29 13:32:29 +02:00
|
|
|
Object Selection
|
|
|
|
----------------
|
|
|
|
|
|
|
|
Using alt-i and alt-a, you can select some text object, the starting
|
|
|
|
point is always the last character of the selection.
|
|
|
|
|
|
|
|
* _b_, _(_ or _)_: select the enclosing parenthesis
|
|
|
|
* _B_, _{_ or _}_: select the enclosing {} block
|
|
|
|
* _[_ or _]_: select the enclosing [] block
|
|
|
|
* _<_ or _>_: select the enclosing <> block
|
|
|
|
* w: select the whole word
|
|
|
|
* W: select the whole WORD
|
|
|
|
|
2012-06-15 14:24:09 +02:00
|
|
|
When it makes sense, _alt-i_ selects the inner object and alt-a the whole
|
|
|
|
object. For example _alt-i_ ( will only select the inside of the parenthesis,
|
|
|
|
for words, the difference between _alt-i_ and _alt-a_ is that _alt-a_ also
|
|
|
|
selects the following blanks.
|
2012-05-29 13:32:29 +02:00
|
|
|
|
2012-02-10 15:18:17 +01:00
|
|
|
Registers
|
|
|
|
---------
|
|
|
|
|
|
|
|
registers are named list of text. They are used for various purpose, like
|
|
|
|
storing the last yanked test, or the captures groups associated with the
|
|
|
|
last selection.
|
|
|
|
|
|
|
|
While in insert mode, ctrl-r followed by a register name (one character)
|
|
|
|
inserts it.
|
2011-11-16 21:05:51 +01:00
|
|
|
|
2012-02-10 15:18:17 +01:00
|
|
|
For example, ctrl-r followed by " will insert the currently yanked text.
|
|
|
|
ctrl-r followed by 2 will insert the second capture group from the last regex
|
|
|
|
selection.
|
2011-11-16 21:05:51 +01:00
|
|
|
|
2012-02-10 15:18:17 +01:00
|
|
|
Registers are lists, instead of simply text in order to interact well with
|
|
|
|
multiselection. Each selection have it's own captures, or yank buffer.
|
2011-11-16 21:05:51 +01:00
|
|
|
|
2011-11-29 23:37:20 +01:00
|
|
|
Highlighters
|
|
|
|
------------
|
2011-11-08 15:30:10 +01:00
|
|
|
|
2011-11-29 23:37:20 +01:00
|
|
|
Manipulation of the displayed text is done through highlighters, which can be added
|
|
|
|
or removed with the command :addhl <highlighter_name> <highlighter_parameters...>
|
|
|
|
and :rmhl <highlighter_id>
|
2011-11-08 15:30:10 +01:00
|
|
|
|
2011-11-29 23:37:20 +01:00
|
|
|
existing highlighters are:
|
2011-11-08 15:30:10 +01:00
|
|
|
|
2011-11-10 15:30:10 +01:00
|
|
|
* *highlight_selections*: used to make current selection visible
|
|
|
|
* *expand_tabs*: expand tabs to next 8 multiple column (to make configurable)
|
2011-12-28 20:04:57 +01:00
|
|
|
* *number_lines*: show line numbers
|
2011-11-10 15:30:10 +01:00
|
|
|
* *regex*: highlight a regex, takes 3 parameters <regex> <fg_color> <bg_color>
|
2012-02-10 15:18:17 +01:00
|
|
|
* *group*: highlighter group, containing other highlighters. takes one
|
|
|
|
parameter, <group_name>. useful when multiple highlighters work
|
|
|
|
together and need to be removed as one. Adding and removing from
|
|
|
|
a group can be done using
|
2012-05-04 06:34:48 +02:00
|
|
|
:addhl -group <group> <highlighter_name> <highlighter_parameters...>
|
|
|
|
:rmhl -group <group> <highlighter_name>
|
2011-11-26 20:19:08 +01:00
|
|
|
|
2011-12-02 15:30:10 +01:00
|
|
|
Filters
|
|
|
|
-------
|
|
|
|
|
|
|
|
Filters can be installed to interact with buffer modifications. They can be
|
|
|
|
added or removed with :addfilter <filter_name> <filter_parameters...> and
|
|
|
|
:rmfilter <filter_id>
|
|
|
|
|
|
|
|
exisiting filters are:
|
|
|
|
|
|
|
|
* *preserve_indent*: insert previous line indent when inserting a newline
|
2011-12-28 20:09:54 +01:00
|
|
|
* *cleanup_whitespaces*: remove trailing whitespaces on the previous line
|
|
|
|
when inserting an end-of-line.
|
|
|
|
* *expand_tabulations*: insert spaces instead of tab characters
|
2011-12-02 15:30:10 +01:00
|
|
|
|
2011-11-26 20:19:08 +01:00
|
|
|
Hooks
|
|
|
|
-----
|
|
|
|
|
|
|
|
commands can be registred to be executed when certain events arise.
|
|
|
|
to register a hook, use the hook command.
|
|
|
|
|
2012-01-25 22:26:41 +01:00
|
|
|
:hook <scope> <hook_name> <filtering_regex> <command> <command_args>...
|
|
|
|
|
2012-06-15 14:24:09 +02:00
|
|
|
<scope> can be either global, buffer or window, the scope are hierarchical,
|
|
|
|
meaning that a Window calling a hook will execute it's own, the buffer ones
|
|
|
|
and the global ones.
|
2011-11-26 20:19:08 +01:00
|
|
|
|
2012-01-25 22:26:41 +01:00
|
|
|
for example, to automatically use line numbering with .cc files,
|
2011-11-26 20:19:08 +01:00
|
|
|
use the following command:
|
|
|
|
|
2012-01-25 22:26:41 +01:00
|
|
|
:hook global WinCreate .*\.cc addhl number_lines
|
|
|
|
|
2012-05-29 13:32:29 +02:00
|
|
|
Shell expension
|
|
|
|
---------------
|
|
|
|
|
|
|
|
Commands support the shell backtick syntax, and kakoune internal state
|
|
|
|
can be accessed through environment variable. For example, if you are
|
|
|
|
editing the editor.cc file, typing ':edit `echo ${kak_bufname/%.cc/.hh}`'
|
|
|
|
will edit the editor.hh file.
|
|
|
|
|