Skip to content

Commit

Permalink
Merge remote-tracking branch 'greenfork/improve-elixir-hooks'
Browse files Browse the repository at this point in the history
  • Loading branch information
mawww committed Jun 15, 2021
2 parents 682426b + 2f22fef commit 8fdda6d
Show file tree
Hide file tree
Showing 17 changed files with 84 additions and 7 deletions.
27 changes: 20 additions & 7 deletions rc/filetype/elixir.kak
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ hook global WinSetOption filetype=elixir %{
require-module elixir

hook window ModeChange pop:insert:.* -group elixir-trim-indent elixir-trim-indent
hook window InsertChar \n -group elixir-insert elixir-insert-on-new-line
hook window InsertChar \n -group elixir-indent elixir-indent-on-new-line
hook window InsertChar \n -group elixir-insert elixir-insert-on-new-line

hook -once -always window WinSetOption filetype=.* %{ remove-hooks window elixir-.+ }
}
Expand Down Expand Up @@ -92,12 +92,25 @@ define-command -hidden elixir-trim-indent %{
try %{ execute-keys -draft -itersel <a-x> s \h+$ <ret> d }
}

define-command -hidden elixir-insert-on-new-line %{
evaluate-commands -draft -itersel %{
# copy -- comments prefix and following white spaces
try %{ execute-keys -draft k <a-x> s ^\h*\K--\h* <ret> y gh j P }
}
}
define-command -hidden elixir-insert-on-new-line %[
evaluate-commands -no-hooks -draft -itersel %[
# copy '#' comment prefix and following white spaces
try %{ execute-keys -draft k <a-x> s ^\h*\K#\h* <ret> y jgi P }
# wisely add end structure
evaluate-commands -save-regs x %[
try %{ execute-keys -draft k <a-x> s ^ \h + <ret> \" x y } catch %{ reg x '' }
try %[
evaluate-commands -draft %[
# Check if previous line opens a block
execute-keys -draft k<a-x> <a-k>^<c-r>x(.+\bdo$)<ret>
# Check that we do not already have an end for this indent level which is first set via `elixir-indent-on-new-line` hook
execute-keys -draft }i J <a-x> <a-K> ^<c-r>x(end|else)[^0-9A-Za-z_!?]<ret>
]
execute-keys -draft o<c-r>xend<esc> # insert a new line with containing end
]
]
]
]

define-command -hidden elixir-indent-on-new-line %{
evaluate-commands -draft -itersel %{
Expand Down
1 change: 1 addition & 0 deletions test/indent/elixir/do-keyword/cmd
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
c<ret>f()<esc>jo<ret>def f1() do<ret>1<esc>jo<ret>def f2(), do: 2<ret>
1 change: 1 addition & 0 deletions test/indent/elixir/do-keyword/in
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
test do%( )
10 changes: 10 additions & 0 deletions test/indent/elixir/do-keyword/out
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
test do
f()
end

def f1() do
1
end

def f2(), do: 2

3 changes: 3 additions & 0 deletions test/indent/elixir/do-keyword/rc
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
source "%val{runtime}/colors/default.kak"
source "%val{runtime}/rc/filetype/elixir.kak"
set buffer filetype elixir
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
c<ret><esc>
4 changes: 4 additions & 0 deletions test/indent/elixir/following-blocks-should-not-prevent-end/in
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
def foo() do%( )

def bar() do
end
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
def foo() do

end

def bar() do
end
3 changes: 3 additions & 0 deletions test/indent/elixir/following-blocks-should-not-prevent-end/rc
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
source "%val{runtime}/colors/default.kak"
source "%val{runtime}/rc/filetype/elixir.kak"
set buffer filetype elixir
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
c<ret><esc>
3 changes: 3 additions & 0 deletions test/indent/elixir/function-definition-shouldnt-duplicate/in
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
defmodule Module do
def test do%( )
end
5 changes: 5 additions & 0 deletions test/indent/elixir/function-definition-shouldnt-duplicate/out
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
defmodule Module do
def test do

end
end
3 changes: 3 additions & 0 deletions test/indent/elixir/function-definition-shouldnt-duplicate/rc
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
source "%val{runtime}/colors/default.kak"
source "%val{runtime}/rc/filetype/elixir.kak"
set buffer filetype elixir
1 change: 1 addition & 0 deletions test/indent/elixir/insert-comment-hash/cmd
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
c<ret><esc><a-o>jo# comment3<ret>comment4<esc><a-o>jo# indented<ret>indented2<esc><a-o>jodef f() do<ret># comment<ret>comment2<esc>j<a-o>jodef f() do<ret># comment<esc>hhhi<ret>
1 change: 1 addition & 0 deletions test/indent/elixir/insert-comment-hash/in
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Comment %( )comment2
18 changes: 18 additions & 0 deletions test/indent/elixir/insert-comment-hash/out
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
# Comment
# comment2

# comment3
# comment4

# indented
# indented2

def f() do
# comment
# comment2
end

def f() do
# comm
# ent
end
3 changes: 3 additions & 0 deletions test/indent/elixir/insert-comment-hash/rc
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
source "%val{runtime}/colors/default.kak"
source "%val{runtime}/rc/filetype/elixir.kak"
set buffer filetype elixir

0 comments on commit 8fdda6d

Please sign in to comment.