Merge branch 'master' of git+ssh://repo.or.cz/srv/git/org-mode

This commit is contained in:
Carsten Dominik 2010-06-08 00:01:28 +02:00
commit 599c8a7114
6 changed files with 130 additions and 59 deletions

View File

@ -35,6 +35,32 @@
The raw Org-mode text of this file can be downloaded at The raw Org-mode text of this file can be downloaded at
[[repofile:contrib/babel/library-of-babel.org][library-of-babel.org]] [[repofile:contrib/babel/library-of-babel.org][library-of-babel.org]]
* File I/O
** reading and writing files
Read the contents of the file at =path= into a string.
#+srcname: read
#+begin_src emacs-lisp :var path=""
(with-temp-filebuffer path
(buffer-substring (point-min) (point-max)))
#+end_src
Read the lines of the file at =path= into a list.
#+srcname: read-lines
#+begin_src emacs-lisp :var path=""
(split-string
(with-temp-filebuffer path
(buffer-substring (point-min) (point-max))))
#+end_src
Write =data= to a file at =path=. If =data= is a list, then write it
as a table in traditional Org-mode table syntax.
#+srcname: write
#+begin_src emacs-lisp :var data="" :var path=""
(with-temp-file path
(org-babel-insert-result data))
nil
#+end_src
* Plotting code * Plotting code
** R ** R

View File

@ -65,13 +65,15 @@ called by `org-babel-execute-src-block'."
(result-params (third processed-params)) (result-params (third processed-params))
(result-type (fourth processed-params)) (result-type (fourth processed-params))
(full-body (org-babel-expand-body:ruby (full-body (org-babel-expand-body:ruby
body params processed-params)) ;; then the source block body body params processed-params))
(result (org-babel-ruby-evaluate session full-body result-type))) (result (org-babel-ruby-evaluate session full-body result-type)))
(or (cdr (assoc :file params)) (or (cdr (assoc :file params))
(org-babel-reassemble-table (org-babel-reassemble-table
result result
(org-babel-pick-name (nth 4 processed-params) (cdr (assoc :colnames params))) (org-babel-pick-name (nth 4 processed-params)
(org-babel-pick-name (nth 5 processed-params) (cdr (assoc :rownames params))))))) (cdr (assoc :colnames params)))
(org-babel-pick-name (nth 5 processed-params)
(cdr (assoc :rownames params)))))))
(defun org-babel-prep-session:ruby (session params) (defun org-babel-prep-session:ruby (session params)
"Prepare SESSION according to the header arguments specified in PARAMS." "Prepare SESSION according to the header arguments specified in PARAMS."
@ -129,9 +131,10 @@ Emacs-lisp table, otherwise return the results as a string."
"If there is not a current inferior-process-buffer in SESSION "If there is not a current inferior-process-buffer in SESSION
then create. Return the initialized session." then create. Return the initialized session."
(unless (string= session "none") (unless (string= session "none")
(let ((session-buffer (save-window-excursion (run-ruby nil session) (current-buffer)))) (let ((session-buffer (save-window-excursion
(run-ruby nil session) (current-buffer))))
(if (org-babel-comint-buffer-livep session-buffer) (if (org-babel-comint-buffer-livep session-buffer)
session-buffer (progn (sit-for .25) session-buffer)
(sit-for .5) (sit-for .5)
(org-babel-ruby-initiate-session session))))) (org-babel-ruby-initiate-session session)))))
@ -175,24 +178,30 @@ last statement in BODY, as elisp."
(with-temp-buffer (with-temp-buffer
(insert body) (insert body)
;; (message "buffer=%s" (buffer-string)) ;; debugging ;; (message "buffer=%s" (buffer-string)) ;; debugging
(org-babel-shell-command-on-region (point-min) (point-max) "ruby" 'current-buffer 'replace) (org-babel-shell-command-on-region
(point-min) (point-max) "ruby" 'current-buffer 'replace)
(buffer-string))) (buffer-string)))
(value (value
(let* ((tmp-file (make-temp-file "ruby-functional-results")) exit-code (let* ((tmp-file (make-temp-file "ruby-functional-results"))
exit-code
(stderr (stderr
(with-temp-buffer (with-temp-buffer
(insert (format (if (member "pp" result-params) (insert (format (if (member "pp" result-params)
org-babel-ruby-pp-wrapper-method org-babel-ruby-pp-wrapper-method
org-babel-ruby-wrapper-method) body tmp-file)) org-babel-ruby-wrapper-method)
;; (message "buffer=%s" (buffer-string)) ;; debugging body tmp-file))
(setq exit-code (setq exit-code
(org-babel-shell-command-on-region (point-min) (point-max) "ruby" nil 'replace (current-buffer))) (org-babel-shell-command-on-region
(point-min) (point-max) "ruby"
nil 'replace (current-buffer)))
(buffer-string)))) (buffer-string))))
(if (> exit-code 0) (org-babel-error-notify exit-code stderr)) (if (> exit-code 0) (org-babel-error-notify exit-code stderr))
(let ((raw (with-temp-buffer (let ((raw (with-temp-buffer
(insert-file-contents (org-babel-maybe-remote-file tmp-file)) (insert-file-contents
(org-babel-maybe-remote-file tmp-file))
(buffer-string)))) (buffer-string))))
(if (or (member "code" result-params) (member "pp" result-params)) (if (or (member "code" result-params)
(member "pp" result-params))
raw raw
(org-babel-ruby-table-or-string raw))))))) (org-babel-ruby-table-or-string raw)))))))
;; comint session evaluation ;; comint session evaluation
@ -203,11 +212,13 @@ last statement in BODY, as elisp."
org-babel-ruby-pp-last-value-eval org-babel-ruby-pp-last-value-eval
org-babel-ruby-last-value-eval) org-babel-ruby-last-value-eval)
org-babel-ruby-eoe-indicator) "\n")) org-babel-ruby-eoe-indicator) "\n"))
(raw (org-babel-comint-with-output buffer org-babel-ruby-eoe-indicator t (raw (org-babel-comint-with-output
buffer org-babel-ruby-eoe-indicator t
(insert full-body) (comint-send-input nil t))) (insert full-body) (comint-send-input nil t)))
(results (cdr (member org-babel-ruby-eoe-indicator (results (cdr (member
(reverse (mapcar #'org-babel-ruby-read-string org-babel-ruby-eoe-indicator
(mapcar #'org-babel-trim raw))))))) (reverse (mapcar #'org-babel-ruby-read-string
(mapcar #'org-babel-trim raw)))))))
(case result-type (case result-type
(output (mapconcat #'identity (reverse (cdr results)) "\n")) (output (mapconcat #'identity (reverse (cdr results)) "\n"))
(value (value

View File

@ -52,38 +52,53 @@ body inside the protection of `save-window-excursion' and
(set-buffer ,buffer) (set-buffer ,buffer)
,@body))) ,@body)))
(defmacro org-babel-comint-with-output (buffer eoe-indicator remove-echo &rest body) (defmacro org-babel-comint-with-output
(buffer eoe-indicator remove-echo &rest body)
"Evaluate BODY in BUFFER, wait until EOE-INDICATOR appears in "Evaluate BODY in BUFFER, wait until EOE-INDICATOR appears in
output, then return all process output. This ensures that the output, then return all process output. This ensures that the
filter is removed in case of an error or user `keyboard-quit' filter is removed in case of an error or user `keyboard-quit'
during execution of body." during execution of body."
(declare (indent 3)) (declare (indent 3))
`(org-babel-comint-in-buffer ,buffer `(org-babel-comint-in-buffer ,buffer
(let ((string-buffer "")) (let ((string-buffer "") dangling-text)
(flet ((my-filt (text) (setq string-buffer (concat string-buffer text)))) (flet ((my-filt (text) (setq string-buffer (concat string-buffer text))))
;; setup filter ;; setup filter
(add-hook 'comint-output-filter-functions 'my-filt) (add-hook 'comint-output-filter-functions 'my-filt)
(unwind-protect (unwind-protect
(progn (progn
;; pass FULL-BODY to process ;; got located, and save dangling text
(goto-char (process-mark (get-buffer-process (current-buffer)))) (goto-char (process-mark (get-buffer-process (current-buffer))))
(let ((start (point))
(end (point-max)))
(setq dangling-text (buffer-substring start end))
(delete-region start end))
;; pass FULL-BODY to process
,@body ,@body
;; wait for end-of-evaluation indicator ;; wait for end-of-evaluation indicator
(while (progn (while (progn
(goto-char comint-last-input-end) (goto-char comint-last-input-end)
(not (save-excursion (not (save-excursion
(and (re-search-forward comint-prompt-regexp nil t) (and (re-search-forward
(re-search-forward (regexp-quote ,eoe-indicator) nil t))))) comint-prompt-regexp nil t)
(re-search-forward
(regexp-quote ,eoe-indicator) nil t)))))
(accept-process-output (get-buffer-process (current-buffer))) (accept-process-output (get-buffer-process (current-buffer)))
;; ;; thought this would allow async background running, but I was wrong... ;; thought the following this would allow async
;; (run-with-timer .5 .5 'accept-process-output (get-buffer-process (current-buffer))) ;; background running, but I was wrong...
)) ;; (run-with-timer .5 .5 'accept-process-output
;; (get-buffer-process (current-buffer)))
)
;; replace cut dangling text
(goto-char (process-mark (get-buffer-process (current-buffer))))
(insert dangling-text))
;; remove filter ;; remove filter
(remove-hook 'comint-output-filter-functions 'my-filt))) (remove-hook 'comint-output-filter-functions 'my-filt)))
;; remove echo'd FULL-BODY from input ;; remove echo'd FULL-BODY from input
(if (and ,remove-echo (if (and ,remove-echo
(string-match (string-match
(replace-regexp-in-string "\n" "\r\n" (regexp-quote ,full-body)) string-buffer)) (replace-regexp-in-string
"\n" "[\r\n]+" (regexp-quote ,full-body))
string-buffer))
(setq raw (substring string-buffer (match-end 0)))) (setq raw (substring string-buffer (match-end 0))))
(split-string string-buffer comint-prompt-regexp)))) (split-string string-buffer comint-prompt-regexp))))

View File

@ -121,18 +121,25 @@ options are taken from `org-babel-default-header-args'."
(defun org-babel-exp-do-export (info type) (defun org-babel-exp-do-export (info type)
"Return a string containing the exported content of the current "Return a string containing the exported content of the current
code block respecting the value of the :exports header argument." code block respecting the value of the :exports header argument."
(case (intern (or (cdr (assoc :exports (third info))) "code")) (flet ((silently () (let ((session (cdr (assoc :session (third info)))))
('none "") (when (and session
('code (org-babel-exp-code info type)) (not (equal "none" session))
('results (org-babel-exp-results info type)) (not (assoc :noeval (third info))))
('both (concat (org-babel-exp-code info type) (org-babel-exp-results info type 'silent))))
"\n\n" (clean () (org-babel-remove-result info)))
(org-babel-exp-results info type))))) (case (intern (or (cdr (assoc :exports (third info))) "code"))
('none (silently) (clean) "")
('code (silently) (clean) (org-babel-exp-code info type))
('results (org-babel-exp-results info type))
('both (concat (org-babel-exp-code info type)
"\n\n"
(org-babel-exp-results info type))))))
(defun org-babel-exp-code (info type) (defun org-babel-exp-code (info type)
"Return the code the current code block in a manner suitable "Return the code the current code block in a manner suitable
for exportation by org-mode. This function is called by for exportation by org-mode. This function is called by
`org-babel-exp-do-export'." `org-babel-exp-do-export'. The code block will not be
evaluated."
(let ((lang (first info)) (let ((lang (first info))
(body (second info)) (body (second info))
(switches (fourth info)) (switches (fourth info))
@ -165,10 +172,12 @@ for exportation by org-mode. This function is called by
call-line)) call-line))
((t (format ": %s\n" call-line))))))))) ((t (format ": %s\n" call-line)))))))))
(defun org-babel-exp-results (info type) (defun org-babel-exp-results (info type &optional silent)
"Return the results of the current code block in a manner "Return the results of the current code block in a manner
suitable for exportation by org-mode. This function is called by suitable for exportation by org-mode. This function is called by
`org-babel-exp-do-export'." `org-babel-exp-do-export'. The code block will be evaluated.
Optional argument SILENT can be used to inhibit insertion of
results into the buffer."
(let ((lang (first info)) (let ((lang (first info))
(body (second info)) (body (second info))
(params (params
@ -189,28 +198,31 @@ suitable for exportation by org-mode. This function is called by
(let ((raw (org-babel-execute-src-block (let ((raw (org-babel-execute-src-block
nil info '((:results . "silent")))) nil info '((:results . "silent"))))
(result-params (split-string (cdr (assoc :results params))))) (result-params (split-string (cdr (assoc :results params)))))
(cond ;; respect the value of the :results header argument (unless silent
((member "file" result-params) (cond ;; respect the value of the :results header argument
(org-babel-result-to-file raw)) ((member "file" result-params)
((or (member "raw" result-params) (member "org" result-params)) (org-babel-result-to-file raw))
(format "%s" raw)) ((or (member "raw" result-params) (member "org" result-params))
((member "code" result-params) (format "%s" raw))
(format "src_%s{%s}" lang raw)) ((member "code" result-params)
(t (format "src_%s{%s}" lang raw))
(if (stringp raw) (t
(if (= 0 (length raw)) "=(no results)=" (if (stringp raw)
(format "=%s=" raw)) (if (= 0 (length raw)) "=(no results)="
(format "=%S=" raw)))))) (format "=%s=" raw))
(format "=%S=" raw)))))))
('block ('block
(org-babel-execute-src-block (org-babel-execute-src-block
nil nil (org-babel-merge-params params '((:results . "replace")))) nil nil (org-babel-merge-params
params `((:results . ,(if silent "silent" "replace")))))
"") "")
('lob ('lob
(save-excursion (save-excursion
(re-search-backward org-babel-lob-one-liner-regexp nil t) (re-search-backward org-babel-lob-one-liner-regexp nil t)
(org-babel-execute-src-block (org-babel-execute-src-block
nil (list lang body (org-babel-merge-params nil (list lang body
params '((:results . "replace"))))) ""))))) (org-babel-merge-params
params `((:results . ,(if silent "silent" "replace")))))) "")))))
(provide 'org-babel-exp) (provide 'org-babel-exp)
;;; org-babel-exp.el ends here ;;; org-babel-exp.el ends here

View File

@ -255,7 +255,8 @@ form
"no") "no")
(fifth spec))))) (fifth spec)))))
(insert-comment (format "[[%s][%s]]" (org-link-escape link) source-name)) (insert-comment (format "[[%s][%s]]" (org-link-escape link) source-name))
(insert (format "\n%s\n" (org-babel-chomp body))) (insert (format "\n%s\n" (replace-regexp-in-string
"^," "" (org-babel-chomp body))))
(insert-comment (format "%s ends here" source-name))))) (insert-comment (format "%s ends here" source-name)))))
(provide 'org-babel-tangle) (provide 'org-babel-tangle)

View File

@ -46,7 +46,9 @@ then run `org-babel-execute-src-block'."
then run `org-babel-expand-src-block'." then run `org-babel-expand-src-block'."
(interactive) (interactive)
(let ((info (org-babel-get-src-block-info))) (let ((info (org-babel-get-src-block-info)))
(if info (progn (org-babel-expand-src-block current-prefix-arg info) t) nil))) (if info
(progn (org-babel-expand-src-block current-prefix-arg info) t)
nil)))
(defadvice org-edit-special (around org-babel-prep-session-for-edit activate) (defadvice org-edit-special (around org-babel-prep-session-for-edit activate)
"Prepare the current source block's session according to it's "Prepare the current source block's session according to it's
@ -75,7 +77,9 @@ to `org-open-at-point'."
then run `org-babel-load-in-session'." then run `org-babel-load-in-session'."
(interactive) (interactive)
(let ((info (org-babel-get-src-block-info))) (let ((info (org-babel-get-src-block-info)))
(if info (progn (org-babel-load-in-session current-prefix-arg info) t) nil))) (if info
(progn (org-babel-load-in-session current-prefix-arg info) t)
nil)))
(add-hook 'org-metaup-hook 'org-babel-load-in-session-maybe) (add-hook 'org-metaup-hook 'org-babel-load-in-session-maybe)
@ -89,7 +93,8 @@ then run `org-babel-pop-to-session'."
(add-hook 'org-metadown-hook 'org-babel-pop-to-session-maybe) (add-hook 'org-metadown-hook 'org-babel-pop-to-session-maybe)
(defconst org-babel-header-arg-names (defconst org-babel-header-arg-names
'(cache cmdline colnames dir exports file noweb results session tangle var) '(cache cmdline colnames dir exports file noweb results
session tangle var noeval)
"Common header arguments used by org-babel. Note that "Common header arguments used by org-babel. Note that
individual languages may define their own language specific individual languages may define their own language specific
header arguments as well.") header arguments as well.")
@ -384,10 +389,11 @@ the current buffer."
"Call `org-babel-execute-src-block' on every source block in "Call `org-babel-execute-src-block' on every source block in
the current subtree." the current subtree."
(interactive "P") (interactive "P")
(save-excursion (save-restriction
(org-narrow-to-subtree) (save-excursion
(org-babel-execute-buffer) (org-narrow-to-subtree)
(widen))) (org-babel-execute-buffer)
(widen))))
(defun org-babel-get-src-block-info (&optional header-vars-only) (defun org-babel-get-src-block-info (&optional header-vars-only)
"Get information of the current source block. "Get information of the current source block.
@ -965,7 +971,7 @@ code ---- the results are extracted in the syntax of the source
(listp (cdr (car result))))) (listp (cdr (car result)))))
result (list result)) result (list result))
'(:fmt (lambda (cell) (format "%s" cell)))) "\n")) '(:fmt (lambda (cell) (format "%s" cell)))) "\n"))
(goto-char beg) (org-cycle)) (goto-char beg) (org-table-align))
((member "file" result-params) ((member "file" result-params)
(insert result)) (insert result))
((member "html" result-params) ((member "html" result-params)