(ess-rterm-versions-create): version-root should be a local variable.
[ess.git] / doc / newfeat.texi
blobce2c8b4d994be85d5c56a77f449f9186c7681561
1 Changes/New Features in 5.2.12:
2 @itemize @bullet
3 @item @ESS{[SAS]}: @kbd{M-;} fixed, but the XEmacs function @code{comment-dwim}
4 may be broken, if so, use @kbd{M-x comment-region} and @kbd{M-x uncomment-region}
5 instead; only valid PROCs are fontified which is very helpful finding syntax errors
6 (currently supported:  BASE, ETS, FSP, GRAPH, IML, INSIGHT and STAT).
7 @item Rterm/Cygwin combination works under Microsoft Windows.
8 @item @ESS{[R]}: internal calls use baseenv() instead of NULL and
9 define 'baseenv' where needed.
10 @item New experimental support for installing ESS.  See the file 
11 @file{lisp/ess-install.el}.
12 @end itemize
14 Changes/New Features in 5.2.11:
15 @itemize @bullet
16 @item ESS Info entry and @file{dir} handled more effectively for GNU Emacs users
17 @item @ESS{[SAS]}: temporary files created for batch submission of a
18 region are now named based on the current file; see @code{ess-sas-file-root}
19 for details; all @code{lag} and @code{dif} functions now fontified correctly
20 @item iESS[SAS]: fixed a few nagging bugs, however, still does not appear to
21 work at this time; please let us know if you have any ideas.
22 @item @ESS{[S]}: Support for running other versions of Splus has been
23 added for unix.  Two new variables, @code{ess-s-versions} and
24 @code{ess-s-versions-list}, are used to tell ESS what other versions of
25 Splus you would like to run.
26 @end itemize
28 Changes/New Features in 5.2.10:
29 @itemize @bullet
30 @item @ESS{[R]}: ess-r-versions can no longer be customized (since the
31 customization was not taking effect unless customizations were loaded
32 before ESS).  Its value has been changed so that it will also find R
33 executables beginning ``R-devel'' and ``R-patched''.  If you wish to
34 change this variable, it must be set in your @file{.emacs} before ESS is
35 loaded.
36 @item Installation with GNU Make enhanced:  unix and unix-like
37 operating systems will now be able to install @ESS{} for all
38 users in either a GNU Emacs site-lisp or an XEmacs package
39 configuration by editing @file{lisp/ess-site.el} and @file{Makeconf}
40 accordingly, then issuing @code{make install}
41 @item @ESS{[S]}: Filename completion (inside strings) now also works in
42 XEmacs for R and S-plus.
43 @c working around a bug in Xemacs
44 @end itemize
46 Changes/New Features in 5.2.9:
47 @itemize @bullet
48 @item @ESS{[R]} for Windows:  the \ directory character bug
49 with respect to ess-load-file has been eradicated.
50 @item @iESS{[SAS]}: @kbd{C-c C-r} and @kbd{C-c C-b} once again
51 work as intended and documented.
52 @item @ESS{[S]}: M-x ess-fix-EQ-assign is a bit more agressive.
53 @item @ESS{[S]}: Imenu now also shows setAs(), etc.
54 @item @ESS{[R]}: R function pattern enhanced with underlying code such that
55  @kbd{M-C-a} (@code{ess-beginning-of-function}) etc now work for many more
56  cases, including S4 method definitions.
57 @item @iESS{[R]}: myOwnhelp(1) no longer wrongly triggers help(1).
58 @item @ESS{[R]}: Improved detection of bogus help buffers: valid help
59  buffers containing with the string ``no documentation''(e.g. contour)
60  were being treated as bogus.
61 @item @ESS{[R]}: In R help buffers, if @code{options("help.try.all.packages" =
62  TRUE)} then @code{?rlm} will list which packages rlm is defined in.  This help
63  buffer is not bogus, but instead is now relabelled ``*help[R](rlm in
64  packages)*''.
65 @item @ESS{[STA]}: add ``//'' as comment starting character to syntax-table.
66 @end itemize
68 Changes/New Features in 5.2.8:
69 @itemize @bullet
70 @item iESS: [Tab] completes @strong{file} names ``inside string'' as in
71 earlier (<= 5.2.3) ESS versions.
72 @end itemize
74 Changes/New Features in 5.2.7:
75 @itemize @bullet
76 @item If you use Custom to change the variable ess-toolbar-items,
77 the new toolbar is used in all subsequent ESS buffers.
78 @item @ESS{[SAS]}: new feature:  if ess-sas-log-max >0 and
79 your .log grows to more than ess-sas-log-max bytes, just
80 the first ess-sas-log-max bytes are refreshed; this is helpful when your .sas program
81 generates lots of error messages and gets too big for emacs to display
82 @item @ESS{[R/S]}: @kbd{M-;} in R/S editing modes will now indent with
83 either one or two hashes depending on context.
84 @item @ESS{[R]}: David Whiting's Sweave extensions (to 'noweb')
85 are now available (from ess-swv.el loaded by default).
86 @end itemize
88 Changes/New Features in 5.2.6:
89 @itemize @bullet
90 @item Removed non-ASCII characters in a few files.
91 @item @ESS{[R]}: now works better when UTF-8 locale is active; in
92  particular, you get correct directional quotes in R's startup message
93  for R-devel (unstable development version of R 2.1.0) when using
94  environment variables LANGUAGE=en@@quot LC_ALL=en_US.UTF-8
95 @item @ESS{[SAS]}: toggling of .log mode improved (@kbd{F10}); toggling of
96 .lst mode now also available (@kbd{C-F10}); killing all buffers associated
97 with .sas program no longer bound to @kbd{C-F10} since its a bit overzealous.
98 @item S-Plus 7 for Windows is now recognized.
99 @item @ESS{[S]} (incl.@: R): in auto-fill mode, strings are not wrapped anymore.
100 @item @ESS{[S]} (incl.@: R): font-lock now correctly differs between R and S,
101 e.g., for "_"; both now fontify warning(.) and S does terminate() additionally.
102 @item Support for `bell' aka `beep' aka `ding' aka `alarm' in all inferior
103 modes: When \a is output ``to the the console'' at the beginning of a line,
104 the bell is rung.
105 @end itemize
107 Changes/New Features in 5.2.5:
108 @itemize @bullet
109 @item @ESS{[R]}: @kbd{C-c C-q} or @samp{Quit S} from the menu now should work
110 (again and less klunkily) and do not append @samp{-exited} to the
111 buffer name.  Further, the behavior of @code{(ess-cleanup)}, called from
112 ess-quit, now depends on the new customizable variable
113 @code{ess-S-quit-kill-buffers-p} which defaults to @code{nil}.
114 Consequently, the question @emph{``Delete all buffers associated
115 with ..?''} will not be asked anymore by default.
116 @item @ESS{[SAS]} -- ess-ebcdic-to-ascii-search-and-replace will now work
117 with the @code{recode} application as well which is available on many platforms
118 @item @ESS{[S]} (incl.@: R): Name completion for slots of S4 objects now works!
119 @end itemize
121 Changes/New Features in 5.2.4:
122 @itemize @bullet
123 @item The documentation now includes an overview of how to use the emacs
124 TAGS facility for S functions.  (The distribution also used to contain a
125 directory @file{etc/other/Tags} where a ~1990 version of @file{etags.c} was
126 distributed; this is no longer relevant and so has been deleted.)
127 @item @ESS{[SAS]} -- When you are working with EBCDIC files on an ASCII
128 platform, .log NOTEs may display as gibberish since the EBCDIC
129 characters are not converted to ASCII prior to their display.  So,
130 the function ess-ebcdic-to-ascii-search-and-replace is provided for
131 convenience and is bound to @kbd{C-F11}.  This function requires the
132 @code{dd} command (only available on unix or unix-like platforms).
133 @item ESS: Completion of object names is now always done dynamically rather
134 than allowing the option of using a pre-computed database (by
135 @code{ess-create-object-name-db}) since modern computers seem fast
136 enough for dynamic completion.  (We expect few users, if any, have
137 been using the pre-computed database method.)
138 @item ESS: object completion in iESS buffers running on Windows was
139 very slow (for GNU Emacs, but not XEmacs) and has now been fixed.
140 Further, it was more or less broken for all versions of S-plus 6.x,
141 and has been fixed to work everywhere but with the Windows' GUI of
142 S-plus.  The list of objects now shows unique names also when an
143 object appears more than once in the search path.
144 @item @ESS{[R]}: Completion of object names now also includes those
145 starting with ``.''.
146 @end itemize
148 Changes/New Features in 5.2.3:
149 @itemize @bullet
150 @item ESS: When new inferior ESS processes are created, by default they
151 will replace the current buffer (this restores behavior from pre
152 5.2.0). If you wish new ESS processes to start in another window of the
153 current frame, set inferior-ess-same-window to nil.
154 @item New variables inferior-Splus-args and inferior-R-args provide a
155 way to pass command line arguments to starting S and R processes.
156 @end itemize
158 Changes/New Features in 5.2.2:
159 @itemize @bullet
160 @item bug-fixes for 5.2.1 (require 'executable), html docs, etc.
161 @item ess-lisp-directory/../doc/info added to Info-directory-list
162 if ess-info not found by info
163 @item @ESS{[R]}: If you have other versions of R on your
164 exec-path, such as "R-1.8.1" with Unix or "rw1081" with Windows,
165 ESS will find them and create appropriate functions, such as
166 @kbd{M-x R-1.8.1} or @kbd{M-x rw1081}, for calling them.
167 By default only Unix programs beginning "R-1" and
168 "R-2" and Windows programs parallel to the
169 version of R in your exec-path will be found,
170 but see ess-r-versions and ess-rterm-versions for ways to find other
171 versions of R.
172 @item @ESS{[R]}: Other versions of R, such as "R-1.8.1" on Unix and "rw1081" on
173 Windows, are added to the
174 "ESS / Start Process / Other" menu.
175 @item @ESS{[S]}: If you have other versions of S-Plus on your Windows computer,
176 such as S-Plus 6.1 or S-Plus 4.5, ESS will find them and create appropriate
177 functions, such as @kbd{M-x splus61}, for calling the console version (Sqpe)
178 inside an emacs buffer.  By default only
179 programs installed in the default location will be found, but see
180 ess-SHOME-versions for ways to find other versions of S-Plus.
181 @item @ESS{[S]}: Other versions of Sqpe on Windows, such as "splus61",
182 are added to the
183 "ESS / Start Process / Other" menu.
184 @item @ESS{[R]}: (bug fix) ess-quit (bound to @kbd{C-c C-q}) should now quit the
185 inferior R process, when issued from either the inferior buffer, or from
186 a .R buffer.
187 @end itemize
189 Changes/New Features in 5.2.1:
190 @itemize @bullet
191 @item @ESS{[S]} (R and S-plus): now have toolbar support
192 with icons to evaluate code in the inferior process or to switch
193 there.  This code is experimental and likely to change as XEmacs/Emacs
194 issues get resolved. The toolbar should be enabled if your Emacs
195 displays images, but can be disabled with the variable ess-use-toolbar.
196 Thanks to David Smith from Insightful for the S-plus logo.
197 @item @ESS{[SAS]}: ess-sas-graph-view (@kbd{F12}) enhanced; you can specify
198 external file viewers for each graphics file type via the alist
199 ess-sas-graph-view-viewer-alist; also .jpg/.gif are now handled
200 by image-mode on XEmacs, if available, otherwise by graphics
201 primitives as before
202 @end itemize
204 Changes/New Features in 5.2.0:
205 @itemize @bullet
206 @item @ESS{[BUGS]}:  new info documentation!  now supports interactive
207 processing thanks to @uref{mailto:Aki.Vehtari@@hut.fi, Aki Vehtari};
208 new architecture-independent unix support as well as support for BUGS v. 0.5
209 @item @ESS{[SAS]}:  convert .log to .sas with ess-sas-transcript;
210 info documentation improved; Local Variable bug fixes;
211 SAS/IML statements/functions now highlighted; files edited
212 remotely by ange-ftp/EFS/tramp are recognized and pressing
213 SUBMIT opens a buffer on the remote host via the local variable
214 ess-sas-shell-buffer-remote-init which defaults to "ssh";
215 changed the definition of the variable ess-sas-edit-keys-toggle
216 to boolean rather than 0/1; added the function ess-electric-run-semicolon
217 which automatically reverse indents lines containing only "run;";
218 @kbd{C-F1} creates MS RTF portrait from the current buffer;
219 @kbd{C-F2} creates MS RTF landscape from the current buffer;
220 @kbd{C-F9} opens a SAS DATASET with PROC INSIGHT rather than PROC FSVIEW;
221 "inferior" aliases for SAS batch:  @kbd{C-c C-r} for submit region,
222 @kbd{C-c C-b} for submit buffer, @kbd{C-c C-x} for goto .log; @kbd{C-c C-y} for goto .lst
223 @item @ESS{[S]}: Pressing underscore ("_") once inserts " <- " (as before);
224 pressing underscore twice inserts a literal underscore.  To stop this
225 smart behaviour, add "(ess-toggle-underscore nil)" to your .emacs after
226 ess-site has been loaded;
227 ess-dump-filename-template-proto (new name!) now can be
228 customized successfully (for S language dialects);
229 Support for Imenu has been improved; set ess-imenu-use-S to non-nil to
230 get an "Imenu-S" item on your menubar;
231 ess-help: Now using nice underlines (instead of `nuke-* ^H_')
232 @item @ESS{[R]}:  After (require 'essa-r), @kbd{M-x ess-r-var} allows to load
233 numbers from any Emacs buffer into an existing *R* process;
234 @kbd{M-x ess-rdired} gives a ``directory editor'' of R objects;
235 fixed ess-retr-lastvalue-command, i.e. .Last.value bug
236 (thanks to David Brahm)
237 @item ESS: Support for creating new window frames has been added to
238 ESS.  Inferior ESS processes can be created in dedicated frames by
239 setting inferior-ess-own-frame to t.  ESS help buffers can also open in
240 new frames; see the documentation for ess-help-own-frame for details.
241 (Thanks to Kevin Rodgers for contributing code.)
242 @end itemize
244 Changes/New Features in 5.1.24:
245 @itemize @bullet
246 @item The version number is now correct even inside ESS/Emacs
247 @end itemize
249 Changes/New Features in 5.1.23:
250 @itemize @bullet
251 @item Minor more Makefile clean up.
252 @end itemize
254 Changes/New Features in 5.1.22:
255 @itemize @bullet
256 @item Besides info documentation, PDF and HTML
257 documentation are also provided (instead of built using "make") and available
258 on the web as well; see @uref{http://ess.r-project.org/,
259  ESS web page} and @uref{http://lib.stat.cmu.edu/general/ESS/doc, StatLib}
260 @item Now that info documentation is available, the
261 README.* files are no longer supported.  However, they
262 are still distributed for what it's worth.
263 @item ESS is now an XEmacs package!  See
264 @uref{http://www.xemacs.org/Install/index.html, XEmacs Installation HOWTO}
265 for details (specifically, items 10-15).
266 @item @ESS{[SAS]}: more user-friendly enhancements for remote
267 SAS batch jobs with Kermit file transfers (LOG and OUTPUT
268 function key features now supported).  Multiple shells
269 now supported so you can run SAS on different computers
270 from different buffers by setting the buffer-local variable
271 ess-sas-shell-buffer to unique buffer names.
272 @item Major re-vamping of Makefile/Makeconf.
273 @end itemize
275 Changes/New Features in 5.1.21:
276 @itemize @bullet
277 @item @ESS{[SAS]}: info documentation now available!, see
278 ESS->Help for SAS; @kbd{F12} opens GSASFILE nearest point for viewing
279 either within emacs, when available, or via an external viewer;
280 more syntax highlighting keywords; more enhancements for remote
281 SAS batch jobs with Kermit; new framework for remote SAS interactive
282 jobs, see ess-remote
283 @item @ESS{[S]}: info documentation now available!, see
284 ESS->Help for the S family
285 @item Makefile: tag now independent of rel; info files
286 made by doc/Makefile and installed in new info sub-directory
287 @end itemize
289 Changes/New Features in 5.1.20:
290 @itemize @bullet
291 @item New `options()$STERM' in the S dialects (S, S-Plus, R).
292 The S program can determine the environment in which it is
293 currently running.  ESS sets the option to `iESS' or `ddeESS'
294 when it starts an S language process.  We recommend other specific
295 values for S language processes that ESS does not start.
296 @item New `ess-mouse-me' function, assigned to S-mouse-3 by default.
297 User may click on a word or region and then choose from the
298 menu to display the item, or a summary, or a plot, etc.
299 This feature is still under development.
300 @item GNU Emacs 21.1 is now supported (fixed for S dialects, SAS & BUGS),
301 (some from Stephen Eglen).
302 @item XEmacs 21.x is now supported (fixed w32-using-nt bug)
303 @item XEmacs on Win (NT) is better supported.
304 @item Workaround for bug in Sqpe+6 (S-PLUS 6 for Win).
305 @item should now work even when imenu is not available (for old XEmacsen).
306 @item @ESS{[SAS]}: XEmacs-Imenu fix; @kbd{C-TAB} is globalized along with your
307 function-key definitions, if specified; you can specify your SAS
308 library definitions outside of autoexec.sas for ess-sas-data-view
309 with SAS code placed in the variable ess-sas-data-view-libname,
310 also the dataset name is defaulted to the nearest permanent dataset
311 to point; Speedbar support now works for permanent datasets, please
312 ignore first./last.; new font-locking is now the default with more
313 improvements for font-locking PROCs, macro statements, * ; and %* ;
314 comments; you can toggle sas-log-mode with @kbd{F10} which will font-lock
315 your .log (if it isn't too big); submit remote .sas files accessed
316 with ange-ftp, EFS or Tramp (Kermit is experimental) by setting
317 ess-sas-submit-method to 'sh; ess-sas-submit-command and
318 ess-sas-submit-command-options are buffer-local so you can have
319 local file variable sections at the end of your .sas files to
320 request different executables or specify special options and the
321 local file variables are re-read at submit instead of only at file
322 open so that if you make a change it is picked up immediately;
323 @item @ESS{[BUGS]}: font-lock with `in' fixed.
324 @item for STATA: font-lock bug fixed.
325 @item for Rd mode: @kbd{C-c C-v} and `switch-process' in menu.
326 further, @kbd{C-c C-f} prefix (Rd-font) for inserting or surrounding a word
327 by things such as \code@{.@}, \code@{\link@{.@}@}, \emph@{.@} etc.
328 @item new functions (ess-directory-function) and (ess-narrow-to-defun)
329 ess-directory <-> default-directory logic (Jeff Mincy).
330 @item Re-organized Makefile and fixed a few bugs.
331 @end itemize
333 Changes/New Features in 5.1.19:
334 @itemize @bullet
335 @item S+6 now supported (Tony Rossini (Unix) and Rich Heiberger (Windows))
336 @item New BUGS support through @ESS{[BUGS]} mode (Rodney Sparapani)
337 Templates assist you in writing .bug and .cmd code (.cmd and .log
338 are replaced by .bmd and .bog to avoid emacs extension collisions).
339 Substitution" parameters facilitate "automagic" generation of
340 data...in" and "init...in" filenames, "const N=" from your data
341 file and "monitor()/stats()" commands.  Activated by pressing @kbd{F12}.
342 @item Fixes for `ess-smart-underscore' SAS breakage (Rich Heiberger)
343 @item You can change between PC and Unix, local and global SAS function-key
344 definitions interactively (Rich Heiberger)
345 @item @kbd{C-Submit} a highlighted region to SAS batch (Rodney Sparapani)
346 @item New and improved SAS syntax highlighting (Rodney Sparapani)
347 To get the new functionality, set ess-sas-run-make-regexp to nil.
348 Also available in .log files via @kbd{F10}.
349 @item Open a permanent SAS dataset for viewing via @kbd{F9} (Rodney Sparapani)
350 You must have the library defined in autoexec.sas for it to work.
351 @item User-friendly defaults for `sas-program', `ess-sas-batch-pre-command'
352 and `ess-sas-batch-post-command' as well Customize support for these
353 and other @ESS{[SAS]} variables (Rodney Sparapani)
354 @item `ess-sas-suffix-2' now defaults to .dat via @kbd{F11} (Rodney Sparapani)
355 @item Emacs/XEmacs, Unix/Windows issues collectively handled in ess-emcs.el
356 @item defadvice solves problem of missing *ESS* (thanks to Jeff Mincy)
357 @item Improved manual a bit by including things that were only in `README'.
358 @end itemize
360 Changes/New Features in 5.1.18:
361 @itemize @bullet
362 @item New `ess-smart-underscore' function, now assigned to "_" by default.
363 Inserts `ess-S-assign' (customizable " <- "), unless inside string
364 and comments where plain "_" is used instead. (MM)
365 @item Fixes for longstanding interactive SAS breakage (RMH)
366 @end itemize
368 Changes/New Features in 5.1.17:
369 @itemize @bullet
370 @item Documentation for Windows Installation (Rich Heiberger)
371 @item removal of ess-vars, finalization of customize support (in the
372 sense that there is no more use of ess-vars, but that we need to
373 fix ess-cust) (AJ Rossini)
374 @item Many small (and large) fixes/contributions (MMaechler)
375 @item addition of the "S-equal" variable and provide @kbd{M-x ess-add-MM-keys}
376 a way to remap "_" to `ess-S-assign', typically " <- ", but
377 customizable. (MMaechler)
378 @end itemize
380 Changes/New Features in 5.1.16:
381 @itemize @bullet
382 @item BUG FIXES
383 @item Better SAS support
384 @end itemize
386 Changes/New Features in 5.1.15:
387 @itemize @bullet
388 @item BUG FIXES
389 @end itemize
391 Changes/New Features in 5.1.14:
392 @itemize @bullet
393 @item Yet more fixes to SAS mode, (Rich Heiberger and Rodney Sparapani)
394 @item Customize support (for most Emacsen which support it) (AJRossini)
395 @item ARC and ViSta support out of the box, and fixes for XLispStat (AJRossini)
396 @end itemize
398 Changes/New Features in 5.1.13:
399 @itemize @bullet
400 @item Version numbering finally all depending on the ./VERSION file,
401 thanks to Martin Maechler.
402 @item Yet more fixes to SAS mode, thanks to Rich Heiberger.
403 @end itemize
405 Changes/New Features in 5.1.12:
406 @itemize @bullet
407 @item Splus 5.1 stabilized, thanks to Martin Maechler, Bill Venables,
408 Chuck Taylor, and others.
409 @item More fixes to SAS mode, thanks to Rodney Sparapani
410 and Rich Heiberger.
411 @end itemize
413 Changes/New Features in 5.1.11:
414 @itemize @bullet
415 @item More fixes to Stata mode, thanks to
416 @uref{mailto:brendan@@essex.ac.uk, Brendan Halpin}.
417 @item fixed bugs in ESS-elsewhere, thanks to many testers
418 @item README.SPLUS4WIN has DETAILED instructions for S-PLUS 2000, thanks
419 to @uref{mailto:brahm@@alum.mit.edu, David Brahm}.
420 @item Fixes to SAS mode, thanks to Rodney Sparapani
421 @end itemize
423 Changes/New Features in 5.1.10:
424 @itemize @bullet
425 @item More fixes to Stata mode
426 @item primitive generic version of ESS-elsewhere
427 @item Small fixes to SAS/Stata.
428 @end itemize
430 Changes/New Features in 5.1.9:
431 @itemize @bullet
432 @item Stata mode works
433 @item Literate Data Analysis using Noweb works
434 @end itemize
436 Changes/New Features in 5.1.8:
437 @itemize @bullet
438 @item Bug fixes
439 @item R documentation mode defaults changed
440 @end itemize
442 Changes/New Features in 5.1.2:
443 @itemize @bullet
444 @item  able to use inferior iESS mode to
445 communicate directly with a running S-Plus 4.x process using the
446 Microsoft DDE protocol.  We use the familiar (from Unix ESS) @kbd{C-c C-n}
447 and related key sequences to send lines from the S-mode file to the
448 inferior S process.  We continue to edit S input files in @ESS{[S]} mode
449 and transcripts of previous S sessions in ESS Transcript mode.  All
450 three modes know the S language, syntax, and indentation patterns and
451 provide the syntactic highlighting that eases the programming tasks.
452 @end itemize