mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2024-11-22 07:09:54 +00:00
(string-rectangle): Make operate-on-rectangle convert tabs.
(string-rectangle-line): After inserting string, insert the same width of whitespace that we deleted earlier. (operate-on-rectangle): Operate even if width is 0. (open-rectangle-line): Clean up.
This commit is contained in:
parent
9d721a9e79
commit
bc8ea5430e
71
lisp/rect.el
71
lisp/rect.el
@ -51,21 +51,20 @@ Point is at the end of the segment of this line within the rectangle."
|
||||
(setq endlinepos (point-marker)))
|
||||
(if (< endcol startcol)
|
||||
(setq startcol (prog1 endcol (setq endcol startcol))))
|
||||
(if (/= endcol startcol)
|
||||
(save-excursion
|
||||
(goto-char startlinepos)
|
||||
(while (< (point) endlinepos)
|
||||
(let (startpos begextra endextra)
|
||||
(move-to-column startcol coerce-tabs)
|
||||
(setq begextra (- (current-column) startcol))
|
||||
(setq startpos (point))
|
||||
(move-to-column endcol coerce-tabs)
|
||||
(setq endextra (- endcol (current-column)))
|
||||
(if (< begextra 0)
|
||||
(setq endextra (+ endextra begextra)
|
||||
begextra 0))
|
||||
(funcall function startpos begextra endextra))
|
||||
(forward-line 1))))
|
||||
(save-excursion
|
||||
(goto-char startlinepos)
|
||||
(while (< (point) endlinepos)
|
||||
(let (startpos begextra endextra)
|
||||
(move-to-column startcol coerce-tabs)
|
||||
(setq begextra (- (current-column) startcol))
|
||||
(setq startpos (point))
|
||||
(move-to-column endcol coerce-tabs)
|
||||
(setq endextra (- endcol (current-column)))
|
||||
(if (< begextra 0)
|
||||
(setq endextra (+ endextra begextra)
|
||||
begextra 0))
|
||||
(funcall function startpos begextra endextra))
|
||||
(forward-line 1)))
|
||||
(- endcol startcol)))
|
||||
|
||||
(defun delete-rectangle-line (startdelpos ignore ignore)
|
||||
@ -179,17 +178,19 @@ but instead winds up to the right of the rectangle."
|
||||
(goto-char start))
|
||||
|
||||
(defun open-rectangle-line (startpos begextra endextra)
|
||||
(let ((column (+ (current-column) begextra endextra)))
|
||||
;; Column where rectangle ends.
|
||||
(let ((endcol (+ (current-column) endextra))
|
||||
whitewidth)
|
||||
(goto-char startpos)
|
||||
(let ((ocol (current-column)))
|
||||
;; Column where rectangle begins.
|
||||
(let ((begcol (- (current-column) begextra)))
|
||||
(skip-chars-forward " \t")
|
||||
(setq column (+ column (- (current-column) ocol))))
|
||||
(delete-region (point)
|
||||
;; Use skip-chars-backward's LIM argument to leave
|
||||
;; characters before STARTPOS undisturbed.
|
||||
(progn (skip-chars-backward " \t" startpos)
|
||||
(point)))
|
||||
(indent-to column)))
|
||||
;; Width of whitespace to be deleted and recreated.
|
||||
(setq whitewidth (- (current-column) begcol)))
|
||||
;; Delete the whitespace following the start column.
|
||||
(delete-region startpos (point))
|
||||
;; Open the desired width, plus same amount of whitespace we just deleted.
|
||||
(indent-to (+ endcol whitewidth))))
|
||||
|
||||
;;;###autoload
|
||||
(defun string-rectangle (start end string)
|
||||
@ -199,21 +200,22 @@ This command does not delete or overwrite any existing text.
|
||||
|
||||
Called from a program, takes three args; START, END and STRING."
|
||||
(interactive "r\nsString rectangle: ")
|
||||
(operate-on-rectangle 'string-rectangle-line start end nil)
|
||||
(operate-on-rectangle 'string-rectangle-line start end t)
|
||||
(goto-char start))
|
||||
|
||||
(defun string-rectangle-line (startpos begextra endextra)
|
||||
(let ((column (+ (current-column) begextra endextra)))
|
||||
(let (whitespace)
|
||||
(goto-char startpos)
|
||||
;; Compute horizontal width of following whitespace.
|
||||
(let ((ocol (current-column)))
|
||||
(skip-chars-forward " \t")
|
||||
(setq column (+ column (- (current-column) ocol))))
|
||||
(delete-region (point)
|
||||
;; Use skip-chars-backward's LIM argument to leave
|
||||
;; characters before STARTPOS undisturbed.
|
||||
(progn (skip-chars-backward " \t" startpos)
|
||||
(point)))
|
||||
(insert string)))
|
||||
(setq whitespace (- (current-column) ocol)))
|
||||
;; Delete the following whitespace.
|
||||
(delete-region startpos (point))
|
||||
;; Insert the desired string.
|
||||
(insert string)
|
||||
;; Insert the same width of whitespace that we had before.
|
||||
(indent-to (+ (current-column) whitespace))))
|
||||
|
||||
;;;###autoload
|
||||
(defun clear-rectangle (start end)
|
||||
@ -224,12 +226,15 @@ When called from a program, requires two args which specify the corners."
|
||||
(operate-on-rectangle 'clear-rectangle-line start end t))
|
||||
|
||||
(defun clear-rectangle-line (startpos begextra endextra)
|
||||
;; Find end of whitespace after the rectangle.
|
||||
(skip-chars-forward " \t")
|
||||
(let ((column (+ (current-column) endextra)))
|
||||
;; Delete the text in the rectangle, and following whitespace.
|
||||
(delete-region (point)
|
||||
(progn (goto-char startpos)
|
||||
(skip-chars-backward " \t")
|
||||
(point)))
|
||||
;; Reindent out to same column that we were at.
|
||||
(indent-to column)))
|
||||
|
||||
(provide 'rect)
|
||||
|
Loading…
Reference in New Issue
Block a user