[Rd] Re: a better "source(echo=TRUE)" {was "....how to pause...."}

From: Duncan Murdoch <murdoch_at_stats.uwo.ca>
Date: Tue 30 Nov 2004 - 23:10:48 EST

On Tue, 30 Nov 2004 12:51:12 +0100, Martin Maechler <maechler@stat.math.ethz.ch> wrote:

>>>>>> "Duncan" == Duncan Murdoch <murdoch@stats.uwo.ca>
>>>>>> on Sun, 28 Nov 2004 10:25:24 -0500 writes:
> Duncan> <........>
> Duncan> <........>
> Duncan> We already have code to source() from the clipboard, and it could
> Duncan> address the problems above, but:
> Duncan> - Source with echo=T doesn't echo, it deparses, so some comments are
> Duncan> lost, formatting is changed, etc.
>yes, and we would have liked to have an alternative "source()"
>for a *very* long time...
>Examples where I "hate" the non-echo (i.e. the loss of all
>comments and own-intended formatting) is when you use it for
>demos, etc, notably in R's own demo() and example() functions.
>But to do this might be more tricky than at first thought:
>Of course you can readLines() the source file and writeLines()
>them to whatever your console is. The slightly difficult thing
>is to "see" which junks to ``send to R'' , i.e. to parse() and eval().
>The basic problem seems to see when expressions are complete.
>Maybe we should / could think about enhancing parse() {or a new
>function with extended behavior} such that it would not only
>return the parse()d expressions, but also indices (byte or even
>line counters) to the source text, indicating where each of the
>expression started and ended.
>That way I could see a way to proceed.

I started trying to do that last summer, but ran out of time before I finished, and haven't got anything new done this fall. I think the part you describe above was done, but what I hadn't worked out were the details of where the source would be stored. For example, if my example was

# Comment 1
x <- 1
# Comment 2
y <- 2
# Comment 3

do I store the source in one place with references from each line, or break it up into separate pieces (two or five), or just refer to the file these lines came from? I was trying to do it by storing the source or a filename reference in one place with offsets to it from each line, but didn't get done.

Duncan Murdoch

R-devel@stat.math.ethz.ch mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel Received on Tue Nov 30 23:28:15 2004

This archive was generated by hypermail 2.1.8 : Fri 18 Mar 2005 - 09:01:54 EST