diff --git a/lisp/ob-core.el b/lisp/ob-core.el index 7591e99ca..a4b2294d7 100644 --- a/lisp/ob-core.el +++ b/lisp/ob-core.el @@ -679,14 +679,14 @@ block." (dir (cdr (assq :dir params))) (mkdirp (cdr (assq :mkdirp params))) (default-directory - (or (and dir - (not (member mkdirp '("no" "nil" nil))) - (progn - (let ((d (file-name-as-directory - (expand-file-name dir)))) - (make-directory d 'parents) - d))) - default-directory)) + (cond + ((not dir) default-directory) + ((member mkdirp '("no" "nil" nil)) + (file-name-as-directory (expand-file-name dir))) + (t + (let ((d (file-name-as-directory (expand-file-name dir)))) + (make-directory d 'parents) + d)))) (cmd (intern (concat "org-babel-execute:" lang))) result) (unless (fboundp cmd) diff --git a/testing/lisp/test-ob.el b/testing/lisp/test-ob.el index facc0a4ba..d1b3f333a 100644 --- a/testing/lisp/test-ob.el +++ b/testing/lisp/test-ob.el @@ -1633,7 +1633,14 @@ t (org-babel-execute-src-block) (message default-directory) (prog1 (file-directory-p "data/code") - (delete-directory "data" t))))) + (delete-directory "data" t)))) + (should + (equal "/tmp/test-dir-no-mkdirp/" + (org-test-with-temp-text-in-file + "#+begin_src emacs-lisp :dir /tmp/test-dir-no-mkdirp +default-directory +#+end_src" + (org-babel-execute-src-block))))) (ert-deftest test-ob/script-escape () ;; Delimited lists of numbers