[Rd] Sweave processes \Sexpr in commented LaTeX source (2.3.1patched and 2.4.0)
Marc Schwartz (via MN)
mschwartz at mn.rr.com
Thu Sep 21 17:58:08 CEST 2006
On Thu, 2006-09-21 at 16:40 +0200, Friedrich Leisch wrote:
> >>>>> On Wed, 20 Sep 2006 10:07:26 -0700,
> >>>>> Seth Falcon (SF) wrote:
>
> > "Antonio, Fabio Di Narzo" <antonio.fabio at gmail.com> writes:
> >> 2006/9/20, Seth Falcon <sfalcon at fhcrc.org>:
> >>> Peter Dalgaard <p.dalgaard at biostat.ku.dk> writes:
> >>> > ..not to mention TeX comments inside Sexpr (e.g. %*%...). Skipping
> >>> > lines with % as the first character might be a viable compromise
> >>> > though.
> >>>
> >>> +1. You could probably ignore any lines where the first
> >>> non-whitespace char is '%'. But if that seems to risky, then only
> >>> recognizing first-char-is-% seems a worthwhile heuristic.
> >>>
> >>> Another place where this has bitten people is when they do:
> >>>
> >>> %\usepackage{Sweave}
> >>>
> >>> Sweave picks that up and doesn't insert the usepackage line itself.
> >>
> >> I've found that extremely useful for sweaving Stex files which aren't
> >> "master" files (i.e., only files to include in a main latex file).
> >> Inserting '\usepackage{Sweave}' in each would result in a latex error.
> >> So commenting it out is a useful workaround.
>
> > Commenting it out _and_ having Sweave see it?
>
> Yes, I actually do that quite often, e.g., when I have my own
> definitions of the Sinput/Soutput/... environments in the document
> preamble and don't want to use any Sweave style file.
>
> Note that we recently had a thread on the \usepackage{Sweave} path
> insertion problems in windows and as a result I will stop being
> special about it at all, i.e., users will have to put a
> \usepackage{Sweave} into their documents, and take care that latex
> finds a version of it.
>
> The thread was end of August and I didn't do it for 2.4 because I
> didn't want to break all vignettes that close to a release. But I will
> do for the 2.5 series once 2.4.0 is released.
>
> Ad evaluation of \Sexpr{}: That can be considered a bug, hence I could
> try a fix even in feature freeze. But as I will be offline for a week
> starting tomorrow this will also have to wait until the 2.5 series (or
> 2.4.1, depending on the change).
>
> My favorite would not be a separate option eval.Sexpr but eveluate
> only when the global option for eval is true. Then an
>
> \SweaveOpts{eval=false}
>
> at any place in a document would stop all evalualtions, be it code
> chunks (which do not override the default) or Sexpr. If somebody has
> good useage for a separate option I could be convinced to have it,
> otherwise I'll go for \Sexpr{} listening to the eval option.
Fritz,
I appreciate your consideration of this issue.
I think that your solution using a global evaluation option would be
fine.
Thanks again,
Marc
More information about the R-devel
mailing list