mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-25 10:58:52 +00:00
More elegant knitr support and bug fix
Implement a more simple and elegant integration of the R package knitr. Now, lyxknitr.R does not need to move or copy files at all. This also fixes a bug: when /tmp was on a different file system (e.g. encrypted home), lyxknitr.R failed to move files to /tmp because it relied on R's 'file.rename' function, which in turn relied on the rename function in <stdio.h>, which was failing with the EXDEV errno. Patch from Yihui Xie.
This commit is contained in:
parent
fcfa044614
commit
4d9f620349
@ -176,7 +176,7 @@ status collapsed
|
||||
|
||||
\begin_layout Plain Layout
|
||||
|
||||
http://yihui.github.com/knitr
|
||||
http://yihui.name/knitr
|
||||
\end_layout
|
||||
|
||||
\end_inset
|
||||
|
@ -1,7 +1,7 @@
|
||||
#\DeclareLyXModule[knitr->latex]{Rnw (knitr)}
|
||||
#DescriptionBegin
|
||||
#Uses the knitr package in R for dynamic report generation. This R package has to be installed for this module to work: install.packages('knitr'). Note it depends on R >= 2.14.1.
|
||||
#For more info see http://yihui.github.com/knitr
|
||||
#For more info see http://yihui.name/knitr
|
||||
#DescriptionEnd
|
||||
#Category: literate
|
||||
#Excludes: lilypond | sweave
|
||||
|
@ -11,7 +11,7 @@
|
||||
## author Yihui Xie
|
||||
|
||||
## knitr is an alternative package to Sweave, and has more features
|
||||
## and flexibility; see https://yihui.github.com/knitr
|
||||
## and flexibility; see https://yihui.name/knitr
|
||||
|
||||
## Rscript $$s/scripts/lyxknitr.R $$p$$i $$p$$o $$e $$r
|
||||
## $$p the path of the output (temp dir)
|
||||
@ -31,18 +31,7 @@ options(encoding = .cmdargs[3])
|
||||
## can put your data files there and functions like read.table() can
|
||||
## work correctly without specifying the full path
|
||||
setwd(.cmdargs[4])
|
||||
opts_knit$set(root.dir = getwd())
|
||||
|
||||
## copy the Rnw file to the current working directory if it does not exist
|
||||
.tmp.file = tempfile(); .rnw.file = basename(.cmdargs[1])
|
||||
.rnw.exists = file.exists(.rnw.file)
|
||||
if (.rnw.exists) file.rename(.rnw.file, .tmp.file)
|
||||
file.copy(.cmdargs[1], '.')
|
||||
## run knit() to get .tex or .R
|
||||
knit(.rnw.file, tangle = 'tangle' %in% .cmdargs)
|
||||
|
||||
setwd(.cmdargs[4])
|
||||
## remove the copied .Rnw if it did not exist, otherwise move the original one back
|
||||
if (.rnw.exists) file.rename(.tmp.file, .rnw.file) else unlink(.rnw.file)
|
||||
file.rename(basename(.cmdargs[2]), .cmdargs[2]) # move .tex to the temp dir
|
||||
rm(.tmp.file, .rnw.file, .rnw.exists) # clean up these variables
|
||||
|
||||
knit(.cmdargs[1], output = .cmdargs[2], tangle = 'tangle' %in% .cmdargs)
|
||||
|
@ -142,6 +142,9 @@ What's new
|
||||
|
||||
- Fix tex2lyx import of mhchem commands outside math mode (bug 8306).
|
||||
|
||||
- Fix failure of lyxknitr.R to move files when /tmp was on a different
|
||||
file system (e.g. an encrypted home partition).
|
||||
|
||||
|
||||
* USER INTERFACE
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user