diff options
| author | Thomas Voss <mail@thomasvoss.com> | 2025-12-11 19:50:33 +0100 |
|---|---|---|
| committer | Thomas Voss <mail@thomasvoss.com> | 2025-12-11 19:50:33 +0100 |
| commit | e89cab0aae8bc79270a79fe23edad09e43ba823b (patch) | |
| tree | cc13943e1d843fa8d92a0a936a9493036849c1a7 /.config/emacs/site-lisp/marker.el | |
| parent | b978f0d12c54e2754bea6463f072513838474bc7 (diff) | |
| parent | dad93f009a27699ffc58c7949cd826d3c1487136 (diff) | |
Merge branch 'master' of github.com:Mango0x45/dotfiles
Diffstat (limited to '.config/emacs/site-lisp/marker.el')
| -rw-r--r-- | .config/emacs/site-lisp/marker.el | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/.config/emacs/site-lisp/marker.el b/.config/emacs/site-lisp/marker.el new file mode 100644 index 0000000..f39cad4 --- /dev/null +++ b/.config/emacs/site-lisp/marker.el @@ -0,0 +1,47 @@ +(require 'hi-lock) +(require 'seq) + +(defun marker-mark () + (interactive) + (marker-mark-region (if (use-region-p) + (region-bounds) + `((,(pos-bol) . ,(pos-eol))))) + (when (region-active-p) + (deactivate-mark))) + +(defun marker-mark-region (bounds) + (dolist (x bounds) (marker--mark-region (car x) (cdr x)))) + +(defun marker--mark-region (beg end) + (let ((ov (make-overlay beg end nil :front-advance))) + (overlay-put ov 'priority 1) + (overlay-put ov 'face 'hi-yellow) + (overlay-put ov 'evaporate t) + (overlay-put ov 'marker--mark-p t))) + +(defun marker-unmark () + (interactive) + (if (use-region-p) + (marker-unmark-region (region-bounds)) + (marker-clear)) + (when (region-active-p) + (deactivate-mark))) + +(defun marker-unmark-region (bounds) + (dolist (x bounds) (marker--unmark-region (car x) (cdr x)))) + +(defun marker--unmark-region (beg end) + (dolist (ov (seq-filter (lambda (ov) (overlay-get ov 'marker--mark-p)) + (overlays-in beg end))) + (cond ((< (overlay-start ov) beg) + (move-overlay ov (overlay-start ov) beg)) + ((> (overlay-end ov) end) + (move-overlay ov end (overlay-end ov))) + (:else + (delete-overlay ov))))) + +(defun marker-clear () + (interactive) + (remove-overlays nil nil 'marker--mark-p t)) + +(provide 'marker) |