diff options
| author | Craig Jennings <c@cjennings.net> | 2025-10-17 22:13:41 -0500 | 
|---|---|---|
| committer | Craig Jennings <c@cjennings.net> | 2025-10-17 22:13:41 -0500 | 
| commit | bebefbb7c0aeed1f4726589baa099eb48e0f9d74 (patch) | |
| tree | 7b3c5e9bf3a53b8646da5fe0d650ee56a43c9964 /modules/custom-line-paragraph.el | |
| parent | c04b3e173d88eb0029f1dc200bf92e5825549d41 (diff) | |
refactor: keymap: Use defvar-keymap and keymap-set
- Replace define-prefix-command/define-key with defvar-keymap and keymap-set
- Preserve existing bindings under cj/custom-keymap "l"
- Tidy docstrings and reflow long lines
- No functional changes
Diffstat (limited to 'modules/custom-line-paragraph.el')
| -rw-r--r-- | modules/custom-line-paragraph.el | 32 | 
1 files changed, 15 insertions, 17 deletions
| diff --git a/modules/custom-line-paragraph.el b/modules/custom-line-paragraph.el index db2101fa..7547d8ac 100644 --- a/modules/custom-line-paragraph.el +++ b/modules/custom-line-paragraph.el @@ -33,7 +33,6 @@  (defun cj/duplicate-line-or-region (&optional comment)    "Duplicate the current line or active region below. -  Comment the duplicated text when optional COMMENT is non-nil."    (interactive "P")    (let* ((b (if (region-active-p) (region-beginning) (line-beginning-position))) @@ -51,8 +50,8 @@ Comment the duplicated text when optional COMMENT is non-nil."  (defun cj/remove-duplicate-lines-region-or-buffer ()    "Remove duplicate lines in the region or buffer, keeping the first occurrence. - -Operate on the active region when one exists; otherwise operate on the whole buffer." +Operate on the active region when one exists; otherwise operate on the whole +buffer."    (interactive)    (let ((start (if (use-region-p) (region-beginning) (point-min)))  		(end (if (use-region-p) (region-end) (point-max)))) @@ -61,13 +60,13 @@ Operate on the active region when one exists; otherwise operate on the whole buf  		(while  			(progn  			  (goto-char start) -			  (re-search-forward "^\\(.*\\)\n\\(\\(.*\n\\)*\\)\\1\n" end-marker t)) +			  (re-search-forward "^\\(.*\\)\n\\(\\(.*\n\\)*\\)\\1\n" +								 end-marker t))  		  (replace-match "\\1\n\\2"))))))  (defun cj/remove-lines-containing (text)    "Remove all lines containing TEXT. -  If region is active, operate only on the region, otherwise on entire buffer.  The operation is undoable."    (interactive "sRemove lines containing: ") @@ -95,7 +94,6 @@ The operation is undoable."  (defun cj/underscore-line ()    "Underline the current line by inserting a row of characters below it. -  If the line is empty or contains only whitespace, abort with a message."    (interactive)    (let ((line (buffer-substring-no-properties @@ -111,17 +109,17 @@ If the line is empty or contains only whitespace, abort with a message."  		  (end-of-line)  		  (insert "\n" (make-string len char))))))) - -;; Line & paragraph operations prefix and keymap -(define-prefix-command 'cj/line-and-paragraph-map nil -					   "Keymap for line and paragraph manipulation.") -(define-key cj/custom-keymap "l" 'cj/line-and-paragraph-map) -(define-key cj/line-and-paragraph-map "j" 'cj/join-line-or-region) -(define-key cj/line-and-paragraph-map "J" 'cj/join-paragraph) -(define-key cj/line-and-paragraph-map "d" 'cj/duplicate-line-or-region) -(define-key cj/line-and-paragraph-map "R" 'cj/remove-duplicate-lines-region-or-buffer) -(define-key cj/line-and-paragraph-map "r" 'cj/remove-lines-containing) -(define-key cj/line-and-paragraph-map "u" 'cj/underscore-line) +;; ------------------------- Line And Paragraph Keymap ------------------------- + +(defvar-keymap cj/line-and-paragraph-map +  :doc "Keymap for line and paragraph operations." + "j" #'cj/join-line-or-region + "J" #'cj/join-paragraph + "d" #'cj/duplicate-line-or-region + "R" #'cj/remove-duplicate-lines-region-or-buffer + "r" #'cj/remove-lines-containing + "u" #'cj/underscore-line) +(keymap-set cj/custom-keymap "l" cj/line-and-paragraph-map)  (provide 'custom-line-paragraph)  ;;; custom-line-paragraph.el ends here. | 
