[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[elpa] externals/dash e720428 010/439: Extract basic iteration form into
From: |
Phillip Lord |
Subject: |
[elpa] externals/dash e720428 010/439: Extract basic iteration form into macro. |
Date: |
Tue, 04 Aug 2015 20:25:50 +0000 |
branch: externals/dash
commit e7204280cec92deba0b52ad9e392c6bd7755c485
Author: Magnar Sveen <address@hidden>
Commit: Magnar Sveen <address@hidden>
Extract basic iteration form into macro.
- needs some love
---
bang.el | 32 +++++++++++++++-----------------
1 files changed, 15 insertions(+), 17 deletions(-)
diff --git a/bang.el b/bang.el
index 8859802..1436a9c 100644
--- a/bang.el
+++ b/bang.el
@@ -46,37 +46,35 @@ It should only be set using dynamic scope with a let, like:
(defun !mapcat (fn list)
(!concat (!map fn list)))
+(defmacro !--iterate-with-result (&rest forms)
+ `(let (result)
+ (while list
+ (let ((it (car list))) ,@forms)
+ (setq list (cdr list)))
+ (nreverse result)))
+
(defun !uniq (list)
"Return a new list with all duplicates removed.
The test for equality is done with `equal',
or with `!compare-fn' if that's non-nil."
- (let (result)
- (while list
- (add-to-list 'result (car list) nil !compare-fn)
- (setq list (cdr list)))
- (nreverse result)))
+ (!--iterate-with-result
+ (add-to-list 'result it nil !compare-fn)))
(defun !intersection (list list2)
"Return a new list containing only the elements that are members of both
LIST and LIST2.
The test for equality is done with `equal',
or with `!compare-fn' if that's non-nil."
- (let (result)
- (while list
- (when (!contains-p list2 (car list))
- (setq result (cons (car list) result)))
- (setq list (cdr list)))
- (nreverse result)))
+ (!--iterate-with-result
+ (when (!contains-p list2 it)
+ (setq result (cons it result)))))
(defun !difference (list list2)
"Return a new list with only the members of LIST that are not in LIST2.
The test for equality is done with `equal',
or with `!compare-fn' if that's non-nil."
- (let (result)
- (while list
- (unless (!contains-p list2 (car list))
- (setq result (cons (car list) result)))
- (setq list (cdr list)))
- (nreverse result)))
+ (!--iterate-with-result
+ (unless (!contains-p list2 it)
+ (setq result (cons it result)))))
(defun !contains-p (list element)
"Return whether LIST contains ELEMENT.
- [elpa] branch externals/dash created (now eadb265), Phillip Lord, 2015/08/04
- [elpa] externals/dash 300fbc6 002/439: Remove lisp-comments from README, Phillip Lord, 2015/08/04
- [elpa] externals/dash 9a34da8 004/439: Add config for travis-ci, Phillip Lord, 2015/08/04
- [elpa] externals/dash 302c8ea 001/439: Initial commit., Phillip Lord, 2015/08/04
- [elpa] externals/dash 14673a6 007/439: Use nreverse for performance reasons., Phillip Lord, 2015/08/04
- [elpa] externals/dash 7b52951 008/439: Add watchr script to get autotest, Phillip Lord, 2015/08/04
- [elpa] externals/dash 93957f0 006/439: Add travis status icon to README, Phillip Lord, 2015/08/04
- [elpa] externals/dash ad44aee 009/439: Add more tests., Phillip Lord, 2015/08/04
- [elpa] externals/dash 065f76b 005/439: Use ert.el to run on Emacs 23 as well., Phillip Lord, 2015/08/04
- [elpa] externals/dash e720428 010/439: Extract basic iteration form into macro.,
Phillip Lord <=
- [elpa] externals/dash c229ba8 011/439: Rewrite to anaphoric filter function., Phillip Lord, 2015/08/04
- [elpa] externals/dash d870282 013/439: Add some tests, and fix the bugs they uncovered., Phillip Lord, 2015/08/04
- [elpa] externals/dash 3e0ef58 012/439: !filter can now take either a function or form (anaphoric), Phillip Lord, 2015/08/04
- [elpa] externals/dash b24d056 014/439: !map macro, Phillip Lord, 2015/08/04
- [elpa] externals/dash ed2e447 015/439: !reduce macro, Phillip Lord, 2015/08/04
- [elpa] externals/dash f9471e4 016/439: !concat done - one less 'cl dependency, Phillip Lord, 2015/08/04
- [elpa] externals/dash 4201ecd 017/439: Out with remove-if, in with !reject, Phillip Lord, 2015/08/04
- [elpa] externals/dash f5b16e3 018/439: Make !partial have the same quote-less API as the rest of bang., Phillip Lord, 2015/08/04
- [elpa] externals/dash a02b6c1 021/439: Add note about no 'cl required., Phillip Lord, 2015/08/04
- [elpa] externals/dash 07de30e 019/439: !mapcat macro, and with that: goodbye 'cl!, Phillip Lord, 2015/08/04