forked from yihui/knitr
-
Notifications
You must be signed in to change notification settings - Fork 0
/
NEWS
1693 lines (1232 loc) · 75.2 KB
/
NEWS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
CHANGES IN knitr VERSION 1.5
NEW FEATURES
- a new option value `results='hold'` to flush all text output to the end
of a chunk like `fig.show='hold'` (thanks, Harlan Harris, #593)
- when cache is enabled, automatic chunk dependencies can be truly automatic
now; there is no need to call `dep_auto()` explicitly, and all we need
to do is the chunk option `autodep=TRUE`; the chunk dependencies will be
rebuilt after each chunk, so when new chunks are inserted into the document,
**knitr** can also figure out the new dependencies automatically (thanks,
@knokknok, #592)
- for Sublime Text users, there is a
[SublimeKnitr](https://github.com/andrewheiss/SublimeKnitr) package to
support LaTeX and Markdown with **knitr**; thanks, Andrew Heiss (#449)
(this is not really a new feature of knitr **itself**, though)
- now the chunk options `warning` and `message` can also take numeric
values as indices to select which warnings/messages to include in the output
(thanks, Simon Urbanek, #590)
BUG FIXES
- code changes in chunks should invalidate the cache when the chunk option
`cache < 3`; fixed by @knokknok in #587
- fixed the bug reported at http://stackoverflow.com/q/18302179/559676;
before evaluating inline R code, the chunk options `eval` must be evaluated
to a logical value
- fixed the bug reported at http://stackoverflow.com/q/18544045/559676;
read_chunk() no longer excludes code without chunk headers, so stitch()
will include all the code as expected
- fixed the bug reported under http://stackoverflow.com/a/18541083/559676;
now `\ensuremath{}` can be correctly applied to numbers of the form `10^{-n}`
- fixes a regression bug reported by Graham Williams:
https://groups.google.com/forum/#!topic/knitr/_I5rlo9tOeA the global chunk
options set in child documents are no longer restored
- fixed #604: `kable()` did not work on data frames/matrices of one row
(thanks, Kevin Ushey)
- fixes the bug reported at http://stackoverflow.com/q/18992260/559676;
`render_jekyll('prettify')` should have pasted the source code lines into
one character string
MAJOR CHANGES
- when the chunk option `cache=2`, the recorded plots (i.e. display lists)
will no longer be cached, and the figure files will be assumed to exist
the next time the document is compiled, otherwise the cache will be purged
and the chunk needs to be recomputed; this will save some disk space and
avoid bugs like #588 (thanks, @knokknok)
MINOR CHANGES
- the Rnw chunk syntax is more tolerant on chunk headers in the sense that
any characters after `<<>>=` are discarded, e.g. `<<echo=TRUE>>===foo`
will be treated as `<<echo=TRUE>>=` (thanks, Michael Friendly)
- `knitr:::.onLoad()` no longer modifies the `PATH` variable when
`/usr/texbin` is not in `PATH` under Mac OS
- when a message/warning/error contains line breaks, they are preserved
and the message will not be re-wrapped (#602, thanks, Tyler Rinker)
- `read_chunk()` tolerates white spaces in the end of the chunk headers now
(suggested by John Maindonald, #606)
- for R HTML documents, only the `highlight` component in
`opts_knit$get('header')` was used in previous versions; now all components
except `framed` and `tikz` are used; this makes it possible to further
customize the HTML header (thanks, Wahlen Neuwirth and Erich Neuwirth)
- in previous versions, the global option `KNITR_WIDTH` in R was used to
set `options(width)`; now this option is set from `opts_knit$get('width')`,
which has the same default value `75` (#597)
CHANGES IN knitr VERSION 1.4
NOTE
- if you are using Windows or Linux, you need to read the news about both
versions 1.3 and 1.4, because the version 1.3 did not manage to survive
on CRAN
NEW FEATURES
- the cache system is more granular now: instead of the binary option `cache
= TRUE / FALSE`, we can specify `cache = 0, 1, 2, 3` (`TRUE` indicates 3,
and `FALSE` indicates 0; for 1 and 2, see the documentation for `cache`:
http://yihui.name/knitr/options); this means we may change the chunk
options involved only with output rendering (e.g. from `echo = TRUE` to
`FALSE`, or set `fig.cap = 'a new caption'`) without breaking the cache
(thanks, Jeroen Ooms, Clark Kogan, and Roman Lustrik, #396, #536)
- added two new vignette engines called `docco_linear` and `docco_classic`
using the Docco styles (http://jashkenas.github.io/docco/); see
`browseVignettes(package = 'knitr')` for examples
- added a function `rocco()` to compile R Markdown documents to HTML using
the classic Docco style, i.e. a two-column layout, with text on the left
and code on the right (thanks, Weicheng Zhu, #577)
- added an argument `comment` in `spin()` to specify comment lines that will
be ignored by `spin()`; by default, the block comment `/* comment */` is
recognized; thanks, Bryan Hanson http://stackoverflow.com/q/17664401/559676
- it is possible to set package options prior to loading the **knitr**
package now: for a package option `foo`, we can set `options(knitr.foo =
value)` so that **knitr** will `opts_knit$set(foo = value)` when calling
`knit()`; see `?opts_knit` for details (thanks, Zhiguang Zhao)
- added a new argument `ext` to the `pandoc()` function so that users
can manually specify the output filename extensions (thanks, baptiste,
http://stackoverflow.com/q/17710249/559676)
- for LaTeX and HTML output, syntax highlighting can be done for
languages besides R (e.g. Python, Perl, ...); this is achieved by
`highr::hi_andre()`, so Andre Simon's Highlight must be installed,
otherwise **knitr** will fall back to verbatim output for source code; see
https://github.com/yihui/knitr-examples/blob/master/098-highlight-python.Rnw
for an example (#495)
MAJOR CHANGES
- **knitr** formally depends on the **highr** package now (for syntax
highlighting of LaTeX and HTML)
- the package option `stop_on_error` has been deprecated; now it is much
easier to specify whether you want to stop on errors or not by using the
existing chunk option `error`; if you want to stop, use `error=FALSE`;
see the documentation for details: http://yihui.name/knitr/options
- the meanings of the chunk options `warning` and `message` when they take
the value `FALSE` have also changed: `FALSE` means the warnings/messages
will be printed in the R console and not recorded; this makes it easier
to know when/where the warnings/messages were produced during `knit()`
- syntax highlighting and adding prompts are done in the `source` hook
now; in previous versions, they were done in `knitr:::wrap.source`;
now the `source` hook receives the pure source code instead of syntax
highlighted code
MINOR CHANGES
- for the chunk options set in package option `opts_knit$get('eval.after')`,
they will not be evaluated after a chunk if `eval=FALSE` for that chunk
(#570, thanks, @knokknok)
- for document formats that produce HTML output, the default graphical device
is changed to `png` only if it is `pdf`; if the device has been changed
to values other than `pdf`, **knitr** will no longer modify it internally;
when the `png` device is not available, the `svg` device will be used instead
- removed the global option `KNITR_PROGRESS`, which was introduced to
suppress the progress bar, but now we have got `knit(..., quiet = TRUE)`,
so this option is redundant
BUG FIXES
- in LaTeX output, the double quotes `"` in the messages, errors, and
warnings are replaced by `"{}` because they might cause trouble to babel:
http://stackoverflow.com/q/18125539/559676 (thanks, Thierry)
CHANGES IN knitr VERSION 1.3
NEW FEATURES
- added support for AsciiDoc; see example 089 at
https://github.com/yihui/knitr-examples/blob/master/089-minimal.Rasciidoc
(thanks, Richard Cotton)
- added support for reStructuredText vignettes in packages; now `*.Rrst`
documents are recognized as vignettes as well, and they will be compiled
to PDF via `rst2pdf` (#533) (thanks, Trevor L Davis)
- a new function `kable()` to produce simple tables; see
the vignette `datatables` in `browseVignettes(package =
'knitr')` for an application; also see a LaTeX example at
https://github.com/yihui/knitr-examples/blob/master/091-knitr-table.Rnw
- the chunk options `fig.width` and `fig.height` are vectorized according to
the `dev` option, e.g. `fig.wdith = c(7, 10)` and `dev = c('pdf', 'png')`
(#538) (thanks, @baptiste)
- for `purl()`, code chunks with the option `purl=FALSE` will not be
included in the R script (#519, thanks, Sebastian)
- new `'hide'` value to the `fig.show` option; the figures are created
but not included in the output document (#532) (thanks, Simon)
- the `sas` engine uses the listings output now (#541) and was tweaked
for better LaTeX display (#562) (thanks, Nick Salkowski)
- added a quick and dirty `c` engine (via `R CMD SHLIB`); see
https://github.com/yihui/knitr-examples/blob/master/090-engine-c.Rmd for
an example
- added a new engine `asy` for Asymptote, a vector graphics
language (http://asymptote.sourceforge.net); see examples 093 at
https://github.com/yihui/knitr-examples (thanks, Thibaut Lamadon, #559)
- added a new engine `cat` to write the content of a code chunk to a file;
see the example 095 at https://github.com/yihui/knitr-examples (thanks,
Stephen Eglen)
- added a new function `knit_exit()` to allow `knit()` to exit early as
if it had reached the end of the document (#524, thanks, Renaud)
- the chunk option `fig.align` also works for Markdown output now, e.g.,
`fig.align = 'center'` will center images in HTML via the `style` attribute
of the `<img>` tag (#387)
- the argument `format` in the `pandoc()` function was vectorized, e.g. we
can call `pandoc(input, format = c('html', 'latex'))` and the input file
will be converted to HTML and LaTeX, respectively (#547, thanks, Jeroen Ooms)
- added an argument `options` to `knit_child()` to set global chunk options
for child documents; if a parent chunk calls a child document (via the
`child` option), the chunk options of the parent chunk will be used as
global options for the child document, e.g. for `<<foo, child='bar.Rnw',
fig.path='figure/foo-'>>=`, the figure path prefix will be `figure/foo-` in
`bar.Rnw`; see http://stackoverflow.com/q/17514055/559676 for an application
- `eclipse_theme()` works with font weight (bold) and font style (italic)
now when parsing themes from http://eclipsecolorthemes.org
- added two package options `latex.options.graphicx` and
`latex.options.color` to allow customization of LaTeX package options,
e.g. `opts_knit$set(latex.options.color = 'monochrome')` generates
`\usepackage[monochrome]{color}` in the LaTeX output (#546)
- added a new package option `unnamed.chunk.label` to set the chunk labels
for unnamed chunks, e.g. `opts_knit$set(unnamed.chunk.label = 'fig')`
will generate chunk labels `fig-1`, `fig-2`, ... (#555) (thanks, Noam Ross)
- when `knit()` is running, a global option `knitr.in.progress` will
be set to `TRUE`; this allows other package authors (e.g. `rCharts`
and `googleVis`) to adjust certain package options according to
`getOption('knitr.in.progress')` (thanks, Ramnath V, #564)
BUG FIXES
- fixed #502: using `layout()` and `par()` at the same time
under R 3.0.0 may lead to a corrupt plot (thanks, Hong Xu
http://tex.stackexchange.com/q/108335/9128)
- fixed a bug in `pandoc()`: for single-lettered Pandoc arguments, the
values are passed to them after spaces instead of equal signs (reported
at http://stackoverflow.com/q/16569010/559676)
- fixed #542: when a child document has a sub-child document and also uses
`set_parent()`, the LaTeX header will be added to the wrong file (thanks,
Johan Toloe)
- `stitch_rmd()` was using a wrong R Markdown template
- fixed #537: misleading error message when the graphical device does not
exist (thanks, Scott Kostyshak)
- fixed a bug in `hook_rgl()` reported at http://cos.name/cn/topic/110742
(incorrect LaTeX code when `fig.align='center'` and `fig.show='hold'`)
- fixed #565: added the `envir` argument to `spin()` so that the code is
evaluated in the correct environment by default (thanks, @GillesSanMartin)
MAJOR CHANGES
- `purl()` will write the chunk headers in `# ---- label, opts ----`
instead of `# @knitr label, opts`, i.e. `@knitr` was changed to four dashes
`----`; similarly, `read_chunk()` will use the pattern `# ---- label ----`
to read external code (the old syntax `# @knitr` is still preserved for
compatibility); the main reason for this change is that RStudio uses four
dashes in R comments as section headings, so that it is possible to fold
sections of R
- syntax highlighting is done by the **highr** package if it has been
installed, otherwise the old regular-expression-based syntax highlighting
will still be used; the **highr** package does much better syntax
highlighting than the regexp-based approach (#327)
- the commands for syntax highlighting were changed for compatibility with
Andre Simon's Highlight package; this will affect LaTeX and HTML users,
e.g. `\hlnumber` was renamed to `\hlnum`; cached LaTeX and HTML will have
to be rebuilt for the new syntax highlighting commands to work (#470)
- the argument `eval` was removed in `knit_child()`; if we do not want to
evaluate a child document, we can set `eval=FALSE` in its parent chunk
- the script `inst/bin/knit` gains an option `-o` to specify the output
filenames for `knit()` (#525, thanks, Aaron Wolen)
- the default video format for animations is OGG (it is open and free)
instead of MP4 (non-free) now; this means Internet Explorer under Windows
may not work with the animations (consider Firefox, Chrome and other modern
web browsers)
- warnings and messages in adjacent output chunks are merged, respectively
(#534)
- when the package option `verbose = TRUE`, the time stamp will be printed
after each chunk using `timestamp()`, but this will mess up with the R
command history, so now **knitr** uses `cat()` to write the time stamp
(#545) (thanks, @knokknok)
- the argument `base` in `read_rforge()` was removed and hard-coded inside
the function instead
- for Markdown output, the figure filenames no longer allow special
characters like spaces, and special characters will be automatically
replaced by `_`; this change will avoid problems when publishing to RPubs
from RStudio: if figure paths contain special characters, the figures will
not be uploaded (thanks, Sangsoon Woo)
MINOR CHANGES
- the package vignettes uses `\VignetteEngine{knitr::knitr}` instead of
`\VignetteEngine{knitr}` so that the next version of R can compile the
vignettes out of the box (via `R CMD Sweave`) and no longer need to build
the whole package in order to build the vignettes
MAINTAINENCE
- the package vignettes were moved to the `vignettes` directory from
`inst/doc` since the former will be preferred by the future versions of R
- the testing is done via the **testit** package now
(http://cran.r-project.org/package=testit)
MISC
- **knitr** becomes an affiliated project of FOAS (Foundation for Open
Access Statistics): http://www.foastat.org/projects.html
CHANGES IN knitr VERSION 1.2
NEW FEATURES
- added a Pandoc wrapper function `pandoc()` to convert Markdown documents
to other formats that Pandoc support such as LaTeX/PDF, OpenDocument,
HTML5 slides and unfortunately also Word (#206)
- in the past the chunk hooks were ignored when the chunk option `engine !=
'R'` (i.e. code in the chunk is not R); now they are executed regardless
of the language of the code chunk (#483) (thanks, @cdrv)
- multiple WebGL objects from the **rgl** package can be generated in the
same web page now; each object is uniquely identified by the corresponding
chunk label; see https://dl.dropbox.com/u/15335397/misc/webgl-rmd.html
for an example (#494) (thanks, Carson Sievert)
- if multiple graphical devices are used (the chunk option `dev` is a vector
of length greater than 1), the chunk option `dev.args` can be a named list
of lists of device arguments, with each element a list of arguments to be
passed to the single device; see http://yihui.name/knitr/options
- as announced in the last version, R 3.0.0 will support non-Sweave
vignettes; now it is also possible to compile R HTML vignettes via **knitr**
since `*.Rhtml` files are also registered by **knitr** as vignette files
- a new chunk option `cache.vars` to manually specify which variables to save
in the cache database; by default all newly created and modified variables
are identified and saved, but in some cases, **knitr** may not be able to
identify the modified variables, e.g. `DT[, foo:=value]` in **data.table**
(we can set `cache.vars='DT'` to force **knitr** to save a copy of `DT`)
- added a new engine `Rscript` to run the R code in a new R session;
see http://stackoverflow.com/q/15271406/559676 for an example
- the executable script `inst/bin/knit` can accept multiple input files now
(e.g. `knit foo.Rnw bar.Rmd zzz.Rhtml`)
- `knit()` and `knit2html()` gained a `quiet` argument to suppress messages
and the progress bar (thanks, Vince Buffalo)
- added the `text` argument to `spin()` and `stitch()` respectively as
an alternative way to provide the input like `knit()` (#509) (thanks,
Craig Watson)
- a new function `wrap_rmd()` to wrap long lines in Rmd files without
affecting the code blocks (if there are any); this makes it easier for
verson control purposes
- `rst2pdf()` will pass a default output filename to `rst2pdf` (if the
input is `foo.rst`, the output will be `foo.pdf`)
- `knit2wp()` gained a new argument `publish = TRUE` (thanks, Eric Nantz)
(#512)
BUG FIXES
- fixed the problem reported in http://stackoverflow.com/q/12448507/559676
now \usepackage{upquote} should appear after \usepackage{fontenc}, so
single quotes in verbatim environments will no longer cause problems
- fixed #487: `stitch_rhtml()` and `stitch_rmd()` should not use the chunk
option `out.width = '.6\\linewidth'` (thanks, Tal Galili)
- when the chunk option `engine` is not `R`, the code is also executed
under the directory `opts_knit$get('root.dir')` (if specified); thanks,
Winawer http://stackoverflow.com/q/15512545/559676
- `:` is permitted in `fig.path` now (#513) (thanks, Sebastian)
- fixed an encoding problem (`CP950`) for Hong Kong Windows users reported
at http://bit.ly/16RQL5E
MAJOR CHANGES
- all child documents are inserted into the parent document as character
strings of the (compiled) content, instead of being saved into files
(e.g. `\input{foo-child.tex}`); no matter how many child documents there
are, only one main output file will be generated; the package option
`child.command` was removed accordingly since it is no longer used
- no longer generates concordance data for child documents; the past attempt
did not really work well and the implementation was complicated, so now we
only support concordance for the main document; the consequence of this
change is the synchronization between PDF and Rnw for child documents no
longer works at the line level (clicking in PDF will still bring the focus
back to the child chunk)
- in previous versions, cached chunks were evaluated in separate (empty)
environments in order to capture the newly created variables, but this brings
confusion when we use functions depending on the current environment such as
`ls()` (which will return `character(0)`); now all chunks, cached or not,
are evaluated in the same environment `knit_global()` (finally fixed #456)
- `knit2pdf()` and `knit2html()` return the output filename when the input
is a file (in previous versions, `NULL` was returned in this case)
- the package option `stop_on_error` is set to `2` now when building package
vignettes, which means R will stop on errors in vignettes; this make it
easier to find out possible problems in vignettes during `R CMD build`
- the document hook `hook_rjournal()` was removed; it was too hackish (see
http://yihui.name/en/2013/02/contribute-to-the-r-journal-with-lyx-knitr/
for how to write an article for The R Journal in a less hackish way)
MINOR CHANGES
- the progress bar symbol was changed from `>` to `.` so it looks less
intrusive (#395) (thanks, Michael Friendly)
DOCUMENTATION
- the **knitr** book is forthcoming:
http://www.crcpress.com/product/isbn/9781482203530 run `citation('knitr')`
or `toBibtex(citation('knitr'))` in R to obtain the citation info
- open `help(package = 'knitr', help_type = 'html')` to see the vignette
examples (Rnw, R Markdown and R HTML)
CHANGES IN knitr VERSION 1.1
NEW FEATURES
- (experimental) R 3.0.0 will support non-Sweave vignettes, e.g. Rnw
documents can be compiled by **knitr** instead of Sweave; in addition,
R Markdown vignettes have also become first-class citizens as R package
vignettes; see http://yihui.name/knitr/demo/vignette/ for details
- a new engine for coffeescript
(i.e. the chunk option `engine='coffee'`); see
https://github.com/yihui/knitr-examples/blob/master/080-engine-coffeescript.Rmd
for an example (thanks, Nacho Caballero)
- when the chunk option `eval=FALSE`, `purl()` will comment out the code
when extracting code chunks (thanks, Randall Pruim)
- the global option `KNITR_PROGRESS` can be used to set the package option
`progress` in `opts_knit`, e.g. after `options(KNITR_PROGRESS = FALSE)`,
this option will be set to `FALSE` when the package is loaded (#395)
- the global option `KNITR_WIDTH` can be use to set the R option `width`
before **knitr** is called; in the past this option was hard-coded to
`75`, and now it is set as `options(width = getOption('KNITR_WIDTH', 75L))`
- a new function `knit2wp()` which compiles R Markdown
documents and publishes the results to WordPress; see
http://yihui.name/knitr/demo/wordpress/ for details
- a new hook `hook_webgl()` which writes the WebGL code of an
**rgl** scene into the output using `rgl::writeWebGL()` so we
can reproduce a 3D plot in the browser (thanks, Stephane Laurent
http://stackoverflow.com/q/14879210/559676)
BUG FIXES
- fixed #465: when `eval=FALSE` and `echo` is numeric, code was incorrectly
filtered by the indices in `echo` (thanks, @ateucher)
- `>` was not allowed in HTML inline code expressions
(http://stackoverflow.com/q/14360296/559676); now the regular expression
works correctly to look for `-->` instead of `>`
- `set_parent()` should not print `NULL` in the child document:
http://stackoverflow.com/q/14487718/559676 (thanks, Thomas Holz)
- child documents now inherit the encoding parameter from their parent
document, i.e. the `encoding` value in `knit(..., encoding = ?)` is applied
to `knit_child()`; note this assumes the parent document and the child
documents use the same encoding (thanks, Henrik Nyhus)
MAJOR CHANGES
- empty inline expressions are no longer recognized, e.g. `\Sexpr{}`
will not be parsed; this allows one to write such markers in
tutorials (e.g. `<!--rinline -->` and `` `r ` ``); internally
`all_patterns$foo$inline.code` was changed
- the function `build_dep()` was removed (the warning has been there for
a long time); please use `dep_auto()` instead
- the package option `filter.chunk.end` was removed; this means in Rnw
documents, a single line `@` has the meaning of terminating a chunk _only
if_ there is a chunk header `<<>>=` before it; otherwise it does not have
any special meanings
- the function `run_chunk()` was removed; it is redundant because we already
have the chunk option `ref.label` as well as in-chunk reference `<<label>>`
MINOR CHANGES
- the function `imgur_upload()` uses Imgur API version 3 now; if you are
using the key obtained from version 2, you need to register for your own
client id: http://api.imgur.com (#439)
- allow users to pass a custom environment to `Rcpp::sourceCpp()` in the
`Rcpp` engine; fixes http://stackoverflow.com/q/14882486/559676
- slight improvement of encoding support in `knit()`
CHANGES IN knitr VERSION 1.0
NEW FEATURES
- a new function `knit_expand()` which is similar to **brew**
and mustache, e.g. it expands `pi is {{pi}}` to `pi is
3.14`; it can also be used for building child documents (see
https://github.com/yihui/knitr-examples/blob/master/075-knit-expand.Rnw
for example) (#397) (thanks, Frank Harrell)
- `knit()` gained a new argument `encoding` to specify the encoding of
the input file (multilingual support is complete now), e.g. `knit(...,
encoding = 'GBK')` for Simplified Chinese
- a new function `Sweave2knitr()` to convert Sweave documents to **knitr**;
several automatic translations can be done, e.g. `results=tex` to
`results='asis'`, `width=5` to `fig.width=5`, `echo=true` to `echo=TRUE`,
`keep.source=TRUE` to `tidy=FALSE`, `eps=TRUE` to `dev='postscript'`,
`\SweaveOpts{...}` to `opts_chunk$set(...)` and so on; see the documentation
in the package for details (#451)
- if the Sweave syntax is detected in an Rnw document, a message box
(**tcltk**) will pop up as a reminder on how to fix it
- inline R code also respects the option `opts_knti$get('stop_on_error')`
now, e.g. if we set this option to `2L`, R will completely stop when error
occurs in inline R code
- a new function `all_labels()` to get all chunk
labels in a document; see one application at
https://github.com/yihui/knitr-examples/blob/master/073-code-appendix.Rnw
- chunk hooks will be run (if exist) even if the code chunk is empty
- added two wrapper functions `stitch_rhtml()` and `stitch_rmd()` which
use the R HTML and R Markdown templates respectively when calling `stitch()`
- the chunk label is used as the id of the div element in R HTML output,
e.g. `<div id='chunk-label'>...</div>`
MAJOR CHANGES
- (IMPORTANT) the internal compatibility with Sweave has been dropped
as scheduled in the last version, and the **knitr** parser was greatly
simplified accordingly; Sweave users can call the function `Sweave2knitr()`
to convert old Rnw files to **knitr** files before running `knit()`
- accordingly, the pattern elements `global.options` and `inline.doc`
were removed from `knit_patterns` (`\SweaveOpts{}` and `\SweaveInput{}`
will no longer be supported; please call `Sweave2knitr()` to convert
incompatible Sweave documents)
- chunk labels can be arbitrary characters now; in the past they had to be
valid R symbols, e.g. `2a` was an invalid label; this restriction has been
removed, because chunk labels will be automatically quoted when necessary
(`<<2a>>=` will become `<<'2a'>>=`, but `<<'3-function'>>=` will remain
untouched)
- if the chunk option `include=FALSE`, the evaluation will stop if errors
occur (i.e. `stop_on_error=2L` for **evaluate**), because otherwise it
will be very difficult for authors to notice errors in chunks which have
`include=FALSE` (#453) (thanks, Joshua Pritikin)
- the function `knit_env()` is no longer available (it is not exported
any more), and `knit_global()` has been exported now
MINOR CHANGES
- for inline R code, the value is returned only if the R code prints
a visible value, e.g. `\Sexpr{x <- 1}` will be empty, and `\Sexpr{pi}`
will return the value of pi
BUG FIXES
- fixed #432: no longer uses `\\\\` in LaTeX output; only a single line
break is converted to `\\` (thanks, Kevin Wright)
- `render_html()` guarantees that the R source code is highlighted when
the chunk option `highlight = TRUE` (#447) (thanks, Ramnath Vaidyanathan)
- `dep_auto()` was unable to find the cache files if the input document
is not under the current working directory (thanks, Hui Yao)
Documentation
- because Github has deprecated downloads, all downloads were moved to
Bitbucket, and the links in the package website as well as all examples
have been updated (#438)
CHANGES IN knitr VERSION 0.9
NEW FEATURES
- added a demo named `notebook` which is an R notebook based on the **shiny**
package (https://github.com/rstudio/shiny); use `demo('notebook', package =
'knitr')` to see it, or visit http://glimmer.rstudio.com/yihui/knitr
- for numeric inline output in LaTeX, the `I()` trick is no longer needed,
e.g. `$x=\Sexpr{1.2e10}$` is safe for LaTeX now due to `\ensuremath{}`
(#137) (thanks, Randall Pruim)
- the chunk option `eval` can take numeric values now, specifying which
expressions to evaluate in a chunk (#383) (thanks, Jared Lander)
- a new package option `stop_on_error` which specifies the behavior of
errors in code chunks; this option is passed to the **evaluate** package,
e.g. `opts_knit$set(stop_on_error = 2L)` will make **knitr** completely
stop on errors (the default value is `0L` which means to move on even
if errors occurred); this makes it possible to see the call stacks via
`traceback()` in an interactive R session when an error occurs (#344)
(thanks, Hadley Wickham and Dzidorius Martinaitis)
- added support to the **Rcpp** package through the chunk option
`engine='Rcpp'` so that we can write C++ source code in the document; see
https://github.com/yihui/knitr-examples/blob/master/029-engine-Rcpp.Rmd
for an example (#415) (thanks, JJ Allaire)
- **knitr** throws a warning when a cached chunk depends on an uncached chunk
because this kind of dependency will be ignored (#431) (thanks, @ghostwheel)
- a list of arguments can be passed to `formatR::tidy.source()` as the
chunk option `tidy.opts` now, e.g. `tidy.opts=list(width.cutoff=60,
keep.blank.line=FALSE)` (#429)
- some chunk options are recycled for plots such as `fig.env`,
`out.width` and `out.extra`, etc; this means if there are multiple
plots per chunk, we can specify different output options for them
individually (e.g. `out.width=c('2in', '.4\\linewidth')` for two plots); see
https://github.com/yihui/knitr-examples/blob/master/067-graphics-options.Rnw
for an example (motivated by #430) (thanks, @autumnlin)
- added a new chunk option `fig.subcap` for captions of subfigures in
LaTeX; when there are multiple plots in a chunk, and neither `fig.subcap`
nor `fig.cap` is NULL, `\subfloat{}` will be used for individual
plots (you need to add `\usepackage{subfig}` in the preamble); also see
https://github.com/yihui/knitr-examples/blob/master/067-graphics-options.Rnw
for an example (#388) (thanks, @skipperhoyer)
- `stitch()` accepts labeled R scripts now; if an R script contains chunk
headers of the form `## @knitr label, options`, they will be used in the
template (#411) (thanks, @jamiefolson)
- the function `read_chunk()` gained a few new arguments so that we can
reference external code chunks in another way, which was an idea from the
**SweaveListingUtils** package (thanks, Peter Ruckdeschel)
- a new function `read_demo()` based on `read_chunk()` to read demo scripts
in R packages
- a new convenience function `read_rforge()` to read code
from R-Forge repositories; combined with `read_chunk()`, it
can insert R code from R-Forge into **knitr** dynamically; see
https://github.com/yihui/knitr-examples/blob/master/046-read-rforge.Rmd
for an example (thanks, Peter Ruckdeschel)
- chunk options are also written after `## @knitr` along with chunk labels
when tangling R scripts via `purl()`
- `purl()` gained a new argument `documentation` to also write documentation
lines into the R script (#391 and #401) (thanks, Noam Ross and Fernando
Mayer)
- `knit_rd()` generates a navigation frame on the left and builds links now;
this is like the CHM help in old days (thanks, Michael Friendly)
- a new function `knit_rd_all()` to build static html help pages for all
the packages installed
- we can also use `## @knitr` to write chunk options for `spin()` now
(`#+` and `#-` still work)
- added new language support for Perl and Z Shell (`zsh`); see an example
at https://github.com/yihui/knitr-examples/blob/master/028-engine-perl.Rmd
(#406) (thanks, Jim Hester)
- `render_jekyll()` gained an argument `highlight` to specify which
highlighting engine to use (Pygments or Prettify.js) (thanks, Yanping Chen)
- two new chunk options for language engines: `engine.path` and
`engine.opts`; the former can be used to specify the path of the program
(e.g. `<<engine='ruby', engine.path='/usr/bin/ruby1.9.1'>>=`); the latter
can be used to pass additional arguments to the engine program
- added new engines for GraphViz (`engine='dot'`) and TikZ (`engine='tikz'`);
see https://github.com/yihui/knitr-examples/blob/master/057-engine-dot.Rmd
and https://github.com/yihui/knitr-examples/blob/master/058-engine-tikz.Rmd
for examples (#419) (thanks, Michel Kuhlmann)
- added a preliminary engine for SAS which is basically a call like
`system('sas chunk-code.sas')` (#354)
- a new `document` hook to post-process the LaTeX output document to move
code chunks out of figure/table environments so that code chunks will not
float with the environments; see `?hook_movecode` for details
- chunk hooks are called in the _reverse_ order after a chunk (and natural
order before a chunk); this allows one to, e.g. write an opening environment
before a chunk and close it properly after a chunk
- all language engines also respect the `comment` option when writing output
just like R code chunks (by default the output is commented out by `##`)
- added a new function `set_alias()` as a wrapper to `opts_knit$set(aliases
= ...)`, e.g. `set_alias(w = 'fig.width')` sets `w` as an alias for the
chunk option `fig.width`
MAJOR CHANGES
- global options are strongly recommended to be set via real R code
`opts_chunk$set(opt = value)` in a code chunk instead of the old
syntax in text chunks like `\SweaveOpts{opt = value}`, or `<!--roptions
opt=value-->`, etc, which will be deprecated in the next version; this
will make it cleaner and safer to parse the source documents, e.g. we can
write arbitrarily complicated expressions like `opts_chunk$set(fig.width =
if (foo == 'beamer') { 5 } else { 7 })` which is impossible in the old
syntax; if you still use the old syntax like `\SweaveOpts{}`, you will
see a warning with a pause of 10 seconds
- based on the same reason, it is recommended to use the chunk option `child`
to input child documents; old syntax like `\SweaveInput{}` will be deprecated
- for markdown output, results from inline R code will no longer be put
in a pair of backticks (#379)
- the package option `opts_knit$get('cache.extra')` was removed
because this option should really be a chunk option instead; see
http://yihui.name/knitr/demo/cache/ for the updated documentation (#404
and #405) (thanks, Jim Hester)
- the chunk option `highlight.opts` was deprecated and renamed to
`engine.opts`; this affects users who use Andre Simon's highlight through
the `highlight` engine in **knitr**
- the chunk option `file` for Awk was deprecated; we
can also use `engine.opts` to specify the file for Awk; see
https://github.com/yihui/knitr-examples/blob/master/024-engine-awk.Rmd
for example
- the pattern `knit_pattern$get('ref.label')` was deprecated since it is
unlikely to be customized; a fixed pattern `'^#+\\s*@knitr(.*)$'` will be
used instead
MINOR CHANGES
- when `opts_knit$get('verbose')` is `TRUE`, a `timestamp()` will be
printed before each code chunk is evaluated (#377) (thanks, Carl Boettiger)
- `stitch()` will no longer copy the template over to the current working
directory (thanks, Michael Friendly)
- `stitch()` will no longer open the PDF/HTML output automatically (#411)
(thanks, Michel Kuhlmann)
- the script `inst/bin/knit` can also convert R Markdown documents to HTML
now; the argument `--pdf` was removed and a new argument `--no-convert`
was added
- dots in figure filenames will not be replaced with `_` when the output
is not LaTeX (thanks, Stewart Macarthur)
BUG FIXES
- fixed #410: when the inline R code returns `NA_real_`, the scientific
notation of numbers will run into errors (thanks, Rafik)
- the syntax pattern for Rnw documents was not quite right:
`all_patterns$rnw$chunk.end = '^\\s*@\\s*%*'` actually allows any characters
after `@`, but only LaTeX comments and white spaces are allowed; it has
been fixed to `^\\s*@\\s*(%+.*|)$` now
DOCUMENTATION
- an example of combining R, knitr and D3 to draw a contour plot:
http://yihui.name/knitr/demo/javascript/
CHANGES IN knitr VERSION 0.8
NEW FEATURES
- output from other languages (e.g. python, awk,
...) can also be cached like R output when `cache=TRUE`; see
[023-engine-python.Rmd](https://github.com/yihui/knitr-examples/blob/master/023-engine-python.Rmd)
for an example
- added support for bash/shell scripts; use the chunk option `engine='bash'`
or `engine='sh'` to write shell scripts in code chunks (#361)
- a new function `knit_rd()` to knit package documentation (run examples
code and insert output in the HTML documentation) (#227) (thanks, Taiyun Wei)
- added LuaTeX support for tikz graphics with the **tikzDevice** package
(set `options(tikzDefaultEngine = 'luatex')`); this feature requires
**tikzDevice** version > 0.6.2 (#358) (thanks, Alastair Andrew)
- a new chunk option `fig.env` to set which environment to use for figures in
LaTeX, e.g. we can set `fig.env='marginfigure'` to use `\begin{marginfigure}`
(#364) (thanks, Bryan Hanson)
- added a new package option `global.device` (default `FALSE`) which
specifies whether to use a global graphics device to capture plots; if
`TRUE`, it is possible to write `plot(1:10)` in a previous chunk and
`abline(0, 1)` in a latter chunk because all code chunks share the same
device, however, this may also bring unexpected consequences (in particular,
using `par()` can bring redundant plots)
BUG FIXES
- dots in figure paths are more safely replaced with `_` now,
e.g. `fig.path='../figure'` will no longer be replaced by `__/figure`
(#346) (thanks, @ralfer)
- the `c()` syntax for the chunk option `dependson` did not actually work,
e.g. `dependson=c('foo', 'bar')` (#350) (thanks, Cassio Pereira)
- fixed a bug when `eval=FALSE` and `prompt=TRUE` (the continuation
character was used in some places where there should be the prompt character)
(thanks, Derek Ogle)
- `persp()` plots were not recognized in the last version (thanks,
Jeffrey Racine)
MAJOR CHANGES
- leading spaces are allowed in chunk headers now, e.g. in the past
`<<>>=` must appear in the beginning of a line, but now we can indent
the chunk header by a number of white spaces; this amount of spaces will
be stripped off the chunk if the whole chunk is indented (#236) (thanks,
@jamiefolson and Vitalie Spinu)
- markdown output will be indented if the original code
chunk is indented; this allows chunk output to be nested
within its parent environment, e.g. inside an ordered list (see
[001-minimal.Rmd](https://github.com/yihui/knitr-examples/blob/master/001-minimal.Rmd)
for example)
- when the global chunk option `eval=FALSE`, inline R code will not be
evaluated, and `??` is returned for inline R expressions (#367)
MINOR CHANGES
- if `getOption('OutDec')` is not `.`, inline numeric output will be put
inside `\text{}` in LaTeX to avoid situations like #348 (the normal math
mode may add a space after the comma in `3,1415`)
- if the chunk option `external==FALSE` (default is `TRUE`), **knitr** will
no longer automatically add `\usepackage{tikz}` to the LaTeX preamble; you
need to add it manually (but it is recommended to use `external=TRUE` with
`cache=TRUE` for the sake of speed, because compilation of tikz graphics
may be slow)
- `*.brew` generates `*.txt` by default (instead of `*-out.brew`)
- `knit(text = ...)` will no longer write output in the console (the output
is only returned as a character string)
DOCUMENTATION
- added a simple reference card:
https://bitbucket.org/stat/knitr/downloads/knitr-refcard.pdf
CHANGES IN knitr VERSION 0.7
NEW FEATURES
- added a new chunk option `out.extra` to write extra graphics output
options, e.g. `<<out.extra='angle=90'>>=` to rotate the figure by 90 degrees;
see http://yihui.name/knitr/options (#301) (thanks, @knokknok)
- when `opts_knit$get('verbose')` is TRUE, logs (messages, warnings and
errors) along with the corresponding R code will be printed after `knit()`
is done; this might help users figure out possible problems in R code
quickly (#276)
- `.Random.seed` is cached again for the sake of reproducibility; see
http://yihui.name/knitr/demo/cache/ for how to maintain reproducibility
when the computation involves with random number generation (#274)
(thanks, Renaud)
- the package option `opts_knit$get('cache.extra')` can be an unevaluated
R expression now, e.g. `opts_knit$set(cache.extra = quote(.Random.seed))`;
see the cache page above for a concrete example
- added a new package option `'root.dir'` (default `NULL`) which can be
used to set the root directory to evaluate code chunks in a document;
by default, the root directory is the directory of the input document,
and this option enables users to set other directories as the working
directory for code chunks (#277) (thanks, Ken Williams)
- `spin()` will add `\documentclass{article}` for Rnw output if no document
class is specified in the R script so that the LaTeX output will be a
complete document (#295) (thanks, Christiaan Klijn)
- added Ruby support in the `engine` option; see the example
https://github.com/yihui/knitr/blob/master/inst/examples/knitr-lang.Rmd
(#294) (thanks, Ramnath Vaidyanathan)
- also added Haskell support in the option `engine='haskell'` through
calling `ghc` (#336) (thanks, Michel Kuhlmann)
- added support to Andre Simon's `highlight` through the option
`engine='highlight'`; see https://gist.github.com/3114112 for an example
of highlighting Matlab code in LaTeX (thanks, Dirk Eddelbuettel and
Renaud Gaujoux)
- the output hooks for LaTeX, HTML, Markdown and reST will respect the
`engine` option now, so these hooks can be readily used for output when
the language is not R, e.g. `render_markdown(strict = TRUE)` also works
for Python output (#251) (thanks, Chris Fonnesbeck)
- the chunk options `eval`, `echo` and `results` are also respected when
the language is not R, e.g. for a Python code chunk with `eval=FALSE`,
the code will not be evaluated, or for a Ruby chunk with `results='hide'`,
the output will be hidden (#293) (thanks, Ramnath Vaidyanathan)
- chunk options `out.width`, `out.height` and `out.extra` also work
for plots in HTML and Markdown output now, e.g. `out.width='200px'` or
`out.extra='style="display:block;"'` (#297) (thanks, Taiyun Wei and Alan
Severini)
- the hook function to create animations in HTML output is exported now as
`hook_ffmpeg_html()`
- added a package option `opts_knit$get('animation.fun')` which defaults
to `hook_ffmpeg_html`; this option is used to create animations in HTML
output so that we do not have to use FFmpeg
- added two functions `hook_r2swf()` and `hook_scianimator()` which can
be set as the package option `opts_knit$get('animation.fun')` and create
animations via the **R2SWF** package or the **SciAnimator** library (see
`animation::saveHTML`) (thanks, Taiyun Wei)
- a new function `image_uri()` to create data URIs for image files; we can
set `opts_knit$set(upload.fun = image_uri)` so that images are embedded
in the HTML output as data URIs (hence the HTML page does not depend on
external images) (#298, #324) (thanks, Wush Wu)
- added a new object `opts_template` which can be used to set a group of
chunk options and they can be referenced later with the new chunk option
`opts.label`; see `?opts_template` for examples; this makes it easy to reuse
groups of frequently used chunk options (#316, #320) (thanks, Cassio Pereira)
- a new function `dep_prev()` to build chunk cache dependencies so that all
later chunks will depend on previous chunks; if any of a previous chunk is
updated, the cache of all chunks after it will be updated as well (#285)
(thanks, @muelleki)
- a new chunk hook function `hook_optipng()` to optimize PNG images using
`optipng` (#272) (thanks, Winston Chang)
- added a new output hook named `document` in `knit_hooks` (see
`knit_hooks$get('document')`); this hook function is used to process the
output of the whole document; it can be useful when we want to post-process
the whote output before writing it to the output file
- a new function `rst2pdf()` which uses the program `rst2pdf` to
convert reST documents to PDF; it is also supported by `knit2pdf()` when
`compiler='rst2pdf'` (#300) (thanks, Alex Zvoleff)
BUG FIXES
- fixed #286: messages (including warnings and errors) are guaranteed to
be ended by `\n`, so even when chunk option `comment=NA`, messages will