Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Vi non broad word chars #1106

Merged
merged 7 commits into from
Sep 28, 2023
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
44 changes: 39 additions & 5 deletions extensions/vi-mode/options.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -317,9 +317,7 @@
(:set-hook (new-value)
(setf (lem:variable-value 'lem/line-numbers:line-numbers :global) new-value)))

(defvar *default-iskeyword* '("@" "48-57" "_" "192-255"))

(defun compile-iskeyword (value)
(defun compile-rules (value option-name)
(apply #'disjoin
(mapcar (lambda (rule)
(check-type rule string)
Expand All @@ -343,13 +341,18 @@
(progn
(unless (= (length rule) 1)
(error 'option-error
:format-control "Invalid rule in iskeyword: ~A"
:format-arguments (list rule)))
:format-control "Invalid rule in ~A: ~A"
:format-arguments (list option-name rule)))
(let ((rule-char (aref rule 0)))
(lambda (c)
(char= c rule-char))))))))
value)))

(defvar *default-iskeyword* '("@" "48-57" "_" "192-255"))

(defun compile-iskeyword (value)
(compile-rules value "iskeyword"))

(define-option "iskeyword" ((cons *default-iskeyword*
(compile-iskeyword *default-iskeyword*))
:type list
Expand All @@ -376,6 +379,37 @@
(option-value option))
:test 'equal)))))

(defvar *default-non-broad-word-char* (mapcar #'string '(#\Newline #\Space #\Tab)))

(defun compile-non-broad-word-char (value)
(compile-rules value "non-broad-word-char"))

(define-option "non-broad-word-char"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't like you to take this as a strong opinion, but I'm not sure about this naming.
All Vim options doesn't contains symbols in their name, and all this kind of options starts with is.
So, maybe isseparator or isblank... something like that looks ideal to me.
How do you think?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Then I suggest isWORDseparator because in Vim broad word is called WORD. Otherwise it is not clear separator of what it is.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Even better. That sounds reasonable in some sense, but the upcased name is also strange since all Vim's options have downcased names.
Vim has isprint to set custom printable chars, so isseparator doesn't look weird to me, though.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

OK. Let it be isseparator then.

((cons *default-non-broad-word-char*
(compile-non-broad-word-char *default-non-broad-word-char*))
:type list
:aliases ("nbwc")
:scope :buffer)
(:documentation "Comma-separated string to specify the characters that should be recognized as non broad word characters. (buffer local)
Aliases: nbwc")
(:getter (option)
(car (option-raw-value option)))
(:setter (new-value option)
(setf (option-%value option)
(cons new-value
(compile-non-broad-word-char new-value))))
(:initializer (option)
(let ((syntax-table (lem:mode-syntax-table (lem:buffer-major-mode (lem:current-buffer)))))
(setf (option-value option)
(delete-duplicates
(nconc (mapcar (lambda (c)
(if (char= c #\@)
"@-@"
(string c)))
(lem-base::syntax-table-space-chars syntax-table))
(option-value option))
:test 'equal)))))

(define-option "scrolloff" (0 :type number :aliases ("so"))
(:documentation "The minimal number of lines to keep above of below the cursor.
Default: 0
Expand Down
21 changes: 20 additions & 1 deletion extensions/vi-mode/tests/options.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,13 @@
(:import-from :lem-fake-interface
:with-fake-interface)
(:shadowing-import-from :lem-vi-mode/tests/utils
:with-current-buffer))
:with-current-buffer)
(:import-from :named-readtables
:in-readtable))
(in-package :lem-vi-mode/tests/options)

(in-readtable :interpol-syntax)

(deftest get-option
(ok (typep (get-option "number") 'option)
"Can get a global option")
Expand All @@ -24,3 +28,18 @@
(with-current-buffer (buf)
(ok (equalp (option-value "iskeyword") isk)
"Another buffer's local option is not changed"))))))

(deftest non-broad-word-char-option
(ok (typep (get-option "non-broad-word-char") 'option)
"Can get non-broad-word-char option")
(ok (typep (get-option "nbwc") 'option)
"Can get non-broad-word-char option by alias")
(with-fake-interface ()
(with-vi-buffer (#?"abc\n[(]def)\n")
(cmd "E")
(ok (buf= #?"abc\n(def[)]\n")))
(with-vi-buffer (#?"abc\n[(]def)\n")
(execute-set-command "nbwc+=(")
(execute-set-command "nbwc+=)")
(cmd "WE")
(ok (buf= #?"abc\n(de[f])\n")))))
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for writing tests!

5 changes: 5 additions & 0 deletions extensions/vi-mode/word.lisp
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,15 @@
((blank-char-p char) :blank)
(t :non-word))))

(defun non-broad-word-char-p (char)
(funcall (cdr (option-raw-value "non-broad-word-char"))
char))

(defun broad-word-char-type (char)
(when char
(cond
((blank-char-p char) :blank)
((non-broad-word-char-p char) :non-word)
(t :word))))

(defun forward-word-begin (char-type-fn &optional (point (current-point)))
Expand Down