[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[elpa] externals/dash 4e76865 075/439: Add !take-while
From: |
Phillip Lord |
Subject: |
[elpa] externals/dash 4e76865 075/439: Add !take-while |
Date: |
Tue, 04 Aug 2015 20:26:34 +0000 |
branch: externals/dash
commit 4e76865ace9dad63721272e59a11f09b37823e28
Author: Magnar Sveen <address@hidden>
Commit: Magnar Sveen <address@hidden>
Add !take-while
---
README.md | 11 +++++++++++
bang.el | 15 +++++++++++++++
examples.el | 5 +++++
3 files changed, 31 insertions(+), 0 deletions(-)
diff --git a/README.md b/README.md
index 5441fd2..15da0c9 100644
--- a/README.md
+++ b/README.md
@@ -20,6 +20,7 @@ Or you can just dump `bang.el` in your load path somewhere.
* [!keep](#keep-fn-list) `(fn list)`
* [!concat](#concat-rest-lists) `(&rest lists)`
* [!mapcat](#mapcat-fn-list) `(fn list)`
+* [!take-while](#take-while-fn-list) `(fn list)`
* [!interpose](#interpose-sep-list) `(sep list)`
* [!replace-where](#replace-where-pred-rep-list) `(pred rep list)`
* [!first](#first-fn-list) `(fn list)`
@@ -162,6 +163,16 @@ Thus function `fn` should return a collection.
(!!mapcat (list 0 it) '(1 2 3)) ;; => '(0 1 0 2 0 3)
```
+### !take-while `(fn list)`
+
+Returns a new list of successive items from `list` while (`fn` item) returns a
non-nil value.
+
+```cl
+(!take-while 'even? '(1 2 3 4)) ;; => '()
+(!take-while 'even? '(2 4 5 6)) ;; => '(2 4)
+(!!take-while (< it 4) '(1 2 3 4 3 2 1)) ;; => '(1 2 3)
+```
+
### !interpose `(sep list)`
Returns a new list of all elements in `list` separated by `sep`.
diff --git a/bang.el b/bang.el
index 4f5c404..4fc290f 100644
--- a/bang.el
+++ b/bang.el
@@ -144,6 +144,21 @@ the supplied LISTS."
Thus function FN should return a collection."
(!!mapcat (funcall fn it) list))
+(defmacro !!take-while (form list)
+ "Anaphoric form of `!take-while'."
+ (let ((l (make-symbol "list"))
+ (r (make-symbol "result")))
+ `(let ((,l ,list)
+ (,r '()))
+ (while (and ,l (let ((it (car ,l))) ,form))
+ (setq ,r (cons (car ,l) ,r))
+ (setq ,l (cdr ,l)))
+ (nreverse ,r))))
+
+(defun !take-while (fn list)
+ "Returns a new list of successive items from LIST while (FN item) returns a
non-nil value."
+ (!!take-while (funcall fn it) list))
+
(defun !interpose (sep list)
"Returns a new list of all elements in LIST separated by SEP."
(let (result)
diff --git a/examples.el b/examples.el
index d894a4d..32f9221 100644
--- a/examples.el
+++ b/examples.el
@@ -58,6 +58,11 @@
(!mapcat (lambda (item) (list 0 item)) '(1 2 3)) => '(0 1 0 2 0 3)
(!!mapcat (list 0 it) '(1 2 3)) => '(0 1 0 2 0 3))
+(defexamples !take-while
+ (!take-while 'even? '(1 2 3 4)) => '()
+ (!take-while 'even? '(2 4 5 6)) => '(2 4)
+ (!!take-while (< it 4) '(1 2 3 4 3 2 1)) => '(1 2 3))
+
(defexamples !interpose
(!interpose "-" '()) => '()
(!interpose "-" '("a")) => '("a")
- [elpa] externals/dash 05dec7a 062/439: Fix example., (continued)
- [elpa] externals/dash 05dec7a 062/439: Fix example., Phillip Lord, 2015/08/04
- [elpa] externals/dash 4205e58 064/439: Add clojure threading macros, !-> and !->>, Phillip Lord, 2015/08/04
- [elpa] externals/dash 6520496 060/439: First release, remove warning., Phillip Lord, 2015/08/04
- [elpa] externals/dash ca3eea7 070/439: Fix examples-to-docs to support documenting macros., Phillip Lord, 2015/08/04
- [elpa] externals/dash b29a5bb 071/439: Use make-symbol in macros to avoid names clashing., Phillip Lord, 2015/08/04
- [elpa] externals/dash 6f17346 068/439: Don't run !rpartial tests on Emacsen <24, Phillip Lord, 2015/08/04
- [elpa] externals/dash 66ffaa6 072/439: Add !interpose, Phillip Lord, 2015/08/04
- [elpa] externals/dash ec6a85f 074/439: Add threading macro !!-> with `it` as placeholder., Phillip Lord, 2015/08/04
- [elpa] externals/dash 9410f7e 073/439: Add !replace-where, Phillip Lord, 2015/08/04
- [elpa] externals/dash cd2a793 069/439: Run travis-ci on both E23 and E24, Phillip Lord, 2015/08/04
- [elpa] externals/dash 4e76865 075/439: Add !take-while,
Phillip Lord <=
- [elpa] externals/dash 6238f8f 077/439: Add !split-with, Phillip Lord, 2015/08/04
- [elpa] externals/dash b9b6330 079/439: Add !take, Phillip Lord, 2015/08/04
- [elpa] externals/dash 8c75026 080/439: Add !drop, Phillip Lord, 2015/08/04
- [elpa] externals/dash 123eaaa 078/439: Docs: Refer to !replace-where from !!replace-where., Phillip Lord, 2015/08/04
- [elpa] externals/dash ec835e4 081/439: Add !split-at, Phillip Lord, 2015/08/04
- [elpa] externals/dash 3802890 082/439: Simplify !concat, Phillip Lord, 2015/08/04
- [elpa] externals/dash fea1aa3 086/439: Add -interleave, Phillip Lord, 2015/08/04
- [elpa] externals/dash 0dab44c 084/439: Add -flatten, Phillip Lord, 2015/08/04
- [elpa] externals/dash 82a12a2 076/439: Add !drop-while, Phillip Lord, 2015/08/04
- [elpa] externals/dash 9ff9fd0 085/439: Move functions that are not strictly list related last., Phillip Lord, 2015/08/04