* 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