From d26a98d71a717f6c489417edcef7701fd52b608c Mon Sep 17 00:00:00 2001 From: Eric Schulte Date: Mon, 9 Feb 2009 14:41:31 -0800 Subject: [PATCH] I've done a fairly destructive edit of this file. The main goal was to enforce a structure on the document that we can use moving forward, so that any future objective changes are all made to the main objective list. I apologize for removing sections written by other people. I did this when they were redundant or it was not clear how to fit them into this structure. Rest assured if the previous text wasn't persisted in git I would have been much more cautious about removing it. I hope that this outline structure should be able to remain stable through the process of fleshing out objectives, and cashing those objectives out into tasks. That said, please feel free to make any changes that you see fit. Changes include... - tearing stuff out, and imposing structure - updated .gitignore to ignore exported files --- .gitignore | 1 + rorg.html | 767 ----------------------------------------------------- rorg.org | 287 ++++++++++++-------- 3 files changed, 173 insertions(+), 882 deletions(-) delete mode 100644 rorg.html diff --git a/.gitignore b/.gitignore index cb9e5d00a..089f74e4c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ *~ +*.html .Rhistory .Rdata diff --git a/rorg.html b/rorg.html deleted file mode 100644 index 0d1b38454..000000000 --- a/rorg.html +++ /dev/null @@ -1,767 +0,0 @@ - - - -rorg — Code evaluation in org-mode, with an emphasis on R - - - - - - - -

rorg — Code evaluation in org-mode, with an emphasis on R

- - -
-

Table of Contents

- -
- -
-

Overview (Dan 2009-02-08 Sun)

-
- - -
- -
-

Project objectives

-
- -

This project is basically about putting source code into org -files. This isn't just code to look pretty as a source code example, -but code to be evaluated. Org files have 3 main export targets: org, -html and latex. Thus the aim of this project is to produce files in -those formats that have benefitted in some way from the evaluation of -source code that is present in the source org file. We have a current -focus on R code, but we are regarding that more as a working example -than as a defining feature of the project. -

-

-Code evaluation can have three relevant consequences. Our aim is to -deal with these consequences as follows: -

- -
- -
-

It produces text/numeric output

-
- -

We (optionally) incorporate the text output as text in the target -document -

- -
- -
-

It produces graphical output

-
- -

We either link to the graphics or (html/latex) include them inline. -

- -
- -
-

It creates some non-graphics files

-
- -

? We link to other file output -

- -
- -
-

It alters the environment by side effect in some other way

-
- -

We bear this in mind -

-
-
- -
- -
-

Implementation questions

-
- -

These objectives raise three questions: -

-
    -
  1. -How is the code placed in the org file? -
  2. -
  3. -When is the code evaluated? -
  4. -
  5. -What is the result of code evaluation? - -
  6. -
- -
- -
-

How is the code placed in the org file?

-
- -

Using some version of the code block ideas that Eric and Austin -have worked on. (In addition, an aim of org-R was to allow Org -users who are not R users to specify R code implicitly, using -native org syntax. I'd like to maintain that, but it's not central -to this project.) -

-
- -
- -
-

When is the code evaluated?

-
- -

Let's use an asterisk to indicate content which includes the -result of code evaluation, rather than the code itself. Clearly -we have a requirement for the following transformation: -

-

-org → org* -

-

-Let's say this transformation is effected by a function -`org-eval-buffer'. This transformation is necessary when the -target format is org (say you want to update the values in an org -table, or generate a plot and create an org link to it), and it -can also be used as the first step by which to reach html and -latex: -

-

-org → org* → html -

-

-org → org* → latex -

-

-Thus in principle we can reach our 3 target formats with -`org-eval-buffer', `org-export-as-latex' and `org-export-as-html'. -

-

-An extra transformation that we might want is -

-

-org → latex -

-

-I.e. export to latex without evaluation of code, in such a way that R -code can subsequently be evaluated using -Sweave(driver=RweaveLatex), which is what the R community is -used to. This would provide a `bail out' avenue where users can -escape org mode and enter a workflow in which the latex/noweb file -is treated as source. -

-
    -
  • How do we implement `org-eval-buffer'?
    - -

    -AIUI The following can all be viewed as implementations of -org-eval-buffer for R code: -

    -
      -
    • org-eval-light
      -This is the beginnings of a general evaluation mechanism, that -could evaluate python, ruby, shell, perl, in addition to R. -The header says it's based on org-eval, what is org-eval?? - -
    • -
    • org-R
      -This accomplishes org → org* in elisp by visiting code blocks -and evaluating code using ESS. - -
    • -
    • RweaveOrg
      -This accomplishes org → org* using R via - -
      -Sweave("file-with-unevaluated-code.org", driver=RweaveOrg, syntax=SweaveSyntaxOrg)
      -
      - -
    • -
    • org-exp-blocks.el
      -Like org-R, this achieves org → org* in elisp by visiting code -blocks and using ESS to evaluate R code. - - -
    • -
    -
  • -
-
- -
- -
-

What is the result of code evaluation?

-
- -

Here we have to consider text/numeric output, and graphical -output. And also the stage at which evaluation occurs -

    -
  • org → org*
    -
      -
    • Text / numerical output
      -In the case of org → org*, I would argue that, where -appropriate, it should be stored in org tables. Thus an advantage -our project would have over Sweave is that tabular output is -automatically conveqrted to native tables on export to HTML and -latex. -
    • -
    • Graphical output
      -We place an org link to the file. This is done already by -org-R-apply, and by RweaveOrg. -
    • -
    -
  • -
  • latex → latex*
    -This is done by Sweave(driver=RweaveLatex) and so is out of our hands - -
  • -
-
-
-
- -
- -
-

Commentary

-
- - - -
- -
-

Eric 2009-02-06 Fri 15:41

-
- -

I think we're getting close to a comprehensive set of objectives -(although since you two are the real R user's I leave that decision up -to you). Once we've agreed on a set of objectives and agreed on at -least to broad strokes of implementation, I think we should start -listing out and assigning tasks. -

- -
-
- -
- -
-

Objectives

-
- - -
- -
-

Send data to R from org

-
- -

Org-mode includes orgtbl-mode, an extremely convenient way of using -tabular data in a plain text file. Currently, spreadsheet -functionality is available in org tables using the emacs package -calc. It would be a boon both to org users and R users to allow -org tables to be manipulated with the R programming language. Org -tables give R users an easy way to enter and display data; R gives -org users a powerful way to perform vector operations, statistical -tests, and visualization on their tables. -

- -
- -
-

Implementations

-
- -
    -
  • naive
    -Naive implementation would be to use (org-export-table "tmp.csv") -and (ess-execute "read.csv('tmp.csv')"). -
  • -
  • org-R
    -org-R passes data to R from two sources: org tables, or csv -files. Org tables are first exported to a temporary csv file -using org-R-export-to-csv. -
  • -
  • org-exp-blocks
    -org-exp-blocks uses org-interblock-R-command-to-string to send -commands to an R process running in a comint buffer through ESS. -org-exp-blocks has no support for dumping table data to R process, or -vice versa. - -
  • -
  • RweaveOrg
    -NA - - -
  • -
-
-
- -
- -
-

Evaluate R code from org and deal with output appropriately

-
- - -
- -
-

vector output

-
- -

When R code evaluation generates vectors and 2-dimensional arrays, -this should be formatted appropriately in org buffers (orgtbl-mode) as well -as in export targets (html, latex) -

-

-Agreed, if we can convert the vector data to lists then we can use -the many orgtbl-to-* functions to convert the list to whatever -output format we desire. See `orgtbl-to-orgtbl, `orgtbl-to-latex', -`orgtbl-to-html', `orgtbl-to-csv', etc… -

-
    -
  • Implementations
    -
      -
    • org-R
      -org-R converts R output (vectors, or matrices / 2d-arrays) to an -org table and stores it in the org buffer, or in a separate org -file (csv output would also be perfectly possible). -
    • -
    • org-exp-blocks
      -
    • -
    • RweaveOrg
      -
    • -
    -
  • -
-
- -
- -
-

graphical output

-
- -

R can generate graphical output on a screen graphics device -(e.g. X11, quartz), and in various standard image file formats -(png, jpg, ps, pdf, etc). When graphical output is generated by -evaluation of R code in Org, at least the following two things are desirable: -

    -
  1. -output to screen for immediate viewing is possible -
  2. -
  3. -graphical output to file is linked to appropriately from the -org file This should have the automatic consequence that it is -included appropriately in subsequent export targets (html, -latex). - -
  4. -
-
    -
  • Implementations
    -
      -
    • org-R
      -org-R does (1) if no output file is specified and (2) otherwise -
    • -
    • org-exp-blocks
      -org-exp-blocks tries to do 2, but I don't think that part was -every really working - -
    • -
    • RweaveOrg
      - - -
    • -
    -
  • -
-
-
- -
- -
-

Evaluate R code on export

-
- -

At first I was leaning towards leaving the exporting to Sweave, but it -seems that once we have evaluation or R working, it will not be -difficult to implement full evaluation of R blocks, one-liners, and -creation of R graphics on export directly in elisp. -

-

-I think that this would be worth the effort since it would eliminate -the need for using Sweave, and would allow for exportation to any -target format supported by org-mode. -

- -
-
- -
- -
-

Notes

-
- - -
- -
-

Special editing and evaluation of source code in R blocks

-
- -

Unfortunately org-mode how two different block types, both useful. -In developing RweaveOrg, a third was introduced. -

-

-Eric is leaning towards using the #+begin_src blocks, as that is -really what these blocks contain: source code. Austin believes -that specifying export options at the beginning of a block is -useful functionality, to be preserved if possible. -

-

-Note that upper and lower case are not relevant in block headings. -

- -
- -
-

PROPOSED R-block proposal

-
- -

I (Eric) propose that we use the syntax of source code blocks as they -currently exist in org-mode with the addition of evaluation, -header-arguments, exportation, single-line-blocks, and -references-to-table-data. -

-
    -
  1. -evaluation: These blocks can be evaluated through \C-c\C-c with -a slight addition to the code already present and working in -org-eval-light.el. All we should need to add for R support would -be an appropriate entry in org-eval-light-interpreters with a -corresponding evaluation function. For an example usinga -org-eval-light see * src block evaluation w/org-eval-light. - -
  2. -
  3. -header-arguments: These can be implemented along the lines of -Austin's header arguments in org-sweave.el. - -
  4. -
  5. -exportation: Should be as similar as possible to that done by -Sweave, and hopefully can re-use some of the code currently present -in org-exp-blocks.el. - -
  6. -
  7. -single-line-blocks: It seems that it is useful to be able to -place a single line of R code on a line by itself. Should we add -syntax for this similar to Dan's #+R: lines? I would lean -towards something here that can be re-used for any type of source -code in the same manner as the #+begin_src R blocks, maybe -#+src_R? - -
  8. -
  9. -references-to-table-data: I get this impression that this is -vital to the efficient use of R code in an org file, so we should -come up with a way to reference table data from a single-line-block -or from an R source-code block. It looks like Dan has already done -this in org-R.el. - -
  10. -
- -

What do you think? Does this accomplish everything we want to be able -to do with embedded R source code blocks? -

-
    -
  • src block evaluation w/org-eval-light
    -here's an example using org-eval-light.el - -

    -first load the org-eval-light.el file -

    -

    -<elisp:(load (expand-file-name "org-eval-light.el" (expand-file-name "existing_tools" (file-name-directory buffer-file-name))))> -

    -

    -then press \C-c\C-c inside of the following src code snippet. The -results should appear in a comment immediately following the source -code block. It shouldn't be too hard to add R support to this -function through the `org-eval-light-interpreters' variable. -

    -

    -(Dan: The following causes error on export to HTML hence spaces inserted at bol) -

    -

    -#+beginsrc shell -date -#+endsrc -

    -
  • -
-
- -
- -
-

Source code blocks

-
- -

Org has an extremely useful method of editing source code and -examples in their native modes. In the case of R code, we want to -be able to use the full functionality of ESS mode, including -interactive evaluation of code. -

-

-Source code blocks look like the following and allow for the -special editing of code inside of the block through -`org-edit-special'. -

- - - -
-
-,## hit C-c ' within this block to enter a temporary buffer in r-mode.
-
-,## while in the temporary buffer, hit C-c C-c on this comment to
-,## evaluate this block
-a <- 3
-a
-
-,## hit C-c ' to exit the temporary buffer
-
- - - - -
- -
- -
-

dblocks

-
- -

dblocks are useful because org-mode will automatically call -`org-dblock-write:dblock-type' where dblock-type is the string -following the #+BEGIN: portion of the line. -

-

-dblocks look like the following and allow for evaluation of the -code inside of the block by calling \C-c\C-c on the header of -the block. -

- -
- -
- -
-

R blocks

-
- -

In developing RweaveOrg, Austin created org-sweave.el. This -allows for the kind of blocks shown in testing.Rorg. These blocks -have the advantage of accepting options to the Sweave preprocessor -following the #+BEGINR declaration. -

-
-
- -
- -
-

Interaction with the R process

-
- - -

-We should take care to implement this in such a way that all of the -different components which have to interactive with R including: -

    -
  • -evaluation of source code blocks -
  • -
  • -automatic evaluation on export -
  • -
  • -evaluation of \R{} snippets -
  • -
  • -evaluation of single source code lines -
  • -
  • -sending/receiving vector data - -
  • -
- -

I think we currently have two implementations of interaction with R -processes; org-R.el and org-exp-blocks.el. We should be sure to take -the best of each of these approaches. -

- -
-
- -
- -
-

Tasks

-
- - - -
- -
- -
-

buffer dictionary

-
- -

LocalWords: DBlocks dblocks -

-
-

Author: Dan -<dan@Tichodroma> -

-

Date: 2009-02-08 14:56:13 EST

-

HTML generated by org-mode 6.21trans in emacs 22

-
- diff --git a/rorg.org b/rorg.org index 2a545087f..77c0d5106 100644 --- a/rorg.org +++ b/rorg.org @@ -3,45 +3,54 @@ #+SEQ_TODO: TODO PROPOSED | DONE DROPPED MAYBE #+STARTUP: oddeven -* Overview (Dan [2009-02-08 Sun]) -** Project objectives +* Overview This project is basically about putting source code into org files. This isn't just code to look pretty as a source code example, but code to be evaluated. Org files have 3 main export targets: org, -html and latex. Thus the aim of this project is to produce files in -those formats that have benefitted in some way from the evaluation of -source code that is present in the source org file. We have a current +html and latex. Once we have implemented a smooth bi-directional flow +of data between org-mode formats (including tables, and maybe lists +and property values) and source-code blocks, we will be able to use +org-mode's built in export to publish this data in any org-supported +format using org-mode as an intermediate format. We have a current focus on R code, but we are regarding that more as a working example than as a defining feature of the project. -Code evaluation can have three relevant consequences. Our aim is to -deal with these consequences as follows: +The main objectives of this project are... -*** It produces text/numeric output - We (optionally) incorporate the text output as text in the target - document -*** It produces graphical output - We either link to the graphics or (html/latex) include them inline. -*** It creates some non-graphics files - ? We link to other file output -*** It alters the environment by side effect in some other way - We bear this in mind +# Lets start with this list and make changes as appropriate. Please +# try to make changes to this list, rather than starting any new +# lists. -** Implementation questions - These objectives raise three questions: +- [[* evaluation of embedded source code][evaluation of embedded source code]] + - [[* execution on demand and on export][execution on demand and on export]] + - [[* evaluation of source blocks][evaluation of source blocks]] + - [[* inline source evaluation][inline source evaluation]] +- [[* interaction with the source-code's process][interaction with the source-code's process]] +- [[* output of code evaluation][output of code evaluation]] + - [[* textual/numeric output][textual/numeric output]] + - [[* graphical output][graphical output]] + - [[* file creation][non-graphics file creation]] + - [[* side effects][side effects]] +- [[* reference to data and evaluation results][reference to data and evaluation results]]: This could happen in many + directions + - [[* reference format][reference format]] + - [[* source-target pairs][source-target pairs]] + - [[* source block output from org tables][source block output from org tables]] + - [[* source block outpt from other source block][source block outpt from other source block]] + - [[* source block output from org list][source block output from org list]] ?? maybe + - [[* org table from source block][org table from source block]] + - [[* org table from org table][org table from org table]] + - [[* org properties from source block][org properties from source block]] + - [[* org properties from org table][org properties from org table]] +- [[* caching of evaluation][caching of evaluation]] +- [[* export][export]] - 1. How is the code placed in the org file? - 2. When is the code evaluated? - 3. What is the result of code evaluation? -*** How is the code placed in the org file? - Using some version of the code block ideas that Eric and Austin - have worked on. (In addition, an aim of org-R was to allow Org - users who are not R users to specify R code implicitly, using - native org syntax. I'd like to maintain that, but it's not central - to this project.) +* Objectives -*** When is the code evaluated? +** evaluation of embedded source code + +*** execution on demand and on export Let's use an asterisk to indicate content which includes the *result* of code evaluation, rather than the code itself. Clearly we have a requirement for the following transformation: @@ -81,7 +90,16 @@ deal with these consequences as follows: ***** org-eval-light This is the beginnings of a general evaluation mechanism, that could evaluate python, ruby, shell, perl, in addition to R. - The header says it's based on org-eval, what is org-eval?? + The header says it's based on org-eval + + what is org-eval?? + + org-eval was written by Carsten. It lives in the + org/contrib/lisp directory because it is too dangerous to + include in the base. Unlike org-eval-light org-eval evaluates + all source blocks in an org-file when the file is first opened, + which could be a security nightmare for example if someone + emailed you a pernicious file. ***** org-R This accomplishes org \to org* in elisp by visiting code blocks @@ -96,43 +114,56 @@ deal with these consequences as follows: Like org-R, this achieves org \to org* in elisp by visiting code blocks and using ESS to evaluate R code. +*** evaluation of source blocks +(see [[* Special editing and evaluation of source code][Special editing and evaluation of source code]]) -*** What is the result of code evaluation? - Here we have to consider text/numeric output, and graphical - output. And also the stage at which evaluation occurs -***** org \to org* -****** Text / numerical output - In the case of org \to org*, I would argue that, where - appropriate, it should be stored in org tables. Thus an advantage - our project would have over Sweave is that tabular output is - automatically conveqrted to native tables on export to HTML and - latex. -****** Graphical output - We place an org link to the file. This is done already by - org-R-apply, and by RweaveOrg. -***** latex \to latex* - This is done by Sweave(driver=RweaveLatex) and so is out of our hands +*** inline source evaluation -* Commentary +** interaction with the source-code's process +We should settle on a uniform API for sending code and receiving +output from a source process. Then to add a new language all we need +to do is implement this API. -** Eric <2009-02-06 Fri 15:41> -I think we're getting close to a comprehensive set of objectives -(although since you two are the real R user's I leave that decision up -to you). Once we've agreed on a set of objectives and agreed on at -least to broad strokes of implementation, I think we should start -listing out and assigning tasks. +for related notes see ([[* Interaction with the R process][Interaction with the R process]]) +** output of code evaluation +*** textual/numeric output + We (optionally) incorporate the text output as text in the target + document +*** graphical output + We either link to the graphics or (html/latex) include them + inline. + + I would say, if the block is being evaluated interactively then + lets pop up the image in a new window, and if it is being exported + then we can just include a link to the file which will be exported + appropriately by org-mode. + +*** non-graphics files + ? We link to other file output +*** side effects +If we are using a continuous process in (for example an R process +handled by ESS) then any side effects of the process (for example +setting values of R variables) will be handled automatically -* Objectives -** Send data to R from org - Org-mode includes orgtbl-mode, an extremely convenient way of using - tabular data in a plain text file. Currently, spreadsheet - functionality is available in org tables using the emacs package - calc. It would be a boon both to org users and R users to allow - org tables to be manipulated with the R programming language. Org - tables give R users an easy way to enter and display data; R gives - org users a powerful way to perform vector operations, statistical - tests, and visualization on their tables. +Are there side-effects which need to be considered aside from those +internal to the source-code evaluation process? + +** reference to data and evaluation results +I think this will be very important. I would suggest that since we +are using lisp we use lists as our medium of exchange. Then all we +need are functions going converting all of our target formats to and +from lists. These functions are already provided by for org tables. + +It would be a boon both to org users and R users to allow org tables +to be manipulated with the R programming language. Org tables give R +users an easy way to enter and display data; R gives org users a +powerful way to perform vector operations, statistical tests, and +visualization on their tables. + +This means that we will need to consider unique id's for source +blocks, as well as for org tables, and for any other data source or +target. *** Implementations **** naive @@ -151,59 +182,44 @@ vice versa. **** RweaveOrg NA +*** reference format +This will be tricky, Dan has already come up with a solution for R, I +need to look more closely at that and we should try to come up with a +formats for referencing data from source-code in such a way that it +will be as source-code-language independent as possible. -** Evaluate R code from org and deal with output appropriately -*** vector output - When R code evaluation generates vectors and 2-dimensional arrays, - this should be formatted appropriately in org buffers (orgtbl-mode) as well - as in export targets (html, latex) - - Agreed, if we can convert the vector data to lists then we can use - the many orgtbl-to-* functions to convert the list to whatever - output format we desire. See `orgtbl-to-orgtbl, `orgtbl-to-latex', - `orgtbl-to-html', `orgtbl-to-csv', etc... - -**** Implementations -***** org-R - org-R converts R output (vectors, or matrices / 2d-arrays) to an - org table and stores it in the org buffer, or in a separate org - file (csv output would also be perfectly possible). -***** org-exp-blocks -***** RweaveOrg -*** graphical output - R can generate graphical output on a screen graphics device - (e.g. X11, quartz), and in various standard image file formats - (png, jpg, ps, pdf, etc). When graphical output is generated by - evaluation of R code in Org, at least the following two things are desirable: - 1. output to screen for immediate viewing is possible - 2. graphical output to file is linked to appropriately from the - org file This should have the automatic consequence that it is - included appropriately in subsequent export targets (html, - latex). +*** source-target pairs -**** Implementations -***** org-R - org-R does (1) if no output file is specified and (2) otherwise -***** org-exp-blocks - org-exp-blocks tries to do 2, but I don't think that part was - every really working +The following can be used for special considerations based on +source-target pairs -***** RweaveOrg +**** source block output from org tables +**** source block outpt from other source block +**** source block output from org list +**** org table from source block +**** org table from org table +**** org properties from source block +**** org properties from org table +** caching of evaluation -** Evaluate R code on export -At first I was leaning towards leaving the exporting to Sweave, but it -seems that once we have evaluation or R working, it will not be -difficult to implement full evaluation of R blocks, one-liners, and -creation of R graphics on export directly in elisp. +I'm personally not clear on how this would be implemented, but it does +seem to be important. I'd be interested to hear how Sweave +accomplished this. Should it be based on tracking changes in source +blocks. -I think that this would be worth the effort since it would eliminate -the need for using Sweave, and would allow for exportation to any -target format supported by org-mode. +** export +once the previous objectives are met export should be fairly simple. +Basically it will consist of triggering the evaluation of source code +blocks with the org-export-preprocess-hook. + +This block export evaluation will be aware of the target format +through the htmlp and latexp variables, and can then create quoted +=#+begin_html= and =#+begin_latex= blocks appropriately. * Notes -** Special editing and evaluation of source code in R blocks +** Special editing and evaluation of source code Unfortunately org-mode how two different block types, both useful. In developing RweaveOrg, a third was introduced. @@ -214,7 +230,20 @@ target format supported by org-mode. Note that upper and lower case are not relevant in block headings. -*** PROPOSED R-block proposal +*** block headers/parameters +regardless of the syntax/format chosen for the source blocks, we will +need to be able to pass a list of parameters to these blocks. These +should include (but should certainly not be limited to) +- label of the block +- names of file to which graphical/textual/numerical/tabular output + should be written +- flags for when/if the block should be evaluated (on export etc...) +- flags for how the results of the export should be displayed/included +- flags specific to the language of the source block +- etc... + +*** block format +**** PROPOSED R-block proposal I (Eric) propose that we use the syntax of source code blocks as they currently exist in org-mode with the addition of *evaluation*, *header-arguments*, *exportation*, *single-line-blocks*, and @@ -250,7 +279,7 @@ currently exist in org-mode with the addition of *evaluation*, What do you think? Does this accomplish everything we want to be able to do with embedded R source code blocks? -**** src block evaluation w/org-eval-light +***** src block evaluation w/org-eval-light here's an example using org-eval-light.el first load the org-eval-light.el file @@ -268,7 +297,7 @@ function through the `org-eval-light-interpreters' variable. date #+end_src -*** Source code blocks +**** Source code blocks Org has an extremely useful method of editing source code and examples in their native modes. In the case of R code, we want to be able to use the full functionality of ESS mode, including @@ -290,7 +319,7 @@ a ,## hit C-c ' to exit the temporary buffer #+END_SRC -*** dblocks +**** dblocks dblocks are useful because org-mode will automatically call `org-dblock-write:dblock-type' where dblock-type is the string following the =#+BEGIN:= portion of the line. @@ -302,11 +331,11 @@ a #+BEGIN: dblock-type #+END: -*** R blocks - In developing RweaveOrg, Austin created [[file:existing_tools/RweaveOrg/org-sweave.el][org-sweave.el]]. This - allows for the kind of blocks shown in [[file:existing_tools/RweaveOrg/testing.Rorg][testing.Rorg]]. These blocks - have the advantage of accepting options to the Sweave preprocessor - following the #+BEGIN_R declaration. +**** R blocks + In developing RweaveOrg, Austin created [[file:existing_tools/RweaveOrg/org-sweave.el][org-sweave.el]]. This + allows for the kind of blocks shown in [[file:existing_tools/RweaveOrg/testing.Rorg][testing.Rorg]]. These blocks + have the advantage of accepting options to the Sweave preprocessor + following the #+BEGIN_R declaration. ** Interaction with the R process @@ -326,5 +355,33 @@ the best of each of these approaches. * Tasks -* buffer dictionary +* COMMENT Commentary +I'm seeing this as like commit notes, and a place for less formal +communication of the goals of our changes. + +** Eric <2009-02-06 Fri 15:41> +I think we're getting close to a comprehensive set of objectives +(although since you two are the real R user's I leave that decision up +to you). Once we've agreed on a set of objectives and agreed on at +least to broad strokes of implementation, I think we should start +listing out and assigning tasks. + +** Eric <2009-02-09 Mon 14:25> +I've done a fairly destructive edit of this file. The main goal was +to enforce a structure on the document that we can use moving forward, +so that any future objective changes are all made to the main +objective list. + +I apologize for removing sections written by other people. I did this +when they were redundant or it was not clear how to fit them into this +structure. Rest assured if the previous text wasn't persisted in git +I would have been much more cautious about removing it. + +I hope that this outline structure should be able to remain stable +through the process of fleshing out objectives, and cashing those +objectives out into tasks. That said, please feel free to make any +changes that you see fit. + + +* Buffer Dictionary LocalWords: DBlocks dblocks