(defun right-justify-rectangle (start end)
(interactive "r")
(apply-on-rectangle (lambda (c0 c1)
(move-to-column c1 t)
(let ((start (- (point) (- c1 c0)))
(end (point)))
(when (re-search-backward "\\S-" start t)
(transpose-regions start (match-end 0)
(match-end 0) end))))
start end))
To avoid Tab, configure the variable indent-tabs-mode.
Edit:
Here is a more reasonable version indent-tabs-mode:
(defun right-justify-rectangle (start end)
(interactive "r")
(let ((indent-tabs-mode nil))
(apply-on-rectangle (lambda (c0 c1)
(move-to-column c1 t)
(let ((start (- (point) (- c1 c0)))
(end (point)))
(when (re-search-backward "\\S-" start t)
(transpose-regions start (match-end 0)
(match-end 0) end))))
start end))
(when indent-tabs-mode (tabify start end)))
source
share