emacs-orgmode@gnu.org archives
 help / color / mirror / code / Atom feed
* R output with session polluted with ascii color codes
@ 2018-03-16 13:57 Tyler Smith
  2018-03-16 15:25 ` William Denton
  0 siblings, 1 reply; 5+ messages in thread
From: Tyler Smith @ 2018-03-16 13:57 UTC (permalink / raw)
  To: Emacs Org-Mode Help

Hi,

The printed output of some R functions includes ascii color codes (i.e., ^[[3m^[[90m). This causes problems with R code blocks evaluated with the :session option. I've pasted a file below that demonstrates the problem. (should I attach it as a file? not sure what's preferable).

I can't find a way to disable this feature from R. However, I did find a way to filter out these codes from the babel side. The function of interest is ~org-babel-R-evaluate-session` in ob-R.el. Adding a ~(replace-regexp-in-string ansi-color-control-seq-regexp "" ...)~ form around the output strips away the color codes so they don't mess up the output.  I've included that code in the example. If that makes sense I can put that together as a patch. If that doesn't make sense, please let me know how to fix this!

Best,

Tyler

* Reproducible Example

Start with ~emacs -Q~, then evaluate each of the following code blocks
in turn.

#+BEGIN_SRC elisp setup
(require 'package)
(setq package-load-list
      '((org-plus-contrib t)
	(ess t)
	(julia-mode t)))
(package-initialize)
(require 'org)
(require 'ess)

(org-babel-do-load-languages
 'org-babel-load-languages
 '((emacs-lisp . t)
   (R . t)
   (shell . t)))
#+END_SRC

#+RESULTS:

If you don't already have ~tidyr~ and ~dplyr~ installed, you need to
do that before running the following:

#+BEGIN_SRC R :results output
library(tidyr)
library(dplyr)
as_tibble(iris)
#+END_SRC

#+RESULTS:
#+begin_example
# A tibble: 150 x 5
   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
          <dbl>       <dbl>        <dbl>       <dbl> <fct>  
 1         5.10        3.50         1.40       0.200 setosa 
 2         4.90        3.00         1.40       0.200 setosa 
 3         4.70        3.20         1.30       0.200 setosa 
 4         4.60        3.10         1.50       0.200 setosa 
 5         5.00        3.60         1.40       0.200 setosa 
 6         5.40        3.90         1.70       0.400 setosa 
 7         4.60        3.40         1.40       0.300 setosa 
 8         5.00        3.40         1.50       0.200 setosa 
 9         4.40        2.90         1.40       0.200 setosa 
10         4.90        3.10         1.50       0.100 setosa 
# ... with 140 more rows
#+end_example

#+BEGIN_SRC R :results output :session RSESSION
library(tidyr)
library(dplyr)
as_tibble(iris)
#+END_SRC

#+RESULTS:
#+begin_example

Attaching package: ‘dplyr’

The following objects are masked from ‘package:stats’:

    filter, lag

The following objects are masked from ‘package:base’:

    intersect, setdiff, setequal, union
^[[90m# A tibble: 150 x 5^[[39m
   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
          ^[[3m^[[90m<dbl>^[[39m^[[23m       ^[[3m^[[90m<dbl>^[[39m^[[23m        ^[[3m^[[90m<dbl>^[[39m^[[23m       ^[[3m^[[90m<dbl>^[[39m^[[23m ^[[3m^[[90m<fct>^[[39m^[[23m  
^[[90m 1^[[39m         5.10        3.50         1.40       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m 2^[[39m         4.90        3.00         1.40       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m 3^[[39m         4.70        3.20         1.30       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m 4^[[39m         4.60        3.10         1.50       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m 5^[[39m         5.00        3.60         1.40       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m 6^[[39m         5.40        3.90         1.70       ^[[90m0^[[39m^[[90m.^[[39m400 setosa 
^[[90m 7^[[39m         4.60        3.40         1.40       ^[[90m0^[[39m^[[90m.^[[39m300 setosa 
^[[90m 8^[[39m         5.00        3.40         1.50       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m 9^[[39m         4.40        2.90         1.40       ^[[90m0^[[39m^[[90m.^[[39m200 setosa 
^[[90m10^[[39m         4.90        3.10         1.50       ^[[90m0^[[39m^[[90m.^[[39m100 setosa 
^[[90m# ... with 140 more rows^[[39m
#+end_example

* Proposed Fix

Evaluating the following replaces the built-in function with my fix:

#+BEGIN_SRC elisp fix
(defun org-babel-R-evaluate-session
    (session body result-type result-params column-names-p row-names-p)
  "Evaluate BODY in SESSION.
If RESULT-TYPE equals `output' then return standard output as a
string.  If RESULT-TYPE equals `value' then return the value of the
last statement in BODY, as elisp."
  (cl-case result-type
    (value
     (with-temp-buffer
       (insert (org-babel-chomp body))
       (let ((ess-local-process-name
	      (process-name (get-buffer-process session)))
	     (ess-eval-visibly-p nil))
	 (ess-eval-buffer nil)))
     (let ((tmp-file (org-babel-temp-file "R-")))
       (org-babel-comint-eval-invisibly-and-wait-for-file
	session tmp-file
	(format org-babel-R-write-object-command
		(if row-names-p "TRUE" "FALSE")
		(if column-names-p
		    (if row-names-p "NA" "TRUE")
		  "FALSE")
		".Last.value" (org-babel-process-file-name tmp-file 'noquote)))
       (org-babel-R-process-value-result
	(org-babel-result-cond result-params
	  (with-temp-buffer
	    (insert-file-contents tmp-file)
	    (org-babel-chomp (buffer-string) "\n"))
	  (org-babel-import-elisp-from-file tmp-file '(16)))
	column-names-p)))
    (output
     ;; strip ansi-color-control-seq-regexp from output!!
     (replace-regexp-in-string
      ansi-color-control-seq-regexp ""
      (mapconcat
       'org-babel-chomp
       (butlast
        (delq nil
	      (mapcar
	       (lambda (line) (when (> (length line) 0) line))
	       (mapcar
	        (lambda (line) ;; cleanup extra prompts left in output
		  (if (string-match
		       "^\\([>+.]\\([ ][>.+]\\)*[ ]\\)"
		       (car (split-string line "\n")))
		      (substring line (match-end 1))
		    line))
	        (org-babel-comint-with-output (session org-babel-R-eoe-output)
		  (insert (mapconcat 'org-babel-chomp
				     (list body org-babel-R-eoe-indicator)
				     "\n"))
		  (inferior-ess-send-input)))))) "\n")))))

#+END_SRC

#+RESULTS:
: org-babel-R-evaluate-session

#+BEGIN_SRC R :results output :session RSESSION
as_tibble(iris)
#+END_SRC

#+RESULTS:
#+begin_example
# A tibble: 150 x 5
   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
          <dbl>       <dbl>        <dbl>       <dbl> <fct>  
 1         5.10        3.50         1.40       0.200 setosa 
 2         4.90        3.00         1.40       0.200 setosa 
 3         4.70        3.20         1.30       0.200 setosa 
 4         4.60        3.10         1.50       0.200 setosa 
 5         5.00        3.60         1.40       0.200 setosa 
 6         5.40        3.90         1.70       0.400 setosa 
 7         4.60        3.40         1.40       0.300 setosa 
 8         5.00        3.40         1.50       0.200 setosa 
 9         4.40        2.90         1.40       0.200 setosa 
10         4.90        3.10         1.50       0.100 setosa 
# ... with 140 more rows
#+end_example

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: R output with session polluted with ascii color codes
  2018-03-16 13:57 R output with session polluted with ascii color codes Tyler Smith
@ 2018-03-16 15:25 ` William Denton
  2018-03-16 17:23   ` Tyler Smith
  0 siblings, 1 reply; 5+ messages in thread
From: William Denton @ 2018-03-16 15:25 UTC (permalink / raw)
  To: Tyler Smith; +Cc: Emacs Org-Mode Help

On 16 March 2018, Tyler Smith wrote:

> ^[[90m# A tibble: 150 x 5^[[39m
>   Sepal.Length Sepal.Width Petal.Length Petal.Width Species
>          ^[[3m^[[90m<dbl>^[[39m^[[23m       ^[[3m^[[90m<dbl>^[[39m^[[23m        ^[[3m^[[90m<dbl>^[[39m^[[23m       ^[[3m^[[90m<dbl>^[[39m^[[23m ^[[3m^[[90m<fct>^[[39m^[[23m
> ^[[90m 1^[[39m         5.10        3.50         1.40       ^[[90m0^[[39m^[[90m.^[[39m200 setosa
> ^[[90m 2^[[39m         4.90        3.00         1.40       ^[[90m0^[[39m^[[90m.^[[39m200 setosa

I tried the example in my configured setup and didn't get the ASCII codes.  I 
don't know why and didn't dig into it, but I could; for now I figured I'd just 
mention this.

Bill
--
William Denton :: Toronto, Canada   ---   Listening to Art: https://listeningtoart.org/
https://www.miskatonic.org/         ---   GHG.EARTH: http://ghg.earth/
Caveat lector.                      ---   STAPLR: http://staplr.org/

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: R output with session polluted with ascii color codes
  2018-03-16 15:25 ` William Denton
@ 2018-03-16 17:23   ` Tyler Smith
  2018-03-16 18:55     ` William Denton
  0 siblings, 1 reply; 5+ messages in thread
From: Tyler Smith @ 2018-03-16 17:23 UTC (permalink / raw)
  To: William Denton; +Cc: Emacs Org-Mode Help

On Fri, Mar 16, 2018, at 11:25 AM, William Denton wrote:
> 
> I tried the example in my configured setup and didn't get the ASCII codes.  I 
> don't know why and didn't dig into it, but I could; for now I figured I'd just 
> mention this.
> 

Thanks for checking. I should have mentioned that I'm running 27.0.50 with org 9.1.7 and ess 17.11. I see this problem with emacs -Q and regular emacs. If you're using the same versions and don't see this, then there should be something I can do in my config to fix it.

Best,

Tyler

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: R output with session polluted with ascii color codes
  2018-03-16 17:23   ` Tyler Smith
@ 2018-03-16 18:55     ` William Denton
  2018-03-16 19:22       ` Tyler Smith
  0 siblings, 1 reply; 5+ messages in thread
From: William Denton @ 2018-03-16 18:55 UTC (permalink / raw)
  To: Tyler Smith; +Cc: Emacs Org-Mode Help

On 16 March 2018, Tyler Smith wrote:

> Thanks for checking. I should have mentioned that I'm running 27.0.50 with org 
> 9.1.7 and ess 17.11. I see this problem with emacs -Q and regular emacs. If 
> you're using the same versions and don't see this, then there should be 
> something I can do in my config to fix it.

I think we're the same---Org says it's 9.1.6, but I just compiled it fresh from 
source five minutes ago, so it should be up to date.  Not sure what's going on 
there.  I recompiled Emacs from fresh source, too, and updated the ESS package 
(17.11, ELPA 20180314.612).

Anyway, I tried again, and there was still no problem in Emacs.  That made me 
wonder if the difference was in R.  When I run "as_tibble(iris)" in the R 
console in a terminal I don't get the ASCII colour codes, so maybe that's where 
the difference lies?  I'm running R 3.4.2, compiled from source, on Ubuntu 
17.10.

Is there an R user on the list who sees the coloured text in the R console and 
can try the example in Org?

#+BEGIN_SRC R :results output :session RSESSION
library(tidyr)
library(dplyr)
as_tibble(iris)
#+END_SRC

Bill
--
William Denton :: Toronto, Canada   ---   Listening to Art: https://listeningtoart.org/
https://www.miskatonic.org/         ---   GHG.EARTH: http://ghg.earth/
Caveat lector.                      ---   STAPLR: http://staplr.org/

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: R output with session polluted with ascii color codes
  2018-03-16 18:55     ` William Denton
@ 2018-03-16 19:22       ` Tyler Smith
  0 siblings, 0 replies; 5+ messages in thread
From: Tyler Smith @ 2018-03-16 19:22 UTC (permalink / raw)
  To: William Denton; +Cc: Emacs Org-Mode Help

On Fri, Mar 16, 2018, at 2:55 PM, William Denton wrote:
> On 16 March 2018, Tyler Smith wrote:
> 
> Anyway, I tried again, and there was still no problem in Emacs.  That made me 
> wonder if the difference was in R.  When I run "as_tibble(iris)" in the R 
> console in a terminal I don't get the ASCII colour codes, so maybe that's where 
> the difference lies?  I'm running R 3.4.2, compiled from source, on Ubuntu 
> 17.10.

I've tried this as well, outside of Emacs. For me, it depends on which terminal emulator I use. xterm displays the colours, while gnome terminal does not. Which is odd, because I use ansi colour codes for my prompt and ls output (etc), and those do display as expected in both xterm and gnome terminal.

Weird!

Thanks,

Tyler

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2018-03-16 19:22 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-03-16 13:57 R output with session polluted with ascii color codes Tyler Smith
2018-03-16 15:25 ` William Denton
2018-03-16 17:23   ` Tyler Smith
2018-03-16 18:55     ` William Denton
2018-03-16 19:22       ` Tyler Smith

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).