diff options
-rw-r--r-- | NEWS | 4 | ||||
-rw-r--r-- | paredit.el | 10 | ||||
-rw-r--r-- | test.el | 20 |
3 files changed, 32 insertions, 2 deletions
@@ -7,6 +7,10 @@ https://paredit.org Latest release: https://paredit.org/paredit.el Current development version: https://paredit.org/paredit-beta.el +** Version 26 (beta) + +*** M-s (paredit-splice-sexp) now restores column in text fields like ielm. + ** Version 25 -- 2022-11-25 *** paredit now lives at paredit.org. @@ -184,7 +184,7 @@ If point was on code, it moves with the code. If point was on indentation, it stays in indentation." (let ((column (make-symbol "column")) (indentation (make-symbol "indentation"))) - `(let ((,column (current-column)) + `(let ((,column (paredit-current-column)) (,indentation (paredit-current-indentation))) (let ((value (progn ,@body))) (paredit-restore-column ,column ,indentation) @@ -2953,10 +2953,16 @@ This is independent of context -- it doesn't check what state the t) nil))) +(defun paredit-current-column () + ;; Like current-column, but respects field boundaries in interactive + ;; modes like ielm. For use only with paredit-restore-column, which + ;; works relative to point-at-bol. + (- (point) (point-at-bol))) + (defun paredit-current-indentation () (save-excursion (back-to-indentation) - (current-column))) + (paredit-current-column))) (defun paredit-restore-column (column indentation) ;; Preserve the point's position either in the indentation or in the @@ -1251,6 +1251,26 @@ Four arguments: the paredit command, the text of the buffer ("\"|foo\\\"bar\"" error) ;++ ("(\"|foo\\\;bar\")" error) )) + +(let ((prompt "prompt> ") + (before "(foo (bar| baz))") + (expected "(foo bar| baz)")) + (with-temp-buffer + (paredit-test-buffer-setup) + (insert prompt) + (add-text-properties (point-min) (point-max) '(field output)) + (insert before) + (goto-char (length prompt)) + (search-forward "|") + (delete-char -1) + (call-interactively 'paredit-splice-sexp) + (insert "|") + (let ((actual (buffer-string))) + (if (not (string= (concat prompt expected) actual)) + (paredit-test-failed 'paredit-splice-sexp + (concat prompt before) + actual + (concat prompt expected)))))) (paredit-test 'paredit-forward-slurp-sexp '(("|" error) |