summaryrefslogtreecommitdiff
path: root/lisp/sort.el
diff options
context:
space:
mode:
authorSam Steingold <sds@gnu.org>2013-05-24 14:39:21 -0400
committerSam Steingold <sds@gnu.org>2013-05-24 14:39:21 -0400
commit9631677d730a314f55378f5da6734db521f8130d (patch)
tree489b0974278443fd68ed5286202290174cb9cc75 /lisp/sort.el
parent5010583555fce883d83e7a50e26d9d34f9e108ce (diff)
downloademacs-9631677d730a314f55378f5da6734db521f8130d.tar.gz
* lisp/sort.el (delete-duplicate-lines): Accept an optional `keep-blanks'
argument (before the `interactive' argument).
Diffstat (limited to 'lisp/sort.el')
-rw-r--r--lisp/sort.el25
1 files changed, 16 insertions, 9 deletions
diff --git a/lisp/sort.el b/lisp/sort.el
index 56e97061d13..9493768f6a0 100644
--- a/lisp/sort.el
+++ b/lisp/sort.el
@@ -568,7 +568,8 @@ From a program takes two point or marker arguments, BEG and END."
(insert (car ll)))))
;;;###autoload
-(defun delete-duplicate-lines (beg end &optional reverse adjacent interactive)
+(defun delete-duplicate-lines (beg end &optional reverse adjacent keep-blanks
+ interactive)
"Delete duplicate lines in the region between BEG and END.
If REVERSE is nil, search and delete duplicates forward keeping the first
@@ -582,6 +583,9 @@ delete repeated lines only if they are adjacent. It works like the utility
this is more efficient in performance and memory usage than when ADJACENT
is nil that uses additional memory to remember previous lines.
+If KEEP-BLANKS is non-nil (when called interactively with three C-u prefixes),
+duplicate blank lines are preserved.
+
When called from Lisp and INTERACTIVE is omitted or nil, return the number
of deleted duplicate lines, do not print it; if INTERACTIVE is t, the
function behaves in all respects as if it had been called interactively."
@@ -591,6 +595,7 @@ function behaves in all respects as if it had been called interactively."
(list (region-beginning) (region-end)
(equal current-prefix-arg '(4))
(equal current-prefix-arg '(16))
+ (equal current-prefix-arg '(64))
t)))
(let ((lines (unless adjacent (make-hash-table :weakness 'key :test 'equal)))
line prev-line
@@ -605,14 +610,16 @@ function behaves in all respects as if it had been called interactively."
(and (< (point) end) (not (eobp))))
(setq line (buffer-substring-no-properties
(line-beginning-position) (line-end-position)))
- (if (if adjacent (equal line prev-line) (gethash line lines))
- (progn
- (delete-region (progn (forward-line 0) (point))
- (progn (forward-line 1) (point)))
- (if reverse (forward-line -1))
- (setq count (1+ count)))
- (if adjacent (setq prev-line line) (puthash line t lines))
- (forward-line (if reverse -1 1)))))
+ (if (and keep-blanks (string= "" line))
+ (forward-line 1)
+ (if (if adjacent (equal line prev-line) (gethash line lines))
+ (progn
+ (delete-region (progn (forward-line 0) (point))
+ (progn (forward-line 1) (point)))
+ (if reverse (forward-line -1))
+ (setq count (1+ count)))
+ (if adjacent (setq prev-line line) (puthash line t lines))
+ (forward-line (if reverse -1 1))))))
(set-marker beg nil)
(set-marker end nil)
(when interactive