[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[O] [PATCH 2/7] New macro: Evaluate FORM in ENVIRONMENT
From: |
David Maus |
Subject: |
[O] [PATCH 2/7] New macro: Evaluate FORM in ENVIRONMENT |
Date: |
Tue, 2 Aug 2011 11:23:35 +0200 |
* org-macs.el (org-eval-in-environment): New macro. Evaluate
FORM in ENVIRONMENT.
(org-with-uninterned): Move to top of file.
---
lisp/org-macs.el | 23 ++++++++++++++++++-----
1 files changed, 18 insertions(+), 5 deletions(-)
diff --git a/lisp/org-macs.el b/lisp/org-macs.el
index 53c60e5..7a0cc60 100644
--- a/lisp/org-macs.el
+++ b/lisp/org-macs.el
@@ -47,6 +47,12 @@
(declare-function org-add-props "org-compat" (string plist &rest props))
(declare-function org-string-match-p "org-compat" (&rest args))
+(defmacro org-with-uninterned (symbols &rest body)
+ `(let ,(mapcar (lambda (s)
+ `(,s (make-symbol (symbol-name ',s)))) symbols)
+ ,@body))
+(put 'org-with-uninterned 'lisp-indent-function 1)
+
(defmacro org-called-interactively-p (&optional kind)
(if (featurep 'xemacs)
`(interactive-p)
@@ -370,11 +376,18 @@ The number of levels is controlled by
`org-inlinetask-min-level'"
(format-seconds string seconds)
(format-time-string string (seconds-to-time seconds))))
-(defmacro org-with-uninterned (symbols &rest body)
- `(let ,(mapcar (lambda (s)
- `(,s (make-symbol (symbol-name ',s)))) symbols)
- ,@body))
-(put 'org-with-uninterned 'lisp-indent-function 1)
+(defun org-make-parameter-alist (flat)
+ "Return alist based on FLAT.
+FLAT is a list with alternating symbol names and values. The
+returned alist is a list of lists with the symbol name in car and
+the value in cdr."
+ (when flat
+ (cons (list (car flat) (cadr flat))
+ (org-make-parameter-alist (cddr flat)))))
+
+(defmacro org-eval-in-environment (environment form)
+ `(eval '(let ,environment ,form)))
+(put 'org-eval-in-environment 'lisp-indent-function 1)
(provide 'org-macs)
--
1.7.2.5
[O] [PATCH 2/7] New macro: Evaluate FORM in ENVIRONMENT,
David Maus <=
[O] [PATCH 3/7] Use new macro org-with-uninterned, David Maus, 2011/08/02
[O] [PATCH 4/7] New function: Substitute posix classes in regular expression, David Maus, 2011/08/02
[O] [PATCH 5/7] Use macro org-with-uninterned, David Maus, 2011/08/02
[O] [PATCH 6/7] Use org-eval-in-environment, make macros functions, David Maus, 2011/08/02
[O] [PATCH 7/7] Make org-batch-store-agenda-views a fun, use org-eval-in-environment, David Maus, 2011/08/02
Re: [O] [PATCH 0/8] Org mode macros, refactored, David Maus, 2011/08/02
Re: [O] [PATCH 0/8] Org mode macros, refactored, Štěpán Němec, 2011/08/02