[BUG FIX] DONE Python session evaluation bug

This commit is contained in:
Eric Schulte 2009-08-14 16:13:57 -06:00
parent 367072d11b
commit 99ba71d35e
2 changed files with 24 additions and 14 deletions

View File

@ -153,14 +153,15 @@ last statement in BODY, as elisp."
(with-temp-buffer (insert-file-contents tmp-file) (buffer-string))))))) (with-temp-buffer (insert-file-contents tmp-file) (buffer-string)))))))
;; comint session evaluation ;; comint session evaluation
(org-babel-comint-in-buffer buffer (org-babel-comint-in-buffer buffer
(let* ((full-body (let* ((raw (org-babel-comint-with-output buffer org-babel-python-eoe-indicator t
(mapconcat
#'org-babel-trim
(list body org-babel-python-last-value-eval org-babel-python-eoe-indicator) "\n"))
(raw (org-babel-comint-with-output buffer org-babel-python-eoe-indicator t
;; for some reason python is fussy, and likes enters after every input ;; for some reason python is fussy, and likes enters after every input
(mapc (lambda (statement) (insert statement) (comint-send-input nil t)) (mapc (lambda (statement) (insert statement) (comint-send-input nil t))
(split-string full-body "[\r\n]+")))) (split-string (org-babel-trim full-body) "[\r\n]+"))
(comint-send-input nil t) (comint-send-input nil t)
(insert org-babel-python-last-value-eval)
(comint-send-input nil t)
(insert org-babel-python-eoe-indicator)
(comint-send-input nil t)))
(results (delete org-babel-python-eoe-indicator (results (delete org-babel-python-eoe-indicator
(cdr (member org-babel-python-eoe-indicator (cdr (member org-babel-python-eoe-indicator
(reverse (mapcar #'org-babel-trim raw))))))) (reverse (mapcar #'org-babel-trim raw)))))))

View File

@ -2819,8 +2819,8 @@ dot("$(2a,0)$",(2,0),N+E);
*** DONE sh *** DONE sh
* Bugs [35/41] * Bugs [36/41]
** TODO Python session evaluation bug ** DONE Python session evaluation bug
The following block evaluates correctly with :session none The following block evaluates correctly with :session none
(set :results to output), but fails with session-based evaluation (set :results to output), but fails with session-based evaluation
(with :results value, as below, you see the error message) (with :results value, as below, you see the error message)
@ -2844,6 +2844,7 @@ dot("$(2a,0)$",(2,0),N+E);
outfile = os.path.join(outdir, '%s-vs-%s-direct' % (case, control)) outfile = os.path.join(outdir, '%s-vs-%s-direct' % (case, control))
cmd = 'snptest %s -frequentist 1 -hwe ' % ('-gen_gz' if format == '.gen.gz' else '') cmd = 'snptest %s -frequentist 1 -hwe ' % ('-gen_gz' if format == '.gen.gz' else '')
cmd += '-cases %s %s ' % (case + format, case + '.sample') cmd += '-cases %s %s ' % (case + format, case + '.sample')
cmd += '-controls %s %s ' % (control + format, control + '.sample') cmd += '-controls %s %s ' % (control + format, control + '.sample')
cmd += '-exclude_samples %s ' % os.path.join(outdir, 'exclusions') cmd += '-exclude_samples %s ' % os.path.join(outdir, 'exclusions')
cmd += '-o %s ' % outfile cmd += '-o %s ' % outfile
@ -2854,10 +2855,20 @@ dot("$(2a,0)$",(2,0),N+E);
#+end_src #+end_src
#+resname: #+resname:
: File "<stdin>", line 14 #+begin_example
: _ snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls NBS.gen.gz NBS.sample -exclude_samples exclusion-study/none/exclusions -o exclusion-study/none/58C-vs-NBS-direct -chunk 10000 > exclusion-study/none/58C-vs-NBS-direct.log
: ^ snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/none/exclusions -o exclusion-study/none/58C-vs-POBI-direct -chunk 10000 > exclusion-study/none/58C-vs-POBI-direct.log
: SyntaxError: invalid syntax snptest -gen_gz -frequentist 1 -hwe -cases NBS.gen.gz NBS.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/none/exclusions -o exclusion-study/none/NBS-vs-POBI-direct -chunk 10000 > exclusion-study/none/NBS-vs-POBI-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls NBS.gen.gz NBS.sample -exclude_samples exclusion-study/noscots/exclusions -o exclusion-study/noscots/58C-vs-NBS-direct -chunk 10000 > exclusion-study/noscots/58C-vs-NBS-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/noscots/exclusions -o exclusion-study/noscots/58C-vs-POBI-direct -chunk 10000 > exclusion-study/noscots/58C-vs-POBI-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases NBS.gen.gz NBS.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/noscots/exclusions -o exclusion-study/noscots/NBS-vs-POBI-direct -chunk 10000 > exclusion-study/noscots/NBS-vs-POBI-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls NBS.gen.gz NBS.sample -exclude_samples exclusion-study/lax/exclusions -o exclusion-study/lax/58C-vs-NBS-direct -chunk 10000 > exclusion-study/lax/58C-vs-NBS-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/lax/exclusions -o exclusion-study/lax/58C-vs-POBI-direct -chunk 10000 > exclusion-study/lax/58C-vs-POBI-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases NBS.gen.gz NBS.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/lax/exclusions -o exclusion-study/lax/NBS-vs-POBI-direct -chunk 10000 > exclusion-study/lax/NBS-vs-POBI-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls NBS.gen.gz NBS.sample -exclude_samples exclusion-study/strict/exclusions -o exclusion-study/strict/58C-vs-NBS-direct -chunk 10000 > exclusion-study/strict/58C-vs-NBS-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases 58C.gen.gz 58C.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/strict/exclusions -o exclusion-study/strict/58C-vs-POBI-direct -chunk 10000 > exclusion-study/strict/58C-vs-POBI-direct.log
snptest -gen_gz -frequentist 1 -hwe -cases NBS.gen.gz NBS.sample -controls POBI.gen.gz POBI.sample -exclude_samples exclusion-study/strict/exclusions -o exclusion-study/strict/NBS-vs-POBI-direct -chunk 10000 > exclusion-study/strict/NBS-vs-POBI-direct.log
#+end_example
** PROPOSED require users to explicitly turn on each language ** PROPOSED require users to explicitly turn on each language
As we continue to add more languages to org-babel, many of which will As we continue to add more languages to org-babel, many of which will
@ -3102,8 +3113,6 @@ the same for the other languages. [Dan]
find . \( -path \*/SCCS -o -path \*/RCS -o -path \*/CVS -o -path \*/MCVS -o -path \*/.svn -o -path \*/.git -o -path \*/.hg -o -path \*/.bzr -o -path \*/_MTN -o -path \*/_darcs -o -path \*/\{arch\} \) -prune -o -type f \( -iname \*.el \) -exec grep -i -nH -e org-babel-trim {} \; find . \( -path \*/SCCS -o -path \*/RCS -o -path \*/CVS -o -path \*/MCVS -o -path \*/.svn -o -path \*/.git -o -path \*/.hg -o -path \*/.bzr -o -path \*/_MTN -o -path \*/_darcs -o -path \*/\{arch\} \) -prune -o -type f \( -iname \*.el \) -exec grep -i -nH -e org-babel-trim {} \;
#+end_src #+end_src
#+resname:
** DONE Allow source blocks to be recognised when #+ are not first characters on the line ** DONE Allow source blocks to be recognised when #+ are not first characters on the line
I think Carsten has recently altered the core so that #+ can have I think Carsten has recently altered the core so that #+ can have
preceding whitespace, at least for literal/code examples. org-babel preceding whitespace, at least for literal/code examples. org-babel