diff options
author | Nicolas Petton <nicolas@petton.fr> | 2015-02-06 15:55:57 +0100 |
---|---|---|
committer | Nicolas Petton <nicolas@petton.fr> | 2015-02-06 15:55:57 +0100 |
commit | c4a0eff0112298de0a97b63e4e22826bf2b4126c (patch) | |
tree | 8cf3babd3fcb25769c6cd36a52bb7753b143bbe2 /lisp/emacs-lisp | |
parent | 05211a578ed2c52f6ed818fc173561afbaea54c2 (diff) | |
download | emacs-c4a0eff0112298de0a97b63e4e22826bf2b4126c.tar.gz emacs-c4a0eff0112298de0a97b63e4e22826bf2b4126c.tar.bz2 emacs-c4a0eff0112298de0a97b63e4e22826bf2b4126c.zip |
Add seq-partition and seq-group-by
* lisp/emacs-lisp/seq.el: Better docstring for seq.el functions
* test/automated/seq-tests.el: New tests for seq-partition and
seq-group-by
Diffstat (limited to 'lisp/emacs-lisp')
-rw-r--r-- | lisp/emacs-lisp/seq.el | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/lisp/emacs-lisp/seq.el b/lisp/emacs-lisp/seq.el index bd234a3b55a..cd45989eca8 100644 --- a/lisp/emacs-lisp/seq.el +++ b/lisp/emacs-lisp/seq.el @@ -230,6 +230,33 @@ The result is a sequence of type TYPE, or a list if TYPE is nil." (apply #'seq-concatenate (or type 'list) (seq-map function seq))) +(defun seq-partition (seq n) + "Return a list of the elements of SEQ grouped into sub-sequences of length N. +The last sequence may contain less than N elements. If N is a +negative integer or 0, nil is returned." + (unless (< n 1) + (let ((result '())) + (while (not (seq-empty-p seq)) + (push (seq-take seq n) result) + (setq seq (seq-drop seq n))) + (nreverse result)))) + +(defun seq-group-by (function seq) + "Apply FUNCTION to each element of SEQ. +Separate the elements of SEQ into an alist using the results as +keys. Keys are compared using `equal'." + (nreverse + (seq-reduce + (lambda (acc elt) + (let* ((key (funcall function elt)) + (cell (assoc key acc))) + (if cell + (setcdr cell (push elt (cdr cell))) + (push (list key elt) acc)) + acc)) + seq + nil))) + (defun seq--drop-list (list n) "Optimized version of `seq-drop' for lists." (while (and list (> n 0)) |