Eric Schulte 16 лет назад
Родитель
Сommit
b7c32fc5d8
4 измененных файлов с 11 добавлено и 9 удалено
  1. 1 1
      lisp/langs/org-babel-R.el
  2. 3 1
      lisp/langs/org-babel-shell.el
  3. 1 1
      lisp/org-babel-comint.el
  4. 6 6
      org-babel.org

+ 1 - 1
lisp/langs/org-babel-R.el

@@ -90,7 +90,7 @@ R process in `org-babel-R-buffer'."
 
 (defun org-babel-R-initiate-session (session)
   "If there is not a current R process then create one."
-  (message "session is %S" session)
+  (setq session (or session "*R*"))
   (if (org-babel-comint-buffer-livep session)
       session
     (save-window-excursion (R) (rename-buffer (if (bufferp session) (buffer-name session)

+ 3 - 1
lisp/langs/org-babel-shell.el

@@ -86,7 +86,9 @@ Emacs-lisp table, otherwise return the results as a string."
 (defun org-babel-shell-initiate-session (&optional session)
   "If there is not a current inferior-process-buffer in SESSION
 then create.  Return the initialized session."
-  (save-window-excursion (shell session) (current-buffer)))
+  (save-window-excursion (shell session)
+                         (org-babel-comint-wait-for-output (current-buffer))
+                         (current-buffer)))
 
 (defvar org-babel-shell-eoe-indicator "echo 'org_babel_shell_eoe'"
   "Used to indicate that evaluation is has completed.")

+ 1 - 1
lisp/org-babel-comint.el

@@ -37,7 +37,7 @@
 (require 'comint)
 
 (defun org-babel-comint-buffer-livep (buffer)
-  (let ((buffer (get-buffer buffer)))
+  (let ((buffer (if buffer (get-buffer buffer))))
     (and buffer (buffer-live-p buffer) (get-buffer-process buffer) buffer)))
 
 (defmacro org-babel-comint-in-buffer (buffer &rest body)

+ 6 - 6
org-babel.org

@@ -1980,14 +1980,14 @@ of these tests may fail.
 | shell                   | basic-shell                |     |           6 |           6 | pass                              |
 | ruby                    | basic-ruby                 |     |   org-babel |   org-babel | pass                              |
 | python                  | basic-python               |     | hello world | hello world | pass                              |
-| R                       | basic-R                    |     |          13 |      #ERROR | expected "13" but was "#ERROR"    |
+| R                       | basic-R                    |     |          13 |          13 | pass                              |
 |-------------------------+----------------------------+-----+-------------+-------------+-----------------------------------|
 | tables                  |                            |     |             |             | pass                              |
 |-------------------------+----------------------------+-----+-------------+-------------+-----------------------------------|
 | emacs lisp              | table-elisp                |     |           3 |           3 | pass                              |
 | ruby                    | table-ruby                 |     |       1-2-3 |       1-2-3 | pass                              |
 | python                  | table-python               |     |           5 |           5 | pass                              |
-| R                       | table-R                    |     |         3.5 |      #ERROR | expected "3.5" but was "#ERROR"   |
+| R                       | table-R                    |     |         3.5 |         3.5 | pass                              |
 |-------------------------+----------------------------+-----+-------------+-------------+-----------------------------------|
 | source block references |                            |     |             |             | pass                              |
 |-------------------------+----------------------------+-----+-------------+-------------+-----------------------------------|
@@ -2005,10 +2005,10 @@ of these tests may fail.
 |-------------------------+----------------------------+-----+-------------+-------------+-----------------------------------|
 | bugs and tasks          |                            |     |             |             | pass                              |
 |-------------------------+----------------------------+-----+-------------+-------------+-----------------------------------|
-| simple ruby arrays      | ruby-array-test            |     |           3 |           3 | pass                              |
-| R number evaluation     | bug-R-number-evaluation    |     |           2 |      #ERROR | expected "2" but was "#ERROR"     |
-| multi-line ruby blocks  | multi-line-ruby-test       |     |           2 |      #ERROR | expected "2" but was "#ERROR"     |
-| forcing vector results  | test-forced-vector-results |     |       Array |      #ERROR | expected "Array" but was "#ERROR" |
+| simple ruby arrays      | ruby-array-test            |     |           3 |      #ERROR | expected "3" but was "#ERROR"     |
+| R number evaluation     | bug-R-number-evaluation    |     |           2 |           2 | pass                              |
+| multi-line ruby blocks  | multi-line-ruby-test       |     |           2 |           2 | pass                              |
+| forcing vector results  | test-forced-vector-results |     |       Array |      Fixnum | expected "Array" but was "Fixnum" |
 #+TBLFM: $5='(if (= (length $3) 1) (progn (message (format "running %S" '(sbe $2 (n $3)))) (sbe $2 (n $3))) (sbe $2))::$6='(if (string= $4 $5) "pass" (format "expected %S but was %S" $4 $5))
 
 ** basic tests