This blog is updated daily.
A general description is here.
‘checkRd()’ gave a spurious error if the ‘\href’ macro was used.
The graphical dialog version of ‘select.list()’ could cause later dialogs to fail if Windows events were not processed between the calls.
Non-ascii characters in the titles of help pages were not rendered properly in some locales, and could cause errors or warnings.
Complex arithmetic (notably ‘z^n’ for complex ‘z’ and integer ‘n’) gave incorrect results since R 2.10.0 on platforms without C99 complex support. This and some lesser issues in trignometric functions have been corrected.
Such platforms were rare (we know of Cygwin and FreeBSD). However, because of new compiler optimizations in the way complex arguments are handled, the same code was selected on x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
There is a workaround for crashes seen with several packages on systems using ‘zlib 1.2.5’: see the INSTALLATION section.
PCRE has been updated to 8.12 (two bug-fix releases since 8.10).
‘rep()’, ‘seq()’, ‘seq.int()’ and ‘seq_len()’ report more often when the first element is taken of an argument of incorrect length.
The Cocoa back-end for the ‘quartz()’ graphics device on Mac OS X provides a way to disable event loop processing temporarily (useful, e.g., for forked instances of R).
‘kernel()’'s default for ‘m’ was not appropriate if ‘coef’ was a set of coefficients. (Reported by Pierre Chausse.)
‘bug.report()’ has been updated for the current R bug tracker, which does not accept emailed submissions.
‘R CMD check’ now checks for the correct use of ‘$(LAPACK_LIBS)’ (as well as ‘$(BLAS_LIBS)’), since several CRAN recent submissions have ignored ‘Writing R Extensions’.
The ‘zlib’ sources in the distribution are now built with all symbols remapped: this is intended to avoid problems seen with packages such as ‘XML’ and ‘rggobi’ which link to ‘zlib.so.1’ on systems using ‘zlib 1.2.5’.
The default for ‘FFLAGS’ and ‘FCFLAGS’ with ‘gfortran’ on x86_64 Linux has been changed back to ‘-g -O2’: however, setting ‘-g -O’ may still be needed for ‘gfortran 4.3.x’.
A ‘LazyDataCompression’ field in the ‘DESCRIPTION’ file will be used to set the value for the ‘--data-compress’ option of ‘R CMD INSTALL’.
Files ‘R/sysdata.rda’ of more than 1Mb are now stored in the lazyload database using ‘xz’ compression: this for example halves the installed size of package ‘Imap’.
‘R CMD INSTALL’ now ensures that directories installed from ‘inst’ have search permission for everyone.
It no longer installs files ‘inst/doc/Rplots.ps’ and ‘inst/doc/Rplots.pdf’. These are almost certainly left-overs from ‘Sweave’ runs, and are often large.
The ‘experimental’ alternative specification of a name space via ‘.Export()’ etc is now deprecated.
‘zip.file.extract()’ is now deprecated.
Zip-ing data sets in packages (and hence ‘R CMD INSTALL --use-zip-data’ and the ‘ZipData: yes’ field in a ‘DESCRIPTION’ file) is deprecated: using efficiently compressed ‘.rda’ images and lazy-loading of data has superseded it.
‘identical()’ could in rare cases generate a warning about non-pairlist attributes on CHARSXPs. As these are used for internal purposes, the attribute check should be skipped. (Reported by Niels Richard Hansen).
If the filename extension (usually ‘.Rnw’) was not included in a call to ‘Sweave()’, source references would not work properly and the ‘keep.source’ option failed. (PR#14459)
‘format.data.frame()’ now keeps zero character column names.
‘pretty(x)’ no longer raises an error when ‘x’ contains solely non-finite values. (PR#14468)
The ‘plot.TukeyHSD()’ function now uses a line width of 0.5 for its reference lines rather than ‘lwd = 0’ (which caused problems for some PDF and PostScript viewers).
The ‘big.mark’ argument to ‘prettyNum()’, ‘format()’, etc. was inserted reversed if it was more than one character long.
‘R CMD check’ failed to check the filenames under ‘man’ for Windows' reserved names.
The ‘"Date"’ and ‘"POSIXt"’ methods for ‘seq()’ could overshoot when ‘to’ was supplied and ‘by’ was specified in months or years.
The internal method of ‘untar()’ now restores hard links as file copies rather than symbolic links (which did not work for cross-directory links).
‘unzip()’ did not handle zip files which contained filepaths with two or more leading directories which were not in the zipfile and did not already exist. (It is unclear if such zipfiles are valid and the third-party C code used did not support them, but PR#14462 created one.)
‘combn(n, m)’ now behaves more regularly for the border case m = 0. (PR#14473)
The rendering of numbers in plotmath expressions (e.g. ‘expression(10^2)’) used the current settings for conversion to strings rather than setting the defaults, and so could be affected by what has been done before. (PR#14477)
The methods of ‘napredict()’ and ‘naresid()’ for ‘na.action = na.exclude’ fits did not work correctly in the very rare event that every case had been omitted in the fit. (Reported by Simon Wood.)
‘weighted.residuals(drop0=TRUE)’ returned a vector when the residuals were a matrix (e.g. those of class ‘"mlm"’). (Reported by Bill Dunlap.)
Package HTML index files ‘<pkg>/html/00Index.html’ were generated with a stylesheet reference that was not correct for static browsing in libraries.
‘ccf(na.action = na.pass)’ was not implemented.
The parser accepted some incorrect numeric constants, e.g. ‘20x2’. (Reported by Olaf Mersmann.)
‘format(*, zero.print)’ did not always replace the full zero parts.
Fixes for subsetting or subassignment of ‘"raster"’ objects when not both ‘i’ and ‘j’ are specified.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a ‘DESCRIPTION’ file (although this is frequently incorrectly specified for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
‘source(file, echo=TRUE)’ could fail if the file contained ‘#line’ directives. It now recovers more gracefully, but may still display the wrong line if the directive gives incorrect information.
‘atan(1i)’ returned ‘NaN+Infi’ (rather than ‘0+Infi’) on platforms without C99 complex support.
‘library()’ failed to cache S4 metadata (unlike ‘loadNamespace()’) causing failures in S4-using packages without a namespace (e.g. those using reference classes).
The function ‘qlogis(lp, log.p=TRUE)’ no longer prematurely overflows to ‘Inf’ when exp(lp) is close to 1.
Updating S4 methods for a group generic function requires resetting the methods tables for the members of the group (patch contributed by Martin Morgan).
In some circumstances (including for package ‘XML’), ‘R CMD INSTALL’ installed version-control directories from source packages.
Added ‘PROTECT’ calls to some constructed expressions used in C level ‘eval’ calls.
‘utils:::create.post()’ (used by ‘bug.report()’ and ‘help.request()’) failed to quote arguments to the mailer, and so often failed.
‘bug.report()’ was naive about how to extract maintainer email addresses from package descriptions, so would often try mailing to incorrect addresses.
‘debugger()’ could fail to read the environment of a call to a function with a ‘...’ argument. (Reported by Charlie Roosen.)
‘prettyNum(c(1i, NA), drop0=TRUE)’ or ‘str(NA_complex_)’ now work correctly.
The DVI/PDF reference manual now includes the help pages for all the standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously omitted (intentionally).
<URL: http://www.rforge.net> has been added to the default set of repositories known to ‘setRepositories()’.
xz-utils has been updated to version 5.0.0.
‘reshape()’ now makes use of ‘sep’ when forming names during reshaping to wide format. (PR#14435)
‘legend()’ allows the length of lines to be set by the end user _via_ the new argument ‘seg.len’.
New S4 reference class utility methods ‘copy()’, ‘field()’, ‘getRefClass()’ and ‘getClass()’ have been added to package ‘methods’.
When a character value is used for the ‘EXPR’ argument in ‘switch()’, a warning is given if more than one unnamed alternative value is given. This will become an error in R 2.13.0.
‘StructTS(type = "BSM")’ now allows series with just two seasons. (Reported by Birgit Erni.)
The PDF reference manual is now built as PDF version 1.5 with object compression, which on platforms for which this is not the default (notably MiKTeX) halves its size.
Variable ‘FCLIBS’ can be set during configuration, for any additional library flags needed when linking a shared object with the Fortran 9x compiler. (Needed with Solaris Studio 12.2.)
‘seq.int()’ no longer sometimes evaluates arguments twice. (PR#14388)
The ‘data.frame’ method of ‘format()’ failed if a column name was longer than 256 bytes (the maximum length allowed for an R name).
‘predict(<lm object>, type ="terms", ...)’ failed if both ‘terms’ and ‘interval’ were specified. (Reported by Bill Dunlap.)
Also, if ‘se.fit = TRUE’ the standard errors were reported for all terms, not just those selected by a non-null ‘terms’.
The TRE regular expressions engine could terminate R rather than give an error when given certain invalid regular expressions. (PR#14398)
‘cmdscale(eig = TRUE)’ was documented to return n-1 eigenvalues but in fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add = TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points. Its return value was described wrongly (it is always a list and contains component ‘ac’).
‘promptClass()’ in package ‘methods’ now works for reference classes and gives a suitably specialized skeleton of documentation.
Also, ‘callSuper()’ now works via the ‘methods()’ invocation as well as for initially specified methods.
‘download.file()’ could leave the destination file open if the URL was not able to be opened. (PR#14414)
Assignment of an environment to functions or as an attribute to other objects now works for S4 subclasses of ‘"environment"’.
Use of ‘[[<-’ for S4 subclasses of ‘"environment"’ generated an infinite recursion from the method. The method has been replaced by internal code.
In a reference class S4 method, ‘callSuper()’ now works in ‘initialize()’ methods when there is no explicit superclass method.
‘!’ dropped attributes such as names and dimensions from a length-zero argument. (PR#14424)
When ‘list2env()’ created an environment it was missing a ‘PROTECT’ call and so was vulnerable to garbage collection.
‘Sweave()’ with ‘keep.source=TRUE’ dropped comments at the start and end of code chunks. It could also fail when ‘\SweaveInput’ was combined with named chunks.
The Fortran code used by ‘nls(algorithm = "port")’ could infinite-loop when compiled with high optimization on a modern version of ‘gcc’, and ‘SAFE_FFLAGS’ is now used to make this less likely. (PR#14427, seen with 32-bit Windows using ‘gcc 4.5.0’ used from R 2.12.0.)
‘sapply()’ with default ‘simplify = TRUE’ and ‘mapply()’ with default ‘SIMPLIFY = TRUE’ wrongly simplified language-like results, as, e.g., in ‘mapply(1:2, c(3,7), FUN = function(i,j) call(':',i,j))’.
Backreferences to undefined patterns in ‘[g]sub(pcre = TRUE)’ could cause a segfault. (PR#14431)
The ‘format()’ (and hence the ‘print()’) method for class ‘"Date"’ rounded fractional dates towards zero: it now always rounds them down.
Reference S4 class creation could generate ambiguous inheritance patterns under very special circumstances.
‘[[<-’ turned S4 subclasses of ‘"environment"’ into plain environments.
Long titles for help pages were truncated in package indices and a few other places.
Additional utilities now work correctly with S4 subclasses of ‘"environment"’ (‘rm’, locking tools and active bindings).
‘spec.ar()’ now also work for the ‘"ols"’ method. (Reported by Hans-Ruedi Kuensch.)
The initialization of objects from S4 subclasses of ‘"environment"’ now allocates a new environment object.
‘R CMD check’ has more protection against (probably erroneous) example or test output which is invalid in the current locale.
‘qr.X()’ with column names and pivoting now also pivots the column names. (PR#14438)
‘unit.pmax()’ and ‘unit.pmin()’ in package ‘grid’ gave incorrect results when all inputs were of length 1. (PR#14443)
The parser for ‘NAMESPACE’ files ignored misspelled directives, rather than signalling an error. For 2.12.x a warning will be issued, but this will be correctly reported as an error in later releases. (Reported by Charles Berry.)
Fix for subsetting of ‘"raster"’ objects when only one of ‘i’ or ‘j’ is specified.
‘grid.raster()’ in package ‘grid’ did not accept ‘"nativeRaster"’ objects (like ‘rasterImage()’ does).
Rendering raster images in PDF output was resetting the clipping region.
Rendering of raster images on Cairo X11 device was wrong, particularly when a small image was being scaled up using interpolation.
With Cairo < 1.6, will be better than before, though still a little clunky. With Cairo >= 1.6, should be sweet as.
Several bugs fixed in ‘read.DIF()’: single column inputs caused errors, cells marked as ‘"character"’ could be converted to other types, and (in Windows) copying from the clipboard failed.
Reading a package's ‘CITATION’ file now defaults to ASCII rather than Latin-1: a package with a non-ASCII ‘CITATION’ file should declare an encoding in its ‘DESCRIPTION’ file and use that encoding for the ‘CITATION’ file.
‘difftime()’ now defaults to the ‘"tzone"’ attribute of ‘"POSIXlt"’ objects rather than to the current timezone as set by the default for the ‘tz’ argument. (Wish of PR#14182.)
‘pretty()’ is now generic, with new methods for ‘"Date"’ and ‘"POSIXt"’ classes (based on code contributed by Felix Andrews).
‘unique()’ and ‘match()’ are now faster on character vectors where all elements are in the global ‘CHARSXP’ cache and have unmarked encoding (ASCII). Thanks to Matthew Dowle for suggesting improvements to the way the hash code is generated in ‘unique.c’.
The ‘enquote()’ utility, in use internally, is exported now.
‘.C()’ and ‘.Fortran()’ now map non-zero return values (other than ‘NA_LOGICAL’) for logical vectors to ‘TRUE’: it has been an implicit assumption that they are treated as true.
The ‘print()’ methods for ‘"glm"’ and ‘"lm"’ objects now insert linebreaks in long calls in the same way that the ‘print()’ methods for ‘"summary.[g]lm"’ objects have long done. This does change the layout of the examples for a number of packages, e.g. ‘MASS’. (PR#14250)
‘constrOptim()’ can now be used with method ‘"SANN"’. (PR#14245)
It gains an argument ‘hessian’ to be passed to ‘optim()’, which allows all the ‘...’ arguments to be intended for ‘f()’ and ‘grad()’. (PR#14071)
‘curve()’ now allows ‘expr’ to be an object of mode ‘"expression"’ as well as ‘"call"’ and ‘"function"’.
The ‘"POSIX[cl]t"’ methods for ‘Axis()’ have been replaced by a single method for ‘"POSIXt"’.
There are no longer separate ‘plot()’ methods for ‘"POSIX[cl]t"’ and ‘"Date"’: the default method has been able to handle those classes for a long time. This _inter alia_ allows a single date-time object to be supplied, the wish of PR#14016.
The methods had a different default (‘""’) for ‘xlab’.
Classes ‘"POSIXct"’, ‘"POSIXlt"’ and ‘"difftime"’ have generators ‘.POSIXct()’, ‘.POSIXlt()’ and ‘.difftime()’. Package authors are advised to make use of them (they are available from R 2.11.0) to proof against planned future changes to the classes.
The ordering of the classes has been changed, so ‘"POSIXt"’ is now the second class. See the document ‘Updating packages for changes in R 2.12.x’ on <URL: http://developer.r-project.org> for the consequences for a handful of CRAN packages.
The ‘"POSIXct"’ method of ‘as.Date()’ allows a timezone to be specified (but still defaults to UTC).
New ‘list2env()’ utility function as an inverse of ‘as.list(<environment>)’ and for fast multi-‘assign()’ to existing environment. ‘as.environment()’ is now generic and uses ‘list2env()’ as list method.
There are several small changes to output which ‘zap’ small numbers, e.g. in printing quantiles of residuals in summaries from ‘"lm"’ and ‘"glm"’ fits, and in test statistics in ‘print.anova()’.
Special names such as ‘"dim"’, ‘"names"’, etc, are now allowed as slot names of S4 classes, with ‘"class"’ the only remaining exception.
File ‘.Renviron’ can have architecture-specific versions such as ‘.Renviron.i386’ on systems with sub-architectures.
‘installed.packages()’ has a new argument ‘subarch’ to filter on sub-architecture.
The ‘summary()’ method for ‘packageStatus()’ now has a separate ‘print()’ method.
The default ‘summary()’ method returns an object inheriting from class ‘"summaryDefault"’ which has a separate ‘print()’ method that calls ‘zapsmall()’ for numeric/complex values.
The startup message now includes the platform and if used, sub-architecture: this is useful where different (sub-)architectures run on the same OS.
The ‘getGraphicsEvent()’ mechanism now allows multiple windows to return graphics events, through the new functions ‘setGraphicsEventHandlers()’, ‘setGraphicsEventEnv()’, and ‘getGraphicsEventEnv()’. (Currently implemented in the ‘windows()’ and ‘X11()’ devices.)
‘tools::texi2dvi()’ gains an ‘index’ argument, mainly for use by ‘R CMD Rd2pdf’.
It avoids the use of ‘texindy’ by ‘texinfo’'s ‘texi2dvi >= 1.157’, since that does not emulate 'makeindex' well enough to avoid problems with special characters (such as ‘(’, ‘{’, ‘!’) in indices.
The ability of ‘readLines()’ and ‘scan()’ to re-encode inputs to marked UTF-8 strings on Windows since R 2.7.0 is extended to non-UTF-8 locales on other OSes.
‘scan()’ gains a ‘fileEncoding’ argument to match ‘read.table()’.
‘points()’ and ‘lines()’ gain ‘"table"’ methods to match ‘plot()’. (Wish of PR#10472.)
‘Sys.chmod()’ allows argument ‘mode’ to be a vector, recycled along ‘paths’.
There are ‘|’, ‘&’ and ‘xor()’ methods for classes ‘"octmode"’ and ‘"hexmode"’, which work bitwise.
Environment variables ‘R_DVIPSCMD’, ‘R_LATEXCMD’, ‘R_MAKEINDEXCMD’, ‘R_PDFLATEXCMD’ are no longer used nor set in an R session. (With the move to ‘tools::texi2dvi()’, the conventional environment variables ‘LATEX’, ‘MAKEINDEX’ and ‘PDFLATEX’ will be used. ‘options("dvipscmd")’ defaults to the value of ‘DVIPS’, then to ‘"dvips"’.)
New function ‘isatty()’ to see if terminal connections are redirected.
‘summaryRprof()’ returns the sampling interval in component ‘sample.interval’ and only returns in ‘by.self’ data for functions with non-zero self times.
‘print(x)’ and ‘str(x)’ now indicate if an empty list ‘x’ is named.
‘install.packages()’ and ‘remove.packages()’ with ‘lib’ unspecified and multiple libraries in ‘.libPaths()’ inform the user of the library location used with a message rather than a warning.
There is limited support for multiple compressed streams on a file: all of ‘[bgx]zfile()’ allow streams to be appended to an existing file, but ‘bzfile()’ reads only the first stream.
Function ‘person()’ in package ‘utils’ now uses a given/family scheme in preference to first/middle/last, is vectorized to handle an arbitrary number of persons, and gains a ‘role’ argument to specify person roles using a controlled vocabulary (the MARC relator terms).
Package ‘utils’ adds a new ‘"bibentry"’ class for representing and manipulating bibliographic information in enhanced BibTeX style, unifying and enhancing the previously existing mechanisms.
A ‘bibstyle()’ function has been added to the ‘tools’ package with default JSS style for rendering ‘"bibentry"’ objects, and a mechanism for registering other rendering styles.
Several aspects of the display of text help are now customizable using the new ‘Rd2txt_options()’ function. options(‘"help_text_width"’) is no longer used.
Added ‘\href’ tag to the Rd format, to allow hyperlinks to URLs without displaying the full URL.
Added ‘\newcommand’ and ‘\renewcommand’ tags to the Rd format, to allow user-defined macros.
New ‘toRd()’ generic in the ‘tools’ package to convert objects to fragments of Rd code, and added ‘"fragment"’ argument to ‘Rd2txt()’, ‘Rd2HTML()’, and ‘Rd2latex()’ to support it.
Directory ‘R_HOME/share/texmf’ now follows the TDS conventions, so can be set as a ‘texmf’ tree (‘root directory’ in MiKTeX parlance).
S3 generic functions now use correct S4 inheritance when dispatching on an S4 object. See ‘?Methods’, section on “Methods for S3 Generic Functions” for recommendations and details.
‘format.pval()’ gains a ‘...’ argument to pass arguments such as ‘nsmall’ to ‘format()’. (Wish of PR#9574)
‘legend()’ supports ‘title.adj’. (Wish of PR#13415)
Added support for subsetting ‘"raster"’ objects, plus assigning to a subset, conversion to a matrix (of colour strings), and comparisons (‘==’ and ‘!=’).
Added a new ‘parseLatex()’ function (and related functions ‘deparseLatex()’ and ‘latexToUtf8()’) to support conversion of bibliographic entries for display in R.
Text rendering of ‘\itemize’ in help uses a Unicode bullet in UTF-8 and most single-byte Windows locales.
Added support for polygons with holes to the graphics engine. This is implemented for the ‘pdf()’, ‘postscript()’, ‘x11(type="cairo")’, ‘windows()’, and ‘quartz()’ devices (and associated raster formats), but not for ‘x11(type="Xlib")’ or ‘xfig()’ or ‘pictex()’. The user-level interface is the ‘polypath()’ function in ‘graphics’ and ‘grid.path()’ in ‘grid’.
File ‘NEWS’ is now generated at installation with a slightly different format: it will be in UTF-8 on platforms using UTF-8, and otherwise in ASCII. There is also a PDF version, ‘NEWS.pdf’, installed at the top-level of the R distribution.
‘kmeans(x, 1)’ now works. Further, ‘kmeans’ now returns between and total sum of squares.
‘arrayInd()’ and ‘which()’ gain an argument ‘useNames’. For ‘arrayInd’, the default is now false, for speed reasons.
As is done for closures, the default ‘print’ method for the formula class now displays the associated environment if it is not the global environment.
A new facility has been added for inserting code into a package without re-installing it, to facilitate testing changes which can be selectively added and backed out. See ‘?insertSource’.
New function ‘readRenviron’ to (re-)read files in the format of ‘~/.Renviron’ and ‘Renviron.site’.
‘require()’ will now return ‘FALSE’ (and not fail) if loading the package or one of its dependencies fails.
‘aperm()’ now allows argument ‘perm’ to be a character vector when the array has named dimnames (as the results of ‘table()’ calls do). Similarly, ‘array()’ allows ‘MARGIN’ to be a character vector. (Based on suggestions of Michael Lachmann.)
Package ‘utils’ now exports and documents functions ‘aspell_package_Rd_files()’ and ‘aspell_package_vignettes()’ for spell checking package Rd files and vignettes using Aspell, Ispell or Hunspell.
Package news can now be given in Rd format, and ‘news()’ prefers these ‘inst/NEWS.Rd’ files to old-style plain text ‘NEWS’ or ‘inst/NEWS’ files.
New simple function ‘packageVersion()’.
The PCRE library has been updated to version 8.10.
The standard Unix-alike terminal interface declares its name to readline as 'R', so that can be used for conditional sections in ‘~/.inputrc’ files.
‘Writing R Extensions’ now stresses that the standard sections in ‘.Rd’ files (other than ‘\alias’, ‘\keyword’ and ‘\note’) are intended to be unique, and the conversion tools now drop duplicates with a warning.
The ‘.Rd’ conversion tools also warn about an unrecognized type in a ‘\docType’ section.
‘ecdf()’ objects now have a ‘quantile()’ method.
‘format()’ methods for date-time objects now attempt to make use of a ‘"tzone"’ attribute with ‘"%Z"’ and ‘"%z"’ formats, but it is not always possible. (Wish of PR#14358.)
‘tools::texi2dvi(file, clean = TRUE)’ now works in more cases (e.g. where emulation is used and when ‘file’ is not in the current directory).
New function ‘droplevels()’ to remove unused factor levels.
‘system(command, intern = TRUE)’ now gives an error on a Unix-alike (as well as on Windows) if ‘command’ cannot be run. It reports a non-success exit status from running ‘command’ as a warning.
On a Unix-alike an attempt is made to return the actual exit status of the command in ‘system(intern = FALSE)’: previously this had been system-dependent but on POSIX-compliant systems the value return was 256 times the status.
‘system()’ has a new argument ‘ignore.stdout’ which can be used to (portably) ignore standard output.
‘system(intern = TRUE)’ and ‘pipe()’ connections are guaranteed to be available on all builds of R.
‘Sys.which()’ has been altered to return ‘""’ if the command is not found (even on Solaris).
A facility for defining reference-based S4 classes (in the OOP style of Java, C++, etc.) has been added experimentally to package ‘methods’; see ‘?ReferenceClasses’.
The ‘predict’ method for ‘"loess"’ fits gains an ‘na.action’ argument which defaults to ‘na.pass’ rather than the previous default of ‘na.omit’.
Predictions from ‘"loess"’ fits are now named from the row names of ‘newdata’.
Parsing errors detected during ‘Sweave()’ processing will now be reported referencing their original location in the source file.
New ‘adjustcolor()’ utility, e.g., for simple translucent color schemes.
‘qr()’ now has a trivial ‘lm’ method with a simple (fast) validity check.
An experimental new programming model has been added to package ‘methods’ for reference (OOP-style) classes and methods. See ‘?ReferenceClasses’.
bzip2 has been updated to version 1.0.6 (bug-fix release). ‘--with-system-bzlib’ now requires at least version 1.0.6.
R now provides ‘jss.cls’ and ‘jss.bst’ (the class and bib style file for the Journal of Statistical Software) as well as ‘RJournal.bib’ and ‘Rnews.bib’, and ‘R CMD’ ensures that the ‘.bst’ and ‘.bib’ files are found by BibTeX.
Functions using the ‘TAR’ environment variable no longer quote the value when making ‘system’ calls. This allows values such as ‘tar --force-local’, but does require additional quotes in, e.g., ‘TAR = "'/path with spaces/mytar'"’.
Supplying the parser with a character string containing both octal/hex and Unicode escapes is now an error.
File extension ‘.C’ for C++ code files in packages is now defunct.
‘R CMD check’ no longer supports configuration files containing Perl configuration variables: use the environment variables documented in ‘R Internals’ instead.
The ‘save’ argument of ‘require()’ now defaults to ‘FALSE’ and ‘save = TRUE’ is now deprecated. (This facility is very rarely actually used, and was superseded by the ‘Depends’ field of the ‘DESCRIPTION’ file long ago.)
‘R CMD check --no-latex’ is deprecated in favour of ‘--no-manual’.
‘R CMD Sd2Rd’ is formally deprecated and will be removed in R 2.13.0.
‘install.packages()’ has a new argument ‘libs_only’ to optionally pass ‘--libs-only’ to ‘R CMD INSTALL’ and works analogously for Windows binary installs (to add support for 64- or 32-bit Windows).
When sub-architectures are in use, the installed architectures are recorded in the ‘Archs’ field of the ‘DESCRIPTION’ file. There is a new default filter, ‘"subarch"’, in ‘available.packages()’ to make use of this.
Code is compiled in a copy of the ‘src’ directory when a package is installed for more than one sub-architecture: this avoid problems with cleaning the sources between building sub-architectures.
‘R CMD INSTALL --libs-only’ no longer overrides the setting of locking, so a previous version of the package will be restored unless ‘--no-lock’ is specified.
‘R CMD Rprof|build|check’ are now based on R rather than Perl scripts. The only remaining Perl scripts are the deprecated ‘R CMD Sd2Rd’ and ‘install-info.pl’ (used only if ‘install-info’ is not found) as well as some maintainer-mode-only scripts.
*NB:* because these have been completely rewritten, users should not expect undocumented details of previous implementations to have been duplicated.
‘R CMD’ no longer manipulates the environment variables ‘PERL5LIB’ and ‘PERLLIB’.
‘R CMD check’ has a new argument ‘--extra-arch’ to confine tests to those needed to check an additional sub-architecture.
Its check for “Subdirectory 'inst' contains no files” is more thorough: it looks for files, and warns if there are only empty directories.
Environment variables such as ‘R_LIBS’ and those used for customization can be set for the duration of checking _via_ a file ‘~/.R/check.Renviron’ (in the format used by ‘.Renviron’, and with sub-architecture specific versions such as ‘~/.R/check.Renviron.i386’ taking precedence).
There are new options ‘--multiarch’ to check the package under all of the installed sub-architectures and ‘--no-multiarch’ to confine checking to the sub-architecture under which ‘check’ is invoked. If neither option is supplied, a test is done of installed sub-architectures and all those which can be run on the current OS are used.
Unless multiple sub-architectures are selected, the install done by ‘check’ for testing purposes is only of the current sub-architecture (_via_ ‘R CMD INSTALL --no-multiarch’).
It will skip the check for non-ascii characters in code or data if the environment variables ‘_R_CHECK_ASCII_CODE_’ or ‘_R_CHECK_ASCII_DATA_’ are respectively set to ‘FALSE’. (Suggestion of Vince Carey.)
‘R CMD build’ no longer creates an ‘INDEX’ file (‘R CMD INSTALL’ does so), and ‘--force’ removes (rather than overwrites) an existing ‘INDEX’ file.
It supports a file ‘~/.R/build.Renviron’ analogously to ‘check’.
It now runs build-time ‘\Sexpr’ expressions in help files.
‘R CMD Rd2dvi’ makes use of ‘tools::texi2dvi()’ to process the package manual. It is now implemented entirely in R (rather than partially as a shell script).
‘R CMD Rprof’ now uses ‘utils::summaryRprof()’ rather than Perl. It has new arguments to select one of the tables and to limit the number of entries printed.
‘R CMD Sweave’ now runs R with ‘--vanilla’ so the environment setting of ‘R_LIBS’ will always be used.
‘lang5()’ and ‘lang6()’ (in addition to pre-existing ‘lang[1-4]()’) convenience functions for easier construction of ‘eval()’ calls. If you have your own definition, do wrap it inside ‘#ifndef lang5 .... #endif’ to keep it working with old and new R.
Header ‘R.h’ now includes only the C headers it itself needs, hence no longer includes ‘errno.h’. (This helps avoid problems when it is included from C++ source files.)
Headers ‘Rinternals.h’ and ‘R_ext/Print.h’ include the C++ versions of ‘stdio.h’ and ‘stdarg.h’ respectively if included from a C++ source file.
A C99 compiler is now required, and more C99 language features will be used in the R sources.
Tcl/Tk >= 8.4 is now required (increased from 8.3).
System functions ‘access’, ‘chdir’ and ‘getcwd’ are now essential to configure R. (In practice they have been required for some time.)
‘make check’ compares the output of the examples from several of the base packages to reference output rather than the previous output (if any). Expect some differences due to differences in floating-point computations between platforms.
File ‘NEWS’ is no longer in the sources, but generated as part of the installation. The primary source for changes is now ‘doc/NEWS.Rd’.
The ‘popen’ system call is now required to build R. This ensures the availability of ‘system(intern = TRUE)’, ‘pipe()’ connections and printing from ‘postscript()’.
The ‘pkg-config’ file ‘libR.pc’ now also works when R is installed using a sub-architecture.
R has always required a BLAS that conforms to IE60559 arithmetic, but after discovery of more real-world problems caused by a BLAS that did not, this is tested more thoroughly in this version.
Calls to ‘selectMethod()’ by default no longer cache inherited methods. This could previously corrupt methods used by ‘as()’.
The densities of non-central chi-squared are now more accurate in some cases in the extreme tails, e.g. ‘dchisq(2000, 2, 1000)’, as a series expansion was truncated too early. (PR#14105)
‘pt()’ is more accurate in the left tail for ‘ncp’ large, e.g. ‘pt(-1000, 3, 200)’. (PR#14069)
The default C function (‘R_binary’) for binary ops now sets the S4 bit in the result if either argument is an S4 object. (PR#13209)
‘source(echo=TRUE)’ failed to echo comments that followed the last statement in a file.
S4 classes that contained one of ‘"matrix"’, ‘"array"’ or ‘"ts"’ and also another class now accept superclass objects in ‘new()’. Also fixes failure to call ‘validObject()’ for these classes.
Conditional inheritance defined by argument ‘test’ in ‘methods::setIs()’ will no longer be used in S4 method selection (caching these methods could give incorrect results). See ‘?setIs’.
The signature of an implicit generic is now used by ‘setGeneric()’ when that does not use a definition nor explicitly set a signature.
A bug in ‘callNextMethod()’ for some examples with ‘"..."’ in the arguments has been fixed. See file ‘src/library/methods/tests/nextWithDots.R’ in the sources.
‘match(x, table)’ (and hence ‘%in%’) now treat ‘"POSIXlt"’ consistently with, e.g., ‘"POSIXct"’.
Built-in code dealing with environments (‘get()’, ‘assign()’, ‘parent.env()’, ‘is.environment()’ and others) now behave consistently to recognize S4 subclasses; ‘is.name()’ also recognizes subclasses.
The ‘abs.tol’ control parameter to ‘nlminb()’ now defaults to ‘0.0’ to avoid false declarations of convergence in objective functions that may go negative.
The standard Unix-alike termination dialog to ask whether to save the workspace takes a EOF response as ‘n’ to avoid problems with a damaged terminal connection. (PR#14332)
Added ‘warn.unused’ argument to ‘hist.default()’ to allow suppression of spurious warnings about graphical parameters used with ‘plot=FALSE’. (PR#14341)
‘predict.lm()’, ‘summary.lm()’, and indeed ‘lm()’ itself had issues with residual DF in zero-weighted cases (the latter two only in connection with empty models). (Thanks to Bill Dunlap for spotting the ‘predict()’ case.)
‘aperm()’ treated ‘resize = NA’ as ‘resize = TRUE’.
‘constrOptim()’ now has an improved convergence criterion, notably for cases where the minimum was (very close to) zero; further, other tweaks inspired from code proposals by Ravi Varadhan.
Rendering of S3 and S4 methods in man pages has been corrected and made consistent across output formats.
Simple markup is now allowed in ‘\title’ sections in ‘.Rd’ files.
The behaviour of ‘as.logical()’ on factors (to use the levels) was lost in R 2.6.0 and has been restored.
‘prompt()’ did not backquote some default arguments in the ‘\usage’ section. (Reported by Claudia Beleites.)
‘writeBin()’ disallows attempts to write 2GB or more in a single call. (PR#14362)
‘new()’ and ‘getClass()’ will now work if Class is a subclass of ‘"classRepresentation"’ and should also be faster in typical calls.
The ‘summary()’ method for data frames makes a better job of names containing characters invalid in the current locale.
‘[[’ sub-assignment for factors could create an invalid factor (reported by Bill Dunlap).
‘Negate(f)’ would not evaluate argument ‘f’ until first use of returned function (reported by Olaf Mersmann).
‘quietly=FALSE’ is now also an optional argument of ‘library()’, and consequently, ‘quietly’ is now propagated also for loading dependent packages, e.g., in ‘require(*, quietly=TRUE)’.
If the loop variable in a ‘for’ loop was deleted, it would be recreated as a global variable. (Reported by Radford Neal; the fix includes his optimizations as well.)
Task callbacks could report the wrong expression when the task involved parsing new code. (PR#14368)
‘getNamespaceVersion()’ failed; this was an accidental change in 2.11.0. (PR#14374)
‘identical()’ returned ‘FALSE’ for external pointer objects even when the pointer addresses were the same.
‘L$a@x[] <- val’ did not duplicate in a case it should have.
‘tempfile()’ now always gives a random file name (even if the directory is specified) when called directly after startup and before the R RNG had been used. (PR#14381)
‘quantile(type=6)’ behaved inconsistently. (PR#14383)
‘backSpline(.)’ behaved incorrectly when the knot sequence was decreasing. (PR#14386)
The reference BLAS included in R was assuming that ‘0*x’ and ‘x*0’ were always zero (whereas they could be ‘NA’ or ‘NaN’ in IEC 60559 arithmetic). This was seen in results from ‘tcrossprod’, and for example that ‘log(0) %*% 0’ gave ‘0’.
The calculation of whether text was completely outside the device region (in which case, you draw nothing) was wrong for screen devices (which have [0, 0] at top-left). The symptom was (long) text disappearing when resizing a screen window (to make it smaller). (PR#14391)
‘model.frame(drop.unused.levels = TRUE)’ did not take into account ‘NA’ values of factors when deciding to drop levels. (PR#14393)
‘library.dynam.unload’ required an absolute path for ‘libpath’. (PR#14385)
Both ‘library()’ and ‘loadNamespace()’ now record absolute paths for use by ‘searchpaths()’ and ‘getNamespaceInfo(ns, "path")’.
The self-starting model ‘NLSstClosestX’ failed if some deviation was exactly zero. (PR#14384)
‘X11(type = "cairo")’ (and other devices such as ‘png’ using cairographics) and which use Pango font selection now work around a bug in Pango when very small fonts (those with sizes between 0 and 1 in Pango's internal units) are requested. (PR#14369)
Added workaround for the font problem with ‘X11(type = "cairo")’ and similar on Mac OS X whereby italic and bold styles were interchanged. (PR#13463 amongst many other reports.)
‘source(chdir = TRUE)’ failed to reset the working directory if it could not be determined - that is now an error.
Fix for crash of ‘example(rasterImage)’ on ‘x11(type="Xlib")’.
Force Quartz to bring the on-screen display up-to-date immediately before the snapshot is taken by ‘grid.cap()’ in the Cocoa implementation. (PR#14260)
‘model.frame’ had an unstated 500 byte limit on variable names. (Example reported by Terry Therneau.)
The 256-byte limit on names is now documented.
Subassignment by ‘[’, ‘[[’ or ‘$’ on an expression object with value ‘NULL’ coerced the object to a list.
‘install.packages()’ has a new optional argument ‘INSTALL_opts’ which can be used to pass options to ‘R CMD INSTALL’ for source-package installs.
‘R CMD check’ now runs the package-specific tests with ‘LANGUAGE=en’ to facilitate comparison to ‘.Rout.save’ files.
‘sessionInfo()’ gives more detailed platform information, including 32/64-bit and the sub-architecture if one is used.
The use of Perl configuration variables for ‘R CMD check’ (as previously documented in ‘Writing R Extensions’) is deprecated and will be removed in R 2.12.0. Use the environment variables documented in ‘R Internals’ instead.
‘R CMD Rd2dvi’ failed if run from a path containing space(s). This also affected ‘R CMD check’, which calls ‘Rd2dvi’.
‘stripchart()’ could fail with an empty factor level. (PR#14317)
Text help rendering of ‘\tabular{}’ has been improved: under some circumstances leading blank columns were not rendered.
‘strsplit(x, fixed=TRUE)’ marked UTF-8 strings with the local encoding when no splits were found.
‘weighted.mean(NA, na.rm=TRUE)’ and similar now returns ‘NaN’ again, as it did prior to R 2.10.0.
‘R CMD’ had a typo in its detection of whether the environment variable ‘TEXINPUTS’ was set (reported by Martin Morgan).
The command-line parser could mistake ‘--file=size...’ for one of the options for setting limits for Ncells or Vcells.
The internal ‘strptime()’ could corrupt its copy of the timezone which would then lead to spurious warnings. (PR#14338)
‘dir.create(recursive = TRUE)’ could fail if one of the components existed but was a directory on a read-only file system. (Seen on Solaris, where the error code returned is not even listed as possible on the man page.)
The ‘postscript()’ and ‘pdf()’ devices will now allow ‘lwd’ values less than 1 (they used to force such values to be 1).
Fixed font face for CID fonts in ‘pdf()’ graphics output. (PR#14326)
‘GERaster()’ now checks for width or height of zero and does nothing in those cases; previously the behaviour was undefined, probably device-specific, and possibly dangerous.
‘wilcox.test(x, y, conf.int = TRUE)’ failed with an unhelpful message if ‘x’ and ‘y’ were constant vectors, and similarly in the one-sample case. (PR#14329)
Improperly calling ‘Recall()’ from outside a function could cause a segfault. (Reported by Robert McGehee.)
‘\Sexpr[result=rd]’ in an Rd file added a spurious newline, which was displayed as extra whitespace when rendered.
‘require(save = TRUE)’ recorded the names of packages it failed to load.
‘packageStatus()’ could return a data frame with duplicate row names which could then not be printed.
‘txtProgressBar(style = 2)’ did not work correctly.
‘txtProgressBar(style = 3)’ did not display until a non-minimum value was set.
‘contour()’ did not display dashed line types properly when contour lines were labelled. (Reported by David B. Thompson.)
‘tools::undoc()’ again detects undocumented data objects. Of course, this also affects ‘R CMD check’.
‘ksmooth(x,NULL)’ no longer segfaults.
‘approxfun()’, ‘approx()’, ‘splinefun()’ and ‘spline()’ could be confused by ‘x’ values that were different but so close as to print identically. (PR#14377)
‘R CMD INSTALL’ checks if dependent packages are available early on in the installation of source packages, thereby giving clearer error messages.
‘R CMD INSTALL --build’ now names the file in the format used for Mac OS X binary files on that platform.
‘BIC()’ in package ‘stats4’ now also works with multiple fitted models, analogously to ‘AIC()’.
Use of file extension ‘.C’ for C++ code in packages is now deprecated: it has caused problems for some ‘make’s on case-insensitive file systems (although it currently works with the recommended toolkits).
Command ‘gnutar’ is preferred to ‘tar’ when configure sets ‘TAR’. This is needed on Mac OS 10.6, where the default ‘tar’, ‘bsdtar 2.6.2’, has been reported to produce archives with illegal extensions to tar (according to the POSIX standard).
The C function ‘mkCharLenCE’ now no longer reads past ‘len’ bytes (unlikely to be a problem except in user code). (PR#14246)
On systems without any default ‘LD_LIBRARY_PATH’ (not even ‘/usr/local/lib’), ‘[DY]LIB_LIBRARY_PATH’ is now set without a trailing colon. (PR#13637)
More efficient implementation of ‘utf8ToInt()’ on long multi-byte strings with many multi-byte characters. (PR#14262)
‘aggregate.ts()’ gave platform-dependent results due to rounding error for ‘ndeltat != 1’.
‘package.skeleton()’ sometimes failed to fix filenames for ‘.R’ or ‘.Rd’ files to start with an alphanumeric. (PR#14253)
It also failed when only an S4 class without any methods was defined. (PR#14280)
‘splinefun(method = ‘"monoH.FC"’)’ was not quite monotone in rare cases. (PR#14215)
‘Rhttpd’ no longer crashes due to ‘SIGPIPE’ when the client closes the connection prematurely. (PR#14266)
‘format.POSIXlt()’ could cause a stack overflow and crash when used on very long vectors. (PR#14267)
‘Rd2latex()’ incorrectly escaped special characters in ‘\usage’ sections.
‘mcnemar.test()’ could alter the levels (dropping unused levels) if passed ‘x’ and ‘y’ as factors (reported by Greg Snow).
‘Rd2pdf’ sometimes needed a further ‘pdflatex’ pass to get hyperlinked pages correct.
‘interaction()’ produced malformed results when levels were duplicated, causing segfaults in ‘split()’.
‘cut(d, breaks = <n>)’ now also works for ‘"Date"’ or ‘"POSIXt"’ argument ‘d’. (PR#14288)
‘memDecompress()’ could decompress incompletely rare ‘xz’-compressed input due to incorrect documentation of ‘xz utils’. (Report and patch from Olaf Mersmann.)
The S4 ‘initialize()’ methods for ‘"matrix"’, ‘"array"’, and ‘"ts"’ have been fixed to call ‘validObject()’. (PR#14284)
‘R CMD INSTALL’ now behaves the same way with or without ‘--no-multiarch’ on platforms with only one installed architecture. (It used to clean the ‘src’ directory without ‘--no-multiarch’.)
‘[<-.data.frame’ was not quite careful enough in assigning (and potentially deleting) columns right-to-left. (PR#14263)
‘rbeta(n, a, b)’ no longer occasionally returns ‘NaN’ for ‘a >> 1 > b’. (PR#14291)
‘pnorm(x, log.p = TRUE)’ could return ‘NaN’ not ‘-Inf’ for ‘x’ near (minus for ‘lower.tail=TRUE’) the largest representable number.
Compressed data files ‘*.(txt|tab|csv).(gz|bz2|xz)’ were not recognized for the list of data topics and hence for packages using ‘LazyData’. (PR#14273)
‘textConnection()’ did an unnecessary translation on strings in a foreign encoding (e.g. UTF-8 strings on Windows) and so was slower than it could have been on very long input strings. (PR#14286)
‘tools::Rd2txt()’ did not render poorly written Rd files consistently with other renderers.
It computed widths of strings that would be ‘print()’ed with escapes incorrectly, for example in the computation of column width for ‘\tabular’.
‘na.action()’ did not extract the ‘na.action’ component as documented.
‘do.call()’ing ‘NextMethod’ in erronous ways no longer segfaults. (PR#13487)
Packages must have been installed under R >= 2.10.0, as the current help system is the only one now supported.
A port to 64-bit Windows is now available as well as binary package repositiories: see the ‘R Administration and Installation Manual’.
Argument matching for primitive functions is now done in the same way as for interpreted functions except for the deliberate exceptions
call switch .C .Fortran .Call .External
all of which use positional matching for their first argument, and also some internal-use-only primitives.
The default device for command-line R at the console on Mac OS X is now ‘quartz()’ and not ‘X11()’.
The ‘open’ modes for connections are now interpreted more consistently. ‘open = "r"’ is now equivalent to ‘open = "rt"’ for all connections. The default ‘open = ""’ now means ‘"rt"’ for all connections except the compressed-file connections ‘gzfile()’, ‘bzfile()’ and ‘xzfile()’ for which it means ‘"rb"’.
‘R CMD INSTALL’ now uses the internal ‘untar()’ function in package ‘utils’: this ensures that all platforms can install ‘bzip2’- and ‘xz’-compressed tarballs. In case this causes problems (as it has on some Windows file systems when run from Cygwin tools) it can be overridden by the environment variable ‘R_INSTALL_TAR’: setting this to a modern external tar program will speed up unpacking of large (tens of Mb or more) tarballs.
‘help(try.all.packages = TRUE)’ is much faster (although the time taken by the OS to find all the packages the first time it is used can dominate the time).
‘R CMD check’ has a new option ‘--timings’ to record per-example timings in file ‘<pkg>.Rcheck/<pkg>-Ex.timings’.
The TRE library has been updated to version 0.8.0 (minor bugfixes).
‘grep[l]’, ‘[g]sub’ and ‘[g]regexpr’ now work in bytes in an 8-bit locales if there is no marked UTF-8 input string: this will be somewhat faster, and for ‘[g]sub()’ give the result in the native encoding rather than in UTF-8 (which returns to the behaviour prior to R 2.10.0).
A new argument ‘skipCalls’ has been added to ‘browser()’ so that it can report the original context when called by other debugging functions.
More validity checking of UTF-8 and MBCS strings is done by ‘agrep()’ and the regular-expression matching functions.
The undocumented restriction on ‘gregexpr()’ to ‘length(text) > 0’ has been removed.
Package ‘tcltk’ now sends strings to Tcl in UTF-8: this means that strings with a marked UTF-8 encoding are supported in non-UTF-8 locales.
The graphics engine now supports rendering of raster (bitmap) images, though not all graphics devices can provide (full) support. Packages providing graphics devices (e.g., ‘Cairo’, ‘RSvgDevice’, ‘cairoDevice’) will need to be reinstalled.
There is also support in the graphics engine for capturing raster images from graphics devices (again not supported on all graphics devices).
‘R CMD check’ now also checks if the package and namespace can be unloaded: this provides a check of the ‘.Last.lib()’ and ‘.onUnload()’ hook functions (unless ‘--install=fake’).
‘prop.table(x)’ now accepts a one-dimensional table for ‘x’.
A new function ‘vapply()’ has been added, based on a suggestion from Bill Dunlap. It requires that a template for the function value be specified, and uses it to determine the output type and to check for consistency in the function values.
The main HTML help page now links to a reformatted copy of this ‘NEWS’ file. (Suggested by Henrik Bengtsson.) Package index files link to the package ‘DESCRIPTION’ and ‘NEWS’ files and a list of demos when using dynamic help.
The ‘[’ method for class ‘"AsIs"’ allows the next method to change the underlying class. (Wish of Jens Oehlschlägel.)
‘write.csv[2]’ no longer allow argument ‘append’ to be changed: as ever, direct calls to ‘write.table()’ give more flexibility as well as more room for error.
The index page for HTML help for a package now collapses multiple signatures for S4 methods into a single entry.
The use of ‘.required’ by ‘require()’ and ‘detach()’ has been replaced by ‘.Depends’ which is set from the ‘Depends’ field of a package (even in packages with name spaces). By default ‘detach()’ prevents such dependencies from being detached: this can be overridden by the argument ‘force’.
‘bquote()’ has been extended to work on function definitions. (Wish of PR#14031).
‘detach()’ when applied to an object other than a package returns the environment that has been detached, to parallel ‘attach()’.
‘readline()’ in non-interactive use returns ‘""’ and does not attempt to read from the ‘terminal’.
New function ‘file_ext()’ in package ‘tools’.
‘xtfrm()’ is now primitive and internally generic, as this allows S4 methods to be set on it without name-space scoping issues.
There are now ‘"AsIs"’ and ‘"difftime"’ methods, and the default method uses ‘unclass(x)’ if ‘is.numeric(x)’ is true (which will be faster but relies on ‘is.numeric()’ having been set correctly for the class).
‘is.numeric(x)’ is now false for a ‘"difftime"’ object (multiplication and division make no sense for such objects).
The default method of ‘weighted.mean(x, w)’ coerces ‘w’ to be numeric (aka double); previously only integer weights were coerced. Zero weights are handled specially so an infinite value with zero weight does not force an ‘NaN’ result.
There is now a ‘"difftime"’ method.
‘bug.report()’ now has arguments ‘package’ and ‘lib.loc’ to generate bug reports about packages. When this is used, it looks for a ‘BugReports’ field in the package ‘DESCRIPTION’ file, which will be assumed to be a URL at which to submit the report, and otherwise generates an email to the package maintainer. (Suggested by Barry Rowlingson.)
‘quantile()’ now has a method for the date-time class ‘"POSIXt"’, and types 1 and 3 (which never interpolate) work for Dates and ordered factors.
‘length(<POSIXlt>)’ now returns the length of the corresponding abstract timedate-vector rather than always 9 (the length of the underlying list structure). (Wish of PR#14073 and PR#10507.)
The ‘readline’ completion backend no longer sorts possible completions alphabetically (e.g., function argument names) if R was built with ‘readline >= 6’.
‘select.list()’ gains a ‘graphics’ argument to allow Windows/Mac users to choose the text interface. This changes the behaviour of ‘new.packages(ask=TRUE)’ to be like ‘update.packages(ask=TRUE)’ on those platforms in using a text menu: use ask=‘"graphics"’ for a graphical menu.
New function ‘chooseBioCmirror()’ to set the ‘"BioC_mirror"’ option.
The R grammar now prevents using the argument ‘name’ in signatures of S4 methods for ‘$’ and ‘$<-’, since they will always be called with a character string value for ‘name’. The implicit S4 generic functions have been changed to reflect this: packages which included ‘name’ in the signature of their methods need to be updated and re-installed.
The handling of the ‘method’ argument of ‘glm()’ has been refined following suggestions by Ioannis Kosmidis and Heather Turner.
‘str()’ gains a new argument ‘list.len’ with default 99, limiting the number of ‘list()’ items (per level), thanks to suggestions from David Winsenius.
Having formal arguments of an S4 method in a different order from the generic is now an error (the warning having been ignored by some package maintainers for a long time).
New functions ‘enc2native()’ and ‘enc2utf8()’ convert character vectors with possibly marked encodings to the current locale and UTF-8 respectively.
Unrecognized escapes and embedded nuls in character strings are now an error, not just a warning. Thus option ‘"warnEscapes"’ is no longer needed. ‘rawToChar()’ now removes trailing nuls silently, but other embedded nuls become errors.
Informational messages about masked objects displayed when a package is attached are now more compact, using ‘strwrap()’ instead of one object per line.
‘print.rle()’ gains argument ‘prefix’.
‘download.file()’ gains a ‘"curl"’ method, mainly for use on platforms which have ‘curl’ but not ‘wget’, but also for some hard-to-access URLs.
In ‘Rd’, ‘\eqn’ and ‘\deqn’ will render in HTML (and convert to text) upper- and lower-case Greek letters (entered as ‘\alpha’ ...), ‘\ldots’, ‘...’, ‘\ge’ and ‘\le’.
‘utf8ToInt()’ and ‘intToUtf8()’ now map ‘NA’ inputs to ‘NA’ outputs.
‘file()’ has a new argument ‘raw’ which may help if it is used with something other than a regular file, e.g. a character device.
New function ‘strtoi()’, a wrapper for the C function ‘strtol’.
‘as.octmode()’ and ‘as.hexmode()’ now allow inputs of length other than one.
The ‘format()’ and ‘print()’ methods for ‘"octmode"’ now preserve names and dimensions (as those for ‘"hexmode"’ did).
The ‘format()’ methods for classes ‘"octmode"’ and ‘"hexmode"’ gain a ‘width’ argument.
‘seq.int()’ returns an integer result in some further cases where ‘seq()’ does, e.g. ‘seq.int(1L, 9L, by = 2L)’.
Added ‘\subsection{}{}’ macro to Rd syntax, for subsections within sections.
n-dimensional arrays with dimension names can now be indexed by an n-column character matrix. The indices are matched against the dimension names. ‘NA’ indices are propagated to the result. Unmatched values and ‘""’ are not allowed and result in an error.
‘interaction(drop=TRUE)’ uses less memory (related to PR#14121).
‘summary()’ methods have been added to the ‘"srcref"’ and ‘"srcfile"’ classes, and various encoding issues have been cleaned up.
If option ‘"checkPackageLicense"’ is set to ‘TRUE’ (not currently the default), users will be asked to agree to non-known-to-be-FOSS package licences at first use.
Checking ‘setAs(a, b)’ methods only gives a message instead of a warning, when one of ‘a’ or ‘b’ is unknown.
New function ‘norm()’ to compute a matrix norm. ‘norm()’ and also ‘backsolve()’ and ‘sample()’ have implicit S4 generics.
Files ‘Renviron.site’ and ‘Rprofile.site’ can have architecture-specific versions on systems with sub-architectures.
‘R CMD check’ now (by default) also checks Rd files for auto-generated content in need of editing, and missing argument descriptions.
‘aggregate()’ gains a formula method thanks to a contribution by Arni Magnusson. The data frame method now allows summary functions to return arbitrarily many values.
‘path.expand()’ now propagates ‘NA’ values rather than converting them to ‘"NA"’.
‘file.show()’ now disallows ‘NA’ values for file names, headers, and pager.
The ‘fuzz’ used by ‘seq()’ and ‘seq.int()’ has been reduced from ‘1e-7’ to ‘1e-10’, which should be ample for the double-precision calculations used in R. It ensures that the fuzz never comes into play with sequences of integers (wish of PR#14169).
The default value of ‘RSiteSearch(restrict=)’ has been changed to include vignettes but to exclude R-help. The R-help archives available have been split, with a new option of ‘"Rhelp10"’ for those from 2010.
New function ‘rasterImage()’ in the ‘graphics’ package for drawing raster images.
‘stats:::extractAIC.coxph()’ now omits aliased terms when computing the degrees of freedom (suggestion of Terry Therneau).
‘cor()’ and ‘cov()’ now test for misuse with non-numeric arguments, such as the non-bug report PR#14207.
‘pchisq(ncp =, log.p = TRUE)’ is more accurate for probabilities near one. E.g. ‘pchisq(80, 4, ncp=1, log.p=TRUE)’. (Maybe what was meant in PR#14216.)
‘maintainer()’ has been added, to give convenient access to the name of the maintainer of a package (contributed by David Scott).
‘sample()’ and ‘sample.int()’ allow zero items to be sampled from a zero-length input. ‘sample.int()’ gains a default value ‘size=n’ to be more similar to ‘sample()’.
‘switch()’ returned ‘NULL’ on error (not previously documented on the help page): it now does so invisibly, analogously to if-without-else.
It is now primitive: this means that argument ‘EXPR’ is always matched to the first argument and there is no danger of partial matching to later named arguments.
Primitive functions ‘UseMethod()’, ‘attr()’, ‘attr<-()’, ‘on.exit()’, ‘retracemem()’ and ‘substitute()’ now use standard argument matching (rather than positional matching). This means that all multi-argument primitives which are not internal now use standard argument matching except where positional matching is desirable (as for ‘switch()’, ‘call()’, ‘.C()’ ...).
All the one-argument primitives now check that any name supplied for their first argument is a partial match to the argument name as documented on the help page: this also applies to replacement functions of two arguments.
‘base::which()’ uses a new ‘.Internal’ function when ‘arr.ind’ is ‘FALSE’ resulting in a 10x speedup. Thanks to Patrick Aboyoun for implementation suggestions.
Help conversion to text now uses the first part of ‘\enc{}{}’ markup if it is representable in the current output encoding. On the other hand, conversion to LaTeX with the default ‘outputEncoding = "ASCII"’ uses the second part.
A new class ‘"listOfMethods"’ has been introduced to represent the methods in a methods table, to replace the deprecated class ‘"MethodsList"’.
‘any()’ and ‘all()’ return early if possible. This may speed up operations on long vectors.
‘strptime()’ now accepts ‘"%z"’ (for the offset from UTC in the RFC822 format of ‘+/-hhmm’).
The PCRE library has been updated to version 8.02, a bug-fix release which also updates tables to Unicode 5.02.
Functions which may use a graphical ‘select.list()’ (including ‘menu()’ and ‘install.packages()’) now check on a Unix-alike that Tk can be started (and not just ‘capabilities("tcltk") && capabilities("X11")’).
The parser no longer marks strings containing octal or hex escapes as being in UTF-8 when entered in a UTF-8 locale.
On platforms with cairo but not Pango (notably Mac OS X) the initial default ‘X11()’ type is set to ‘"Xlib"’: this avoids several problems with font selection when done by cairo rather than Pango (at least on Mac OS X).
New function ‘arrayInd()’ such that ‘which(x, arr.ind = TRUE)’ for an array 'x' is now equivalent to ‘arrayInd(which(x), dim(x), dimnames(x))’.
Bundles of packages are defunct.
‘stats::clearNames()’ is defunct: use ‘unname()’.
Basic regular expressions are defunct, and ‘strsplit()’, ‘grep()’, ‘grepl()’, ‘sub()’, ‘gsub()’, ‘regexpr()’ and ‘gregexpr()’ no longer have an ‘extended’ argument.
‘methods::trySilent()’ is defunct.
‘index.search()’ (which was deprecated in 2.10.0) is no longer exported and has a different argument list.
Use of multiple arguments to ‘return()’ is now defunct.
The use of ‘UseMethod()’ with more than two arguments is now defunct.
In the ‘methods’ package, the ‘"MethodsList"’ metadata objects which had been superseded by hash tables (environments) since R 2.8.0 are being phased out. Objects of this class are no longer assigned or used as metadata by the package.
‘getMethods()’ is now deprecated, with its internal use replaced by ‘findMethods()’ and other changes. Creating objects from the ‘"MethodsList"’ class is also deprecated.
Parsing strings containing both octal/hex and Unicode escapes now gives a warning and will become an error in R 2.12.0.
UTF-8 is now used for the reference manual and package manuals. This requires LaTeX ‘2005/12/01’ or later.
‘configure’ looks for a POSIX compliant ‘tr’, Solaris's ‘/usr/ucb/tr’ having been found to cause ‘Rdiff’ to malfunction.
‘configure’ is now generated with ‘autoconf 2.65’, which works better on recent systems and on Mac OS X.
Characters in R source which are not translatable to the current locale are now handled more tolerantly: these will be converted to hex codes with a warning. Such characters are only really portable if they appear in comments.
‘R CMD INSTALL’ now tests that the installed package can be loaded (and backs out the installation if it cannot): this can be suppressed by ‘--no-test-load’. This avoids installing/updating a package that cannot be used: common causes of failures to load are missing/incompatible external software and missing/broken dependent packages.
Package installation on Windows for a package with a ‘src’ directory now checks if a DLL is created unless there is a ‘src/Makefile.win’ file: this helps catch broken installations where the toolchain has not reported problems in building the DLL. (Note: this can be any DLL, not just one named ‘<pkg-name>.dll’.)
Using ‘with()’, ‘eval()’ etc with a list with some unnamed elements now works. (PR#14035)
The ‘"quick"’ dispatch of S4 methods for primitive functions was not happening, forcing a search each time. (Dispatch for closures was not affected.) A side effect is that default values for arguments in a method that do not have defaults in the generic will now be ignored.
Trying to dispatch S4 methods for primitives during the search for inherited methods slows that search down and potentially could cause an infinite recursion. An internal switch was added to turn off all such methods from ‘findInheritedMethods()’.
R framework installation (on Mac OS X) would not work properly if a rogue ‘Resources’ directory was present at the top level. Such a non-symlink will now be renamed to ‘Resources.old’ (and anything previously named ‘Resources.old’ removed) as part of the framework installation process.
The checks for conforming S4 method arguments could fail when the signature of the generic function omitted some of the formal arguments (in addition to ‘...’). Arguments omitted from the method definition but conforming (per the documentation) should now be ignored (treated as ‘"ANY"’) in dispatching.
The computations for S4 method evaluation when ‘...’ was in the signature could fail, treating ‘...’ as an ordinary symbol. This has been fixed, for the known cases.
Various ‘ar()’ fitting methods have more protection for singular fits.
‘callNextMethod’ now works again with the ‘drop=’ argument in ‘[’
‘parse()’ and ‘parse_Rd()’ miscounted columns when multibyte UTF-8 characters were present.
Formatting of help pages has had minor improvements: extra blank lines have been removed from the text format, and empty package labels removed from HTML.
‘cor(A, B)’ where ‘A’ is n x 1 and ‘B’ a 1-dimensional array segfaulted or gave an internal error. (The case ‘cor(B, A)’ was PR#7116.)
‘cut.POSIXt()’ applied to a start value after the DST transition on a DST-change day could give the wrong time for argument ‘breaks’ in units of days or longer. (PR#14208)
‘do_par()’ ‘UNPROTECT’ed too early (PR#14214)
Subassignment ‘x[[....]] <- y’ didn't check for a zero-length right hand side, and inserted a rubbish value. (PR#14217)
‘fisher.test()’ no longer gives a P-value *very* slightly > 1, in some borderline cases.
Internal function ‘matchArgs()’ no longer modifies the general purpose bits of the ‘SEXP’s that make up the formals list of R functions. This fixes an invalid error message that would occur when a garbage collection triggered a second call to matchArgs for the same function _via_ a finalizer.
‘gsub()’ in 2.10.x could fail from stack overflow for extremely long strings due to temporary data being allocated on the stack. Also, ‘gsub()’ with ‘fixed=TRUE’ is in some circumstances considerably faster.
Several primitives, including ‘attributes()’, ‘attr<-()’ ‘interactive()’, ‘nargs()’ and ‘proc.time()’, did not check that they were called with the correct number of arguments.
A potential race condition in ‘list.files()’ when other processes are operating on the directory has been fixed; the code now dynamically allocates memory for file listings in a single pass instead of making an initial count pass.
‘mean(x, trim=, na.rm = FALSE)’ failed to return ‘NA’ if ‘x’ contained missing values. (Reported by Bill Dunlap.)
Extreme tail behavior of, ‘pbeta()’ {and hence ‘pf()’}, e.g., ‘pbeta(x, 3, 2200, lower.tail=FALSE, log.p=TRUE)’ now returns finite values instead of jumping to ‘-Inf’ too early. (PR#14230).
‘parse(text=x)’ misbehaved for objects ‘x’ that were not coerced internally to character, notably symbols. (Reported to R-devel by Bill Dunlap.)
The internal C function ‘coerceSymbol’ now handles coercion to character, and warns if coercion fails (rather than silently returning ‘NULL’). This allows a name to be given where a character vector is required in functions which coerce internally.
The interpretation by ‘strptime()’ of ‘"%c"’ was non-standard (not that it is ever advisable to use locale- and system-specific input formats).
capabilities(‘"X11"’) now works the same way on Mac OS X as on other platforms (and as documented: it was always true for R built with ‘--with-aqua’, as the CRAN builds are).
The ‘X11()’ device with cairo but not Pango (notably Mac OS X) now checks validity of text strings in UTF-8 locales (since Pango does but cairo it seems does not).
‘read.fwf()’ misread multi-line records when n was specified. (PR#14241)
‘all.equal(tolerance = e)’ passes the numeric tolerance also to the comparison of the attributes.
‘pgamma(0, 0)’, a boundary case, now returns 0, its limit from the left, rather than the limit from the right.
Issuing ‘POST’ requests to the internal web server could stall the request under certain circumstances.
‘gzcon( <textConnection> )’, an error, no longer damages the connection (in a way to have it segfault). (PR#14237)
All the results from ‘hist()’ now use the nominal ‘breaks’ not those adjusted by the numeric ‘fuzz’: in recent versions the nominal ‘breaks’ were reported but the 'density' referred to the intervals used in the calculation - which mattered very slightly for one of the extreme bins. (Based on a report by Martin Becker.)
If ‘xy[z].coords’ (used internally by many graphics functions) are given a list as ‘x’, they now check that the list has suitable names and give a more informative error message. (PR#13936)
The handling of line textures in the ‘postscript()’ and ‘pdf()’ devices was set up for round end caps (the only type which existed at the time): it has now been adjusted for butt endcaps.
‘lchoose(a, k)’ is now defined as ‘log(abs(choose(a,k)))’, analogously to ‘lfactorial()’.
Although ‘\eqn{}’ in Rd files is defined as a ‘verbatim’ macro, many packages expected ‘...’ and ‘\ldots’ to be interpreted there (as was the case in R < 2.10.0), so this is now done (using an ellipsis in HTML rendering).
Escaping of braces in quoted strings in R-code sections of Rd files is allowed again. This had been changed for the new Rd format in R 2.10.0 but was only documented on the developer site and was handled inconsistently by the converters: text and example conversion removed the escapes but HTML conversion did not.
The PCRE library has been updated to version 8.01, a bug-fix release.
‘tools::readNEWS()’ now accepts a digit as the first character of a news section.
Using ‘read.table(header=TRUE)’ on a header with an embedded new line would copy part of the header into the data. (PR#14103)
‘qpois(p = 1, lambda = 0)’ now gives 0 as for all other ‘p’. (PR#14135)
Functions related to string comparison (e.g. ‘unique()’, ‘match()’) could cause crashes when used with strings not in the native encoding, e.g. UTF-8 strings on Windows. (PR#14114 and PR#14125)
‘x[ , drop=TRUE]’ dropped an ‘NA’ level even if it was in use.
The dynamic HTML help system reported the wrong MIME type for the style sheet.
‘tools::codoc()’ (used by ‘R CMD check’) was missing cases where the function had no arguments but was documented to have some.
Help links containing special characters (e.g. ‘"?"’) were not generated correctly when rendered in HTML. (PR#14155)
‘lchoose(a, k)’ no longer wrongly gives ‘NaN’ for negative ‘a’.
‘ks.test()’ could give a p-value that was off by one observation due to rounding error. (PR#14145)
‘readBin()’/‘readChar()’ when reading millions of character strings in a single call used excessive amounts of memory (which also slowed them down).
‘R CMD SHLIB’ could fail if used with paths that were not alphanumeric, e.g. contained ‘+’. (PR#14168)
‘sprintf()’ was not re-entrant, which potentially caused problems if an ‘as.character()’ method called it.
The ‘quartz()’ device did not restore the clipping region when filling the background for a new page. This could be observed in multi-page bitmap output as stale outer regions of the plot.
‘p.adjust(method, n)’ now works correctly for the rare case ‘n > length(p)’, also when method differs from ‘"bonferroni"’ or ‘"none"’, thanks to a patch from Gordon Smyth.
‘tools::showNonASCII()’ failed to detect non-ASCII characters if ‘iconv()’ (incorrectly) converted them to different ASCII characters. (Seen on Windows only.)
‘tcrossprod()’ wrongly failed in some cases when one of the arguments was a vector and the other a matrix.
‘[cr]bind(..., deparse.level=2)’ was not always giving names when documented to do so. (Discovered whilst investigating PR#14189.)
‘match(incomparables=<non-NULL>)’ could in rare cases infinite-loop.
‘poisson.test()’ needed to pass argument ‘conf.level’ to ‘binom.test()’. (PR#14195)
The ‘"nls"’ method for ‘df.residual()’ gave incorrect results for models fitted with ‘na.action = na.exclude’. (PR#14194)
A change to ‘options(scipen=)’ was only implemented when printing next occurred, even though it should have affected intervening calls to ‘axis()’, ‘contour()’ and ‘filledcontour()’.
‘prettyNum(drop0trailing=TRUE)’ did not handle signs of imaginary parts of complex numbers correctly (and this was used by ‘str()’: PR#14201).
‘system.time()’ had the ‘sys.child’ component wrong (copied ‘user.child’ instead) on systems with ‘HAVE_GETRUSAGE’. (PR#14210)
Changing both line texture and line cap (end) resulted in the latter to be omitted form the PDF code. In addition, line cap (end) and join are now set explicitly in PDF output to ensure correct defaults.
The suppression of auto-rotation in ‘bitmap()’ and ‘dev2bitmap()’ with the ‘"pdfwrite"’ device was not working correctly.
‘plot(ecdf(), log="x")’ no longer gives an incorrect warning.
‘read.fwf()’ works again when argument ‘file’ is a connection.
Startup files will now be found if their paths exceed 255 bytes. (PR#14228)
‘contrasts<-’ (in the ‘stats’ package) no longer has an undeclared dependence on ‘methods’ (introduced in 2.10.0).
The PCRE library has been updated to version 8.00.
‘R CMD INSTALL’ has new options ‘--no-R’, ‘--no-libs’, ‘--no-data’, ‘--no-help’, ‘--no-demo’, ‘--no-exec’, and ‘--no-inst’ to suppress installation of the specified part of the package. These are intended for special purposes (e.g. building a database of help pages without fully installing all packages).
The documented line-length limit of 4095 bytes when reading from the console now also applies also to ‘parse(file="")’ (which previously had a limit of around 1024 bytes).
A Bioconductor mirror can be set for use by ‘setRepositories()’ _via_ the option ‘"BioC_mirror"’, e.g. the European mirror can be selected by ‘options(BioC_mirror="http://bioconductor.statistik.tu-dortmund.de")’.
Double-clicking in a ‘tk_select.list()’ list box now selects the item and closes the list box (as happens on the Windows ‘select.list()’ widget).
‘configure’ will be able to find a usable ‘libtiff’ in some rare circumstances where it did not previously (where ‘libtiff’ needed to be linked explicitly against ‘-ljpeg’).
Making ‘refman.pdf’ works around a problem with the indexing with ‘hyperref 6.79d’ and later.
The ‘extended’ argument is deprecated in ‘strsplit()’, ‘grep()’, ‘grepl()’, ‘sub()’, ‘gsub()’, ‘regexpr()’ and ‘gregexpr()’ (not just the value ‘extended = FALSE’) and will be removed in R 2.11.0.
‘trigamma(x)’ and other ‘psigamma(x, n)’ calls are now accurate for very large ‘abs(x)’. (PR#14020)
‘[g]sub(perl=FALSE, fixed=FALSE)’ could use excessive stack space when used with a very long vector containing some non-ASCII strings.
The default method of ‘weighted.mean(na.rm = TRUE)’ did not omit weights for ‘NA’ observations in 2.10.0. (PR#14032)
‘[g]regexpr(pattern, fixed = TRUE)’ returned match positions in bytes (not characters) in an MBCS locale if ‘pattern’ was a single byte.
‘[g]sub(fixed = TRUE)’ with a single-byte pattern could conceivably have matched part of a multibyte character in a non-UTF-8 MBCS.
‘findLineNum()’ and ‘setBreakpoint()’ would sometimes fail if the specified file was not in the current directory.
Package ‘tcltk’'s ‘demo(tkdensity)’ was broken in 2.9.0 when ‘demo()’ was changed to set ‘par(ask = TRUE)’.
‘gsub()’ with backrefs could fail on extremely long strings (hundreds of thousands of characters) due to integer overflow in a length calculation.
‘abline(untf=TRUE)’ now uses a better x-grid in log-scale, e.g., for ‘plot(c(1,300), c(1,300), log="xy"); abline(4,1, untf=TRUE)’.
‘detach()’/‘unloadNamespace()’ arrange to flush the package's lazyload cache of R objects once the package/namespace is no longer needed.
There have been small fixes to the rendering of help, e.g. ‘\command’ is now rendered verbatim (so e.g. ‘--’ is not interpreted, PR#14045).
Also, there are many small changes to help files where the new converters were not rendering them in the same way as before.
‘available.packages()’ would fail when run on a repository with no packages meeting the filtering conditions. (PR#14042)
‘rep(x, times, each = 2)’ gave invalid results when the ‘times’ argument was a vector longer than ‘x’. Reported by Bill Dunlap.
An error when ‘unloadNamespace()’ attempted to run the ‘.onUnload()’ function gave an error in the reporting function and so was not reported properly.
Text help rendering did not handle very long input lines properly.
‘promptMethods()’ generated signature documentation improperly.
‘pgamma(x, a, lower.tail=FALSE)’ and ‘qgamma(...)’ are now considerably more accurate in some regions for very small ‘a’. ‘qgamma()’ now correctly returns ‘0’ instead of ‘NaN’ in similar extreme cases, and ‘qgamma()’ no longer warns in the case of small ‘a’, see (PR#12324).
‘unname()’ now also removes names from a zero length vector.
Printing results from ‘ls.str()’ no longer evaluates unevaluated calls.
‘complete.cases()’ failed on a 0-column data frame argument. (Underlies PR#14066.)
It could return nonsensical results if no input determined the number of cases (seen in the no-segfault tests).
An error in ‘nls()’ with a long formula could cause a segfault. (PR#14059)
‘qchisq(p, df, ncp, lower.tail = FALSE)’ with ‘ncp >= 80’ was inaccurate for small ‘p’ (as the help page said): it is now less inaccurate. (In part, PR#13999.)
For ‘ncp’ less than but close to 80, ‘pchisq()’ and ‘qchisq()’ are more accurate for probablilities very close to 1 (a series expansion was truncated slightly too early).
‘pchisq(x, df, ncp)’ can no longer return values just larger than one for large values of ‘ncp’.
‘intToUtf8()’ could fail when asked to produce 10Mb or more strings, something it was never intended to do: unfortunately Windows crashed R (other OSes reported a lack of resources). (PR#14068)
‘chisq.test()’ could fail when given argument ‘x’ or ‘y’ which deparsed to more than one line. (Reported by Laurent Gauthier.)
S4 methods are uncached whenever the name space containing them is unloaded (by ‘unloadNamespace()’ as well as by ‘detach(unload = TRUE))’.
The internal record-keeping by ‘dyn.load’/‘dyn.unload’ was incomplete, which could crash R if a DLL that registered ‘.External’ routines had earlier been unloaded.
‘bessel[JY](x, nu)’ with ‘nu’ a negative integer (a singular case) is now correct, analogously to ‘besselI()’, see PR#13556.
‘tools::file_path_as_absolute()’ doubled the file separator when applied to a file such as ‘"/vmunix"’ or (on Windows) ‘"d:/afile"’ in a directory for which ‘getwd()’ would return a path with a trailing separator (largely cosmetic, as reasonable file systems handle such a path correctly). (Perhaps what was meant by PR#14078.)
‘unsplit(drop = TRUE)’ applied to a data frame failed to pass ‘drop’ to the computation of row names. (PR#14084)
The ‘"difftime"’ method of ‘mean()’ ignored its ‘na.rm’ argument.
‘tcltk::tk_select.list()’ is now more likely to remove the widget immediately after selection is complete.
Adding/subtracting a ‘"difftime"’ object to/from a ‘"POSIXt"’ or ‘"Date"’ object works again (it was broken by the addition of ‘Ops.difftime’).
Conversion to latex of an Rd file with no aliases failed.
‘wilcox.test(conf.int=TRUE)’ has achieved.level corrected and, for ‘exact=FALSE’, now returns a ‘estimate’ component which does not depend on the alternative used.
‘help.search()’ failed when the package argument was specified. (PR#14113)
‘switch(EXPR = "A")’ now returns ‘NULL’, as does ‘switch(1)’ (which used to signal an error).
Package help is now converted from ‘Rd’ by the R-based converters that were first introduced in 2.9.0. This means
• Packages that were installed by R-devel after 2009-08-09 should not be used with earlier versions of R, and most aspects of package help (including the runnable examples) will be missing if they are so used.
• Text, HTML and latex help and examples for packages installed under the new system are converted on-demand from stored parsed Rd files. (Conversions stored in packages installed under R < 2.10.0 are used if no parsed Rd files are found. It is recommended that such packages be re-installed.)
HTML help is now generated dynamically using an HTTP server running in the R process and listening on the loopback interface.
• Those worried about security implications of such a server can disable it by setting the environment variable ‘R_DISABLE_HTTPD’ to a non-empty value. This disables ‘help.start()’ and HTML help (so text help is shown instead).
• The Java/Javascript search engine has been replaced by an HTML interface to ‘help.search()’. ‘help.start()’ no longer has an argument ‘searchEngine’ as it is no longer needed.
• The HTML help can now locate cross-references of the form ‘\link[pkg]{foo}’ and ‘\link[pkg:foo]{bar}’ where ‘foo’ is an alias in the package, rather than the documented (basename of a) filename (since the documentation has been much ignored).
‘polygon()’, ‘pdf()’ and ‘postscript()’ now have an argument ‘fillOddEven’ (default ‘FALSE’), which controls the mode used for polygon fills of self-intersecting shapes.
New ‘debugonce()’ function; further, ‘getOption("deparse.max.lines")’ is now observed when debugging, from a code suggestion by John Brzustowski. (PR#13647/8)
‘plot()’ methods for ‘"stepfun"’ and hence ‘"ecdf"’ no longer plot points by default for ‘n >= 1000’.
‘[g]sub(perl=TRUE)’ now also supports ‘"\E"’ in order to *end* ‘"\U"’ and ‘"\L"’ case changes, thanks to a patch from Bill Dunlap.
‘factor()’, ‘levels()<-’, etc, now ensure that the resulting factor levels are unique (as was always the implied intention). Factors with duplicated levels are still constructible by low-level means, but are now declared illegal.
New ‘print()’ (S3) method for class ‘"function"’, also used for auto-printing. Further, ‘.Primitive’ functions now print and auto-print identically. The new method is based on code suggestions by Romain François.
The ‘print()’ and ‘toLatex()’ methods for class ‘"sessionInfo"’ now show the locale in a nicer format and have arguments to suppress locale information.
In addition to previously only ‘round()’, there are other ‘Math’ group (S3) methods for ‘"difftime"’, such as ‘floor()’, ‘signif()’, ‘abs()’, etc.
For completeness, ‘old.packages()’ and ‘available.packages()’ allow arguments ‘type’ to be specified (you could always specify arguments ‘available’ or ‘contriburl’).
‘available.packages()’ by default only returns information on the latest versions of packages whose version requirements are satisfied by the currently running R.
‘tools::write_PACKAGES()’ has a new argument ‘latestOnly’, which defaults to ‘TRUE’ when only the latest versions in the repository will be listed in the index.
‘getOption()’ has a new argument ‘default’ that is returned if the specified option is not set. This simplifies querying a value and checking whether it is ‘NULL’ or not.
‘parse()’ now warns if the requested encoding is not supported.
The ‘"table"’ method of ‘as.data.frame()’ gains a ‘stringsAsFactors’ argument to allow the classifying factors to be returned as character vectors rather than the default factor type.
If ‘model.frame.default()’ encounters a character variable where ‘xlev’ indicates a factor, it now converts the variable to a factor (with a warning).
‘curve()’ now returns a list containing the points that w§ere drawn.
‘spineplot()’ now accepts ‘axes = FALSE’, for consistency with other functions called by ‘plot.factor()’.
The Kendall and Spearman methods of ‘cor.test()’ can optionally use continuity correction when not computing exact p-values. (The Kendall case is the wish of PR#13691.)
R now keeps track of line numbers during execution for code sourced with ‘options(keep.source = TRUE)’. The source reference is displayed by debugging functions such as ‘traceback()’, ‘browser()’, ‘recover()’, and ‘dump.frames()’, and is stored as an attribute on each element returned by ‘sys.calls()’.
More functions now have an implicit (S4) generic definition.
‘quantile.default()’ now disallows factors (wish of PR#13631) and its help documents what numeric-like properties its input need to have to work correctly.
‘weighted.mean()’ is now generic and has ‘"Date"’, ‘"POSIXct"’ and ‘"POSIXlt"’ methods.
Naming subscripts (e.g. ‘x[i=1, j=2]’) in ‘data.frame’ methods for ‘[’ and ‘[[’ now gives a warning. (Names are ignored in the default method, but could have odd semantics for other methods, and do for the data.frame ones.)
‘as.data.frame()’ has an ‘"aovproj"’ method. (Wish of PR#13505)
‘as.character(x)’ for numeric ‘x’ no longer produces strings such as ‘"0.30"’, i.e., with trailing zeros. This change also renders levels construction in ‘factor()’ more consistent.
‘codocClasses()’, which checks consistency of the documentation of S4 class slots, now does so in considerably more cases. The documentation of inherited slots (from superclasses) is now optional. This affects ‘R CMD check <pkg>’ when the package defines S4 classes.
‘codoc()’ now also checks S4 methods for code/documentation mismatches.
‘for()’, ‘while()’, and ‘repeat()’ loops now always return NULL as their (invisible) value. This change was needed to address a reference counting bug without creating performance penalties for some common use cases.
The ‘print()’ method for ‘ls.str()’ results now obeys an optional ‘digits’ argument.
The ‘method’ argument of ‘glm()’ now allows user-contributed methods.
More general ‘reorder.default()’ replaces functionality of ‘reorder.factor()’ and ‘reorder.character()’.
The function ‘aspell()’ has been added to provide an interface to the ‘Aspell’ spell-checker.
Filters ‘RdTextFilter()’ and ‘SweaveTeXFilter()’ have been added to the tools package to provide support for ‘aspell()’ or other spell checkers.
‘xtabs()’ with the new argument ‘sparse = TRUE’ now returns a sparse Matrix, using package ‘Matrix’.
‘contr.sum()’ etc gain an argument ‘sparse’ which allows sparse matrices to be returned.
‘contrasts()’ also gains a ‘sparse’ argument which it passes to the actual contrast function if that has a formal argument ‘sparse’.
‘contrasts(f, .) <- val’ now also works when ‘val’ is a sparse Matrix. It is planned that ‘model.matrix()’ will work with such factors ‘f’ in the future.
‘readNEWS()’ will recognize a UTF-8 byte-order mark (BOM) in the ‘NEWS’ file. However, it is safer to use only ASCII code there because not all editors recognize BOMs.
New utility function ‘inheritedSlotNames()’ for S4 class programming.
‘tabulate()’ now allows NAs to pass through (and be ignored).
If ‘debug()’ is called on an S3 generic function then all methods are debugged as well.
Outlier symbols drawn by ‘boxplot()’ now obey the ‘outlwd’ argument. Reported by Jurgen Kluge.
‘svd(x)’ and ‘eigen(x)’ now behave analogously to ‘qr(x)’ in accepting logical matrices ‘x’.
File ‘NEWS’ is now in UTF-8, and has a BOM (often invisible) on the first line, and ‘Emacs’ local variables set for UTF-8 at the end. ‘RShowDoc("NEWS")’ should display this correctly, given suitable fonts.
‘terms.formula(simplify = TRUE)’ now does not deparse the LHS and so preserves non-standard responses such as ‘`a: b`’ (requested by Sundar Dorai-Raj).
New function ‘news()’ for building and querying R or package news information.
‘z^n’ for integer ‘n’ and complex ‘z’ is more accurate now if ‘|n| <= 65536’.
‘factor(NULL)’ now returns the same as ‘factor(character(0))’ instead of an error, and ‘table(NULL)’ consequently does analogously.
‘as.data.frame.vector()’ (and its copies) is slightly faster by avoiding a copy if there are no names (following a suggestion of Tim Hesterberg).
‘writeLines()’, ‘writeBin()’ and ‘writeChar()’ have a new argument ‘useBytes’. If false, character strings with marked encodings are translated to the current locale (as before) but if true they are written byte-by-byte.
‘iconv()’ has a new argument ‘mark’ which can be used (by experts) to suppress the declaration of encodings.
‘DESCRIPTION’ file's ‘LinkingTo’ specs are now recognized as installation dependencies, and included in package management computations.
Standardized ‘DESCRIPTION’ file ‘License’ specs are now available for package management computations.
‘"\uxxxx"’ and ‘"\Uxxxxxxxx"’ escapes can now be parsed to a UTF-8 encoded string even in non-UTF-8 locales (this has been implemented on Windows since R 2.7.0). The semantics have been changed slightly: a string containing such escapes is always stored in UTF-8 (and hence is suitable for portably including Unicode text in packages).
New ‘as.raw()’ method for ‘"tclObj"’ objects (wish of PR#13758).
‘Rd.sty’ now makes a better job of setting email addresses, including using a monospaced font.
‘textConnection()’ gains an ‘encoding’ argument to determine how input strings with marked encodings will be handled.
‘R CMD Rd2pdf’ is available as a shortcut for ‘R CMD Rd2dvi --pdf’.
‘R CMD check’ now checks links where a package is specified (‘\link[pkg]{file}’ or ‘\link[pkg:file]{topic}’), if the package is available. It notes if the package is not available, as in many cases this is an error in the link.
‘identical()’ gains three logical arguments, which allow for even more differentiation, notably ‘-0’ and ‘0’.
‘legend()’ now can specify the ‘border’ color of filled boxes, thanks to a patch from Frederic Schutz.
Indexing with a vector index to ‘[[ ]]’ has now been extended to all recursive types.
Pairlists may now be assigned as elements of lists. (Lists could always be created with pairlist elements, but ‘[[<-’ didn't support assigning them.)
The parser now supports C-preprocessor-like ‘#line’ directives, so error messages and source references may refer to the original file rather than an intermediate one.
New functions ‘findLineNum()’ and ‘setBreakpoint()’ work with the source references to find the location of source lines and set breakpoints (using ‘trace()’) at those lines.
Namespace importing is more careful about warning on masked generics, thanks to a patch by Yohan Chalabi.
‘detach()’ now has an argument ‘character.only’ with the same meaning as for ‘library()’ or ‘require()’.
‘available.packages()’ gains a ‘filters’ argument for specifying the filtering operations performed on the packages found in the repositories. A new built-in ‘"license/FOSS"’ filter only retains packages for which installation can proceed solely based on packages which can be verified as Free or Open Source Software (FOSS) employing the available license specifications.
In registering an S3 class by a call to ‘setOldClass()’, the data part (e.g., the object type) required for the class can be included as one of the superclasses in the Classes argument.
The argument ‘f’ to ‘showMethods()’ can be an expression evaluating to a generic function, allowing methods to be shown for non-exported generics and other nonstandard cases.
‘sprintf()’ now supports ‘%o’ for octal conversions.
New function ‘Sys.readlink()’ for information about symbolic links, including if a file is a symbolic link.
Package ‘tools’ has new functions ‘checkRdaFiles()’ and ‘resaveRdaFiles()’ to report on the format of ‘.rda’/‘.RData’ data files, and to re-save them in a different compressed format, including choosing the most compact format available.
A new ‘INSTALL’ option, ‘--resave-data’, makes use of this.
File ‘~/.R/config’ is used in preference to ‘~/.Rconfig’, and these are now documented in ‘R Installation and Administration’.
Logic operations with complex numbers now work, as they were always documented to, and as in S.
‘arrows()’ and ‘segments()’ allow one of ‘x1’ or ‘y1’ to be omitted to simplify the specification of vertical or horizontal lines (suggestion of Tim Hesterberg).
‘approxfun()’ is faster by avoiding repeated ‘NA’ checks (diagnosis and patch by Karline Soetaert & Thomas Petzoldt).
There are the beginnings of a Nynorsk translation by Karl Ove Hufthammer.
‘stripchart()’ allows ‘par’ ‘bg’ to be passed in for the background colour for ‘pch = 21’ (wish of PR#13984).
New generic function ‘.DollarNames()’ to enable class authors to customize completion after the ‘$’ extractor.
‘load()’, ‘save()’, ‘dput()’ and ‘dump()’ now open a not-yet-open connection in the appropriate mode (as other functions using connections directly already did).
A different regular expression engine is used for basic and extended regexps and is also for approximate matching. This is based on the TRE library of Ville Laurikari, a modified copy of which is included in the R sources.
This is often faster, especially in a MBCS locale.
Some known differences are that it is less tolerant of invalid inputs in MBCS locales, and in its interpretation of undefined (extended) regexps such as ‘"^*"’. Also, the interpretation of ranges such as ‘[W-z]’ in caseless matching is no longer to map the range to lower case.
This engine may in future be used in ‘literal’ mode for ‘fixed = TRUE’, and there is a compile-time option in ‘src/main/grep.c’ to do so.
The use of repeated boundary regexps in ‘gsub()’ and ‘gregexpr()’ as warned about in the help page does not work in this engine (it did in the previous one since 2005).
Extended (and basic) regexps now support same set of options as for ‘fixed = TRUE’ and ‘perl = TRUE’, including ‘useBytes’ and support for UTF-8-encoded strings in non-UTF-8 locales.
‘agrep()’ now has full support for MBCS locales with a modest speed penalty. This enables ‘help.search()’ to use approximate matching character-wise rather than byte-wise.
‘[g]sub’ use a single-pass algorithm instead of matching twice and so is usually faster.
The ‘perl = TRUE’ versions now work correctly in a non-UTF-8 MBCS locale, by translating the inputs to UTF-8.
‘useBytes = TRUE’ now inhibits the translation of inputs with marked encodings.
‘strsplit()’ gains a ‘useBytes’ argument.
The algorithm used by ‘strsplit()’ has been reordered to batch by elements of ‘split’: this can be much faster for ‘fixed = FALSE’ (as multiple compilation of regexps is avoided).
The help pages, including ‘?regexp’, have been updated and should be consulted for details of the new implementations.
A new dynamic HTML help system is used by default, and may be controlled using ‘tools::startDynamicHelp()’. With this enabled, HTML help pages will be generated on request, resolving links by searching through the current ‘.libPaths()’. The user may set options(‘"help.ports"’) to control which IP port is used by the server.
‘help.start()’ no longer sets ‘options(htmlhelp = TRUE)’ (it used to on Unix but not on Windows). Nor does it on Unix reset the ‘"browser"’ option if given an argument of that name.
Arguments ‘update’ and ‘remote’ are now available on all platforms: the default is ‘update = FALSE’ since the http server will update the package index at first use.
‘help()’ has a new argument ‘help_type’ (with default set by the option of that name) to supersede arguments ‘offline’, ‘htmlhelp’ and ‘chmhelp’ (although for now they still work if ‘help_type’ is unset). There is a new type, ‘"PDF"’ to allow offline PDF (rather than PostScript).
A function ‘offline_help_helper()’ will be used if this exists in the workspace or further down the search path, otherwise the function of that name in the ‘utils’ name space is used.
Plain text help is now used as the fallback for HTML help (as it always was for Compiled HTML help on Windows).
It is possible to ask for static HTML pages to be prebuilt _via_ the configure option ‘--enable-prebuilt-html’. This may be useful for those who wish to make HTML help available outside R, e.g. on a local web site.
An experimental tag ‘\Sexpr’ has been added to Rd files, to evaluate expressions at build, install, or render time. Currently install time and render time evaluation are supported.
Tags ‘\if’, ‘\ifelse’ and ‘\out’ have been added to allow format-specific (or more general, using ‘\Sexpr’) conditional text in man pages.
The ‘parse_Rd()’ parser has been made more tolerant of coding errors in Rd files: now all syntax errors are reported as warnings, and an attempt is made to continue parsing.
‘parse_Rd()’ now has an argument ‘fragment’ (default ‘FALSE’) to accept small fragments of Rd files (so that ‘\Sexpr’ can output Rd code which is then parsed).
‘parse_Rd()’ now always converts its input to UTF-8. The ‘Rd2*’ rendering functions have a new argument, ‘outputEncoding’, which controls how their output is encoded.
‘parse_Rd()’ no longer includes the newline as part of a ‘"%"’-style comment.
There have been various bug fixes and code reorganization in the Rd renderers ‘Rd2HTML’, ‘Rd2latex’, ‘Rd2txt’, and ‘Rd2ex’.
All example files are now created with either ASCII or UTF-8 encoding, and the encoding is only marked in the file if there is any non-UTF-8 code (previously it was marked if the help file had non-ASCII contents, possibly in other sections).
‘print.Rd()’ now adds necessary escape characters so that printing and re-parsing an Rd object should produce an equivalent object.
‘parse_Rd()’ was incorrectly handling multiple backslashes in R code strings, converting 4n+3 backslashes to 2n+1 instead of 2n+2.
‘parse_Rd()’ now recognizes the ‘\var’ tag within a quoted string in R-like text.
‘parse_Rd()’ now treats the argument of ‘\command’ as LaTeX-like, rather than verbatim.
New function ‘untar()’ to list or unpack tar archives, possibly compressed. This uses either an external ‘tar’ command or an internal implementation.
New function ‘tar()’ to create (possibly compressed) tar archives.
New functions ‘memCompress()’ and ‘memDecompress()’ for in-memory compression and decompression.
‘bzfile()’ has a ‘compress’ argument to select the amount of effort put into compression when writing.
New function ‘xzfile()’ for use with ‘xz’-compressed files. (This can also read files compressed by some versions of ‘lzma’.)
‘gzfile()’ looks at the file header and so can now also read ‘bzip2’-ed files and ‘xz’-compressed files.
There are the new options of ‘save(compress = "bzip2")’ and ‘"xz"’ to use ‘bzip2’ or ‘xz’ compression (which will be slower, but can give substantially smaller files). Argument ‘compression_level’ gives finer control over the space/time tradeoffs.
‘load()’ can read such saves (but only as from this version of R).
‘R CMD INSTALL’/‘check’ and ‘tools::writePACKAGES’ accept a wider range of compressed tar archives. Precisely how wide depends on the capabilities of the host system's ‘tar’ command: they almost always include ‘.tar.bz2’ archives, and with modern versions of ‘tar’ other forms of compression such as ‘lzma’ and ‘xz’, and arbitrary extensions.
‘R CMD INSTALL’ has a new option ‘--data-compress’ to control the compression used when lazy-loading data. New possibilities are ‘--data-compress=bzip2’ which will give ca 15% better compression at the expense of slower installation times, and ‘--data-compress=xz’, often giving even better compression on large datasets at the expense of much longer installation times. (The latter is used for the recommended packages: it is particularly effective for ‘survival’.)
‘file()’ for open = ‘""’, ‘"r"’ or ‘"rt"’ will automagically detect compressed files (from ‘gzip’, ‘bzip2’ or ‘xz’). This means that compressed files can be specified by file name (rather than _via_ a ‘gzfile()’ connection) to ‘read.table()’, ‘readlines()’, ‘scan()’ and so on.
‘data()’ can handle compressed text files with extensions ‘.{txt,tab,csv}.{gz,bz2,xz}’ .
‘png(type="cairo1")’ is defunct: the value is no longer recognized.
‘tools::Rd_parse()’ is defunct (as this version of R uses only Rd version 2).
Use of file ‘~/.Rconf’ (which was deprecated in favour of ‘~/.Rconfig’ in 2004) has finally been removed.
Bundles of packages are deprecated. See ‘Writing R Extensions’ for the steps needed to unbundle a bundle.
‘help()’ arguments ‘offline’, ‘htmlhelp’ and ‘chmhelp’ are deprecated in favour of ‘help_type’.
‘clearNames()’ (in package ‘stats’) is deprecated for ‘unname()’.
Basic regular expressions (‘extended = FALSE’) are deprecated in ‘strsplit’, ‘grep’ and friends. There is a precise POSIX standard for them, but it is not what recent RE engines implement, and it seems that in almost all cases package authors intended ‘fixed = TRUE’ when using ‘extended = FALSE’.
‘methods::trySilent()’ is deprecated in favour of ‘try(silent=TRUE)’ or - more efficiently and flexibly - something like ‘tryCatch(error = function(e) e)’.
‘index.search()’ is deprecated: there are no longer directories of types other than ‘help’.
cairo >= 1.2 is now required (1.2.0 was released in July 2006) for cairo-based graphics devices (which remain optional).
A suitable ‘iconv()’ is now required: support for configure option ‘--without-iconv’ has been withdrawn (it was deprecated in R 2.5.0).
Perl is no longer ‘essential’. R can be built without it, but scripts ‘R CMD build’, ‘check’, ‘Rprof’ and ‘Sd2d’ currently require it.
A system ‘glob’ function is now essential (a working ‘Sys.glob()’ has been assumed since R 2.9.0 at least).
C99 support for MBCS is now required, and configure option ‘--disable-mbcs’ has been withdrawn.
Having a version of ‘tar’ capable of automagically detecting compressed archives is useful for ‘utils::untar()’, and so ‘gtar’ (a common name for GNU ‘tar’) is preferred to ‘tar’: set environment variable ‘TAR’ to specify a particular ‘tar’ command.
There is some makefile support for adding/updating translations in packages: see ‘po/README’ and ‘Writing R Extensions’.
There is support for the use of ‘dngettext’ for C-level translations in packages: see ‘Writing R Extensions’.
Assigning an extra 0-length column to a data frame by ‘DF[, "foo"] <- value’ now works in most cases (by filling with ‘NA’s) or fails. (It used to give a corrupt data frame.)
‘validObject()’ avoids an error during evaluation in the case of various incorrect slot definitions.
‘n:m’ now returns a result of type ‘"integer"’ in a few more boundary cases.
The ‘zap.ind’ argument to ‘printCoefmat()’ did not usually work as other code attempted to ensure that non-zero values had a non-zero representation.
‘printCoefmat()’ formatted groups of columns together, not just the ‘cs.ind’ group but also the ‘zap.ind’ group and a residual group. It now formats all columns except the ‘cs.ind’ group separately (and zaps the ‘zap.ind’ group column-by-column). The main effect will be see in the output from ‘print.anova()’, as this grouped SS-like columns in the ‘zap.ind’ group.
‘R_ReplDLLinit()’ initializes the top-level jump so that some embedded applications on Windows no longer crash on error.
‘identical()’ failed to take the encoding of character strings into account, so identical byte patterns are not necessarily identical strings, and similarly Latin-1 and UTF-8 versions of the same string differ in byte pattern.
‘methods(f)’ used to warn unnecessarily for an S4 generic ‘f’ which had been created based on an existing S3 generic.
The check for consistent ordering of superclasses was not ignoring all conditional relations (the symptom was usually spurious warnings for classes extending ‘"array"’).
Trying to assign into a raw vector with an index vector containing ‘NA’s could cause a segfault. Reported by Hervé Pagès.
‘Rscript’ could segfault if (by user error) its filename argument was missing. Reported by Martin Morgan.
‘getAnywhere()’ (and functions that use it, including argument completion in the console) did not handle special built-in functions. Reported by Romain Francois.
‘order()’ was missing a ‘PROTECT()’ call and so could segfault when called on character data under certain (rare) circumstances involving marked non-native encodings.
‘prettyNum(z, drop0trailing=TRUE)’ did not work correctly when ‘z’ was a complex vector. Consequently, ‘str(z, ...)’ also did not. (PR#13985)
‘make distclean’ removed too many files in ‘etc/’ if builddir = srcdir.
‘R CMD’ replaced ‘TEXINPUTS’ rather than appending to it (as documented and intended).
‘help.start()’ no longer fails on unix when ‘"browser"’ is a function.
‘pbeta(x, ..., log.p = TRUE)’ is sometimes more accurate, e.g., for very small ‘x’.
Unserializing a pre-2.8 workspace containing pure ASCII character objects with a Latin-1 or UTF-8 encoding would corrupt the ‘CHARSXP’ cache.
Complex arithmetic (notably ‘z^n’ for complex ‘z’ and integer ‘n’) gave
incorrect results since R 2.10.0 on platforms without C99 complex
support. This and some lesser issues in trignometric functions have
been corrected.
Such platforms were rare (we know of Cygwin and FreeBSD). However, because of new compiler optimizations in the way complex arguments are handled, the same code was selected on x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
There is a workaround for crashes seen with several packages on systems
using ‘zlib 1.2.5’: see the INSTALLATION section.
PCRE has been updated to 8.12 (two bug-fix releases since 8.10).
‘rep()’, ‘seq()’, ‘seq.int()’ and ‘seq_len()’ report more often when
the first element is taken of an argument of incorrect length.
The Cocoa back-end for the ‘quartz()’ graphics device on Mac OS X
provides a way to disable event loop processing temporarily (useful,
e.g., for forked instances of R).
‘kernel()’'s default for ‘m’ was not appropriate if ‘coef’ was a set of
coefficients. (Reported by Pierre Chausse.)
‘bug.report()’ has been updated for the current R bug tracker, which
does not accept emailed submissions.
‘R CMD check’ now checks for the correct use of ‘$(LAPACK_LIBS)’ (as
well as ‘$(BLAS_LIBS)’), since several CRAN recent submissions have
ignored ‘Writing R Extensions’.
The ‘zlib’ sources in the distribution are now built with all symbols
remapped: this is intended to avoid problems seen with packages such as
‘XML’ and ‘rggobi’ which link to ‘zlib.so.1’ on systems using ‘zlib
1.2.5’.
The default for ‘FFLAGS’ and ‘FCFLAGS’ with ‘gfortran’ on x86_64 Linux
has been changed back to ‘-g -O2’: however, setting ‘-g -O’ may still
be needed for ‘gfortran 4.3.x’.
A ‘LazyDataCompression’ field in the ‘DESCRIPTION’ file will be used to
set the value for the ‘--data-compress’ option of ‘R CMD INSTALL’.
Files ‘R/sysdata.rda’ of more than 1Mb are now stored in the lazyload
database using ‘xz’ compression: this for example halves the installed
size of package ‘Imap’.
‘R CMD INSTALL’ now ensures that directories installed from ‘inst’ have
search permission for everyone.
It no longer installs files ‘inst/doc/Rplots.ps’ and ‘inst/doc/Rplots.pdf’. These are almost certainly left-overs from ‘Sweave’ runs, and are often large.
The ‘experimental’ alternative specification of a name space via
‘.Export()’ etc is now deprecated.
‘zip.file.extract()’ is now deprecated.
Zip-ing data sets in packages (and hence ‘R CMD INSTALL --use-zip-data’
and the ‘ZipData: yes’ field in a ‘DESCRIPTION’ file) is deprecated:
using efficiently compressed ‘.rda’ images and lazy-loading of data has
superseded it.
‘identical()’ could in rare cases generate a warning about non-pairlist
attributes on CHARSXPs. As these are used for internal purposes, the
attribute check should be skipped. (Reported by Niels Richard Hansen).
If the filename extension (usually ‘.Rnw’) was not included in a call
to ‘Sweave()’, source references would not work properly and the
‘keep.source’ option failed. (PR#14459)
‘format.data.frame()’ now keeps zero character column names.
‘pretty(x)’ no longer raises an error when ‘x’ contains solely
non-finite values. (PR#14468)
The ‘plot.TukeyHSD()’ function now uses a line width of 0.5 for its
reference lines rather than ‘lwd = 0’ (which caused problems for some
PDF and PostScript viewers).
The ‘big.mark’ argument to ‘prettyNum()’, ‘format()’, etc. was inserted
reversed if it was more than one character long.
‘R CMD check’ failed to check the filenames under ‘man’ for Windows'
reserved names.
The ‘"Date"’ and ‘"POSIXt"’ methods for ‘seq()’ could overshoot when
‘to’ was supplied and ‘by’ was specified in months or years.
The internal method of ‘untar()’ now restores hard links as file copies
rather than symbolic links (which did not work for cross-directory
links).
‘unzip()’ did not handle zip files which contained filepaths with two
or more leading directories which were not in the zipfile and did not
already exist. (It is unclear if such zipfiles are valid and the
third-party C code used did not support them, but PR#14462 created
one.)
‘combn(n, m)’ now behaves more regularly for the border case m = 0.
(PR#14473)
The rendering of numbers in plotmath expressions (e.g.
‘expression(10^2)’) used the current settings for conversion to strings
rather than setting the defaults, and so could be affected by what has
been done before. (PR#14477)
The methods of ‘napredict()’ and ‘naresid()’ for ‘na.action =
na.exclude’ fits did not work correctly in the very rare event that
every case had been omitted in the fit. (Reported by Simon Wood.)
‘weighted.residuals(drop0=TRUE)’ returned a vector when the residuals
were a matrix (e.g. those of class ‘"mlm"’). (Reported by Bill
Dunlap.)
Package HTML index files ‘<pkg>/html/00Index.html’ were generated with
a stylesheet reference that was not correct for static browsing in
libraries.
‘ccf(na.action = na.pass)’ was not implemented.
The parser accepted some incorrect numeric constants, e.g. ‘20x2’.
(Reported by Olaf Mersmann.)
‘format(*, zero.print)’ did not always replace the full zero parts.
Fixes for subsetting or subassignment of ‘"raster"’ objects when not
both ‘i’ and ‘j’ are specified.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a
‘DESCRIPTION’ file (although this is frequently incorrectly specified
for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
‘source(file, echo=TRUE)’ could fail if the file contained ‘#line’
directives. It now recovers more gracefully, but may still display the
wrong line if the directive gives incorrect information.
‘atan(1i)’ returned ‘NaN+Infi’ (rather than ‘0+Infi’) on platforms
without C99 complex support.
‘library()’ failed to cache S4 metadata (unlike ‘loadNamespace()’)
causing failures in S4-using packages without a namespace (e.g. those
using reference classes).
The function ‘qlogis(lp, log.p=TRUE)’ no longer prematurely overflows
to ‘Inf’ when exp(lp) is close to 1.
Updating S4 methods for a group generic function requires resetting the
methods tables for the members of the group (patch contributed by
Martin Morgan).
In some circumstances (including for package ‘XML’), ‘R CMD INSTALL’
installed version-control directories from source packages.
Added ‘PROTECT’ calls to some constructed expressions used in C level
‘eval’ calls.
‘utils:::create.post()’ (used by ‘bug.report()’ and ‘help.request()’)
failed to quote arguments to the mailer, and so often failed.
‘bug.report()’ was naive about how to extract maintainer email
addresses from package descriptions, so would often try mailing to
incorrect addresses.
‘debugger()’ could fail to read the environment of a call to a function
with a ‘...’ argument. (Reported by Charlie Roosen.)
‘prettyNum(c(1i, NA), drop0=TRUE)’ or ‘str(NA_complex_)’ now work
correctly.
The DVI/PDF reference manual now includes the help pages for all the
standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously
omitted (intentionally).
<URL: http://www.rforge.net> has been added to the default set of
repositories known to ‘setRepositories()’.
xz-utils has been updated to version 5.0.0.
‘reshape()’ now makes use of ‘sep’ when forming names during reshaping
to wide format. (PR#14435)
‘legend()’ allows the length of lines to be set by the end user _via_
the new argument ‘seg.len’.
New S4 reference class utility methods ‘copy()’, ‘field()’,
‘getRefClass()’ and ‘getClass()’ have been added to package ‘methods’.
When a character value is used for the ‘EXPR’ argument in ‘switch()’, a
warning is given if more than one unnamed alternative value is given.
This will become an error in R 2.13.0.
‘StructTS(type = "BSM")’ now allows series with just two seasons.
(Reported by Birgit Erni.)
The PDF reference manual is now built as PDF version 1.5 with object
compression, which on platforms for which this is not the default
(notably MiKTeX) halves its size.
Variable ‘FCLIBS’ can be set during configuration, for any additional
library flags needed when linking a shared object with the Fortran 9x
compiler. (Needed with Solaris Studio 12.2.)
‘seq.int()’ no longer sometimes evaluates arguments twice. (PR#14388)
The ‘data.frame’ method of ‘format()’ failed if a column name was
longer than 256 bytes (the maximum length allowed for an R name).
‘predict(<lm object>, type ="terms", ...)’ failed if both ‘terms’ and
‘interval’ were specified. (Reported by Bill Dunlap.)
Also, if ‘se.fit = TRUE’ the standard errors were reported for all terms, not just those selected by a non-null ‘terms’.
The TRE regular expressions engine could terminate R rather than give
an error when given certain invalid regular expressions. (PR#14398)
‘cmdscale(eig = TRUE)’ was documented to return n-1 eigenvalues but in
fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add = TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points. Its return value was described wrongly (it is always a list and contains component ‘ac’).
‘promptClass()’ in package ‘methods’ now works for reference classes
and gives a suitably specialized skeleton of documentation.
Also, ‘callSuper()’ now works via the ‘methods()’ invocation as well as for initially specified methods.
‘download.file()’ could leave the destination file open if the URL was
not able to be opened. (PR#14414)
Assignment of an environment to functions or as an attribute to other
objects now works for S4 subclasses of ‘"environment"’.
Use of ‘[[<-’ for S4 subclasses of ‘"environment"’ generated an
infinite recursion from the method. The method has been replaced by
internal code.
In a reference class S4 method, ‘callSuper()’ now works in
‘initialize()’ methods when there is no explicit superclass method.
‘!’ dropped attributes such as names and dimensions from a length-zero
argument. (PR#14424)
When ‘list2env()’ created an environment it was missing a ‘PROTECT’
call and so was vulnerable to garbage collection.
‘Sweave()’ with ‘keep.source=TRUE’ dropped comments at the start and
end of code chunks. It could also fail when ‘\SweaveInput’ was
combined with named chunks.
The Fortran code used by ‘nls(algorithm = "port")’ could infinite-loop
when compiled with high optimization on a modern version of ‘gcc’, and
‘SAFE_FFLAGS’ is now used to make this less likely. (PR#14427, seen
with 32-bit Windows using ‘gcc 4.5.0’ used from R 2.12.0.)
‘sapply()’ with default ‘simplify = TRUE’ and ‘mapply()’ with default
‘SIMPLIFY = TRUE’ wrongly simplified language-like results, as, e.g.,
in ‘mapply(1:2, c(3,7), FUN = function(i,j) call(':',i,j))’.
Backreferences to undefined patterns in ‘[g]sub(pcre = TRUE)’ could
cause a segfault. (PR#14431)
The ‘format()’ (and hence the ‘print()’) method for class ‘"Date"’
rounded fractional dates towards zero: it now always rounds them down.
Reference S4 class creation could generate ambiguous inheritance
patterns under very special circumstances.
‘[[<-’ turned S4 subclasses of ‘"environment"’ into plain environments.
Long titles for help pages were truncated in package indices and a few
other places.
Additional utilities now work correctly with S4 subclasses of
‘"environment"’ (‘rm’, locking tools and active bindings).
‘spec.ar()’ now also work for the ‘"ols"’ method. (Reported by
Hans-Ruedi Kuensch.)
The initialization of objects from S4 subclasses of ‘"environment"’ now
allocates a new environment object.
‘R CMD check’ has more protection against (probably erroneous) example
or test output which is invalid in the current locale.
‘qr.X()’ with column names and pivoting now also pivots the column
names. (PR#14438)
‘unit.pmax()’ and ‘unit.pmin()’ in package ‘grid’ gave incorrect
results when all inputs were of length 1. (PR#14443)
The parser for ‘NAMESPACE’ files ignored misspelled directives, rather
than signalling an error. For 2.12.x a warning will be issued, but
this will be correctly reported as an error in later releases.
(Reported by Charles Berry.)
Fix for subsetting of ‘"raster"’ objects when only one of ‘i’ or ‘j’ is
specified.
‘grid.raster()’ in package ‘grid’ did not accept ‘"nativeRaster"’
objects (like ‘rasterImage()’ does).
Rendering raster images in PDF output was resetting the clipping
region.
Rendering of raster images on Cairo X11 device was wrong, particularly
when a small image was being scaled up using interpolation.
With Cairo < 1.6, will be better than before, though still a little clunky. With Cairo >= 1.6, should be sweet as.
Several bugs fixed in ‘read.DIF()’: single column inputs caused errors,
cells marked as ‘"character"’ could be converted to other types, and
(in Windows) copying from the clipboard failed.
Reading a package's ‘CITATION’ file now defaults to ASCII rather than
Latin-1: a package with a non-ASCII ‘CITATION’ file should declare an
encoding in its ‘DESCRIPTION’ file and use that encoding for the
‘CITATION’ file.
‘difftime()’ now defaults to the ‘"tzone"’ attribute of ‘"POSIXlt"’
objects rather than to the current timezone as set by the default for
the ‘tz’ argument. (Wish of PR#14182.)
‘pretty()’ is now generic, with new methods for ‘"Date"’ and ‘"POSIXt"’
classes (based on code contributed by Felix Andrews).
‘unique()’ and ‘match()’ are now faster on character vectors where all
elements are in the global ‘CHARSXP’ cache and have unmarked encoding
(ASCII). Thanks to Matthew Dowle for suggesting improvements to the
way the hash code is generated in ‘unique.c’.
The ‘enquote()’ utility, in use internally, is exported now.
‘.C()’ and ‘.Fortran()’ now map non-zero return values (other than
‘NA_LOGICAL’) for logical vectors to ‘TRUE’: it has been an implicit
assumption that they are treated as true.
The ‘print()’ methods for ‘"glm"’ and ‘"lm"’ objects now insert
linebreaks in long calls in the same way that the ‘print()’ methods for
‘"summary.[g]lm"’ objects have long done. This does change the layout
of the examples for a number of packages, e.g. ‘MASS’. (PR#14250)
‘constrOptim()’ can now be used with method ‘"SANN"’. (PR#14245)
It gains an argument ‘hessian’ to be passed to ‘optim()’, which allows all the ‘...’ arguments to be intended for ‘f()’ and ‘grad()’. (PR#14071)
‘curve()’ now allows ‘expr’ to be an object of mode ‘"expression"’ as
well as ‘"call"’ and ‘"function"’.
The ‘"POSIX[cl]t"’ methods for ‘Axis()’ have been replaced by a single
method for ‘"POSIXt"’.
There are no longer separate ‘plot()’ methods for ‘"POSIX[cl]t"’ and ‘"Date"’: the default method has been able to handle those classes for a long time. This _inter alia_ allows a single date-time object to be supplied, the wish of PR#14016.
The methods had a different default (‘""’) for ‘xlab’.
Classes ‘"POSIXct"’, ‘"POSIXlt"’ and ‘"difftime"’ have generators
‘.POSIXct()’, ‘.POSIXlt()’ and ‘.difftime()’. Package authors are
advised to make use of them (they are available from R 2.11.0) to proof
against planned future changes to the classes.
The ordering of the classes has been changed, so ‘"POSIXt"’ is now the second class. See the document ‘Updating packages for changes in R 2.12.x’ on <URL: http://developer.r-project.org> for the consequences for a handful of CRAN packages.
The ‘"POSIXct"’ method of ‘as.Date()’ allows a timezone to be specified
(but still defaults to UTC).
New ‘list2env()’ utility function as an inverse of
‘as.list(<environment>)’ and for fast multi-‘assign()’ to existing
environment. ‘as.environment()’ is now generic and uses ‘list2env()’
as list method.
There are several small changes to output which ‘zap’ small numbers,
e.g. in printing quantiles of residuals in summaries from ‘"lm"’ and
‘"glm"’ fits, and in test statistics in ‘print.anova()’.
Special names such as ‘"dim"’, ‘"names"’, etc, are now allowed as slot
names of S4 classes, with ‘"class"’ the only remaining exception.
File ‘.Renviron’ can have architecture-specific versions such as
‘.Renviron.i386’ on systems with sub-architectures.
‘installed.packages()’ has a new argument ‘subarch’ to filter on
sub-architecture.
The ‘summary()’ method for ‘packageStatus()’ now has a separate
‘print()’ method.
The default ‘summary()’ method returns an object inheriting from class
‘"summaryDefault"’ which has a separate ‘print()’ method that calls
‘zapsmall()’ for numeric/complex values.
The startup message now includes the platform and if used,
sub-architecture: this is useful where different (sub-)architectures
run on the same OS.
The ‘getGraphicsEvent()’ mechanism now allows multiple windows to
return graphics events, through the new functions
‘setGraphicsEventHandlers()’, ‘setGraphicsEventEnv()’, and
‘getGraphicsEventEnv()’. (Currently implemented in the ‘windows()’ and
‘X11()’ devices.)
‘tools::texi2dvi()’ gains an ‘index’ argument, mainly for use by ‘R CMD
Rd2pdf’.
It avoids the use of ‘texindy’ by ‘texinfo’'s ‘texi2dvi >= 1.157’, since that does not emulate 'makeindex' well enough to avoid problems with special characters (such as ‘(’, ‘{’, ‘!’) in indices.
The ability of ‘readLines()’ and ‘scan()’ to re-encode inputs to marked
UTF-8 strings on Windows since R 2.7.0 is extended to non-UTF-8 locales
on other OSes.
‘scan()’ gains a ‘fileEncoding’ argument to match ‘read.table()’.
‘points()’ and ‘lines()’ gain ‘"table"’ methods to match ‘plot()’.
(Wish of PR#10472.)
‘Sys.chmod()’ allows argument ‘mode’ to be a vector, recycled along
‘paths’.
There are ‘|’, ‘&’ and ‘xor()’ methods for classes ‘"octmode"’ and
‘"hexmode"’, which work bitwise.
Environment variables ‘R_DVIPSCMD’, ‘R_LATEXCMD’, ‘R_MAKEINDEXCMD’,
‘R_PDFLATEXCMD’ are no longer used nor set in an R session. (With the
move to ‘tools::texi2dvi()’, the conventional environment variables
‘LATEX’, ‘MAKEINDEX’ and ‘PDFLATEX’ will be used.
‘options("dvipscmd")’ defaults to the value of ‘DVIPS’, then to
‘"dvips"’.)
New function ‘isatty()’ to see if terminal connections are redirected.
‘summaryRprof()’ returns the sampling interval in component
‘sample.interval’ and only returns in ‘by.self’ data for functions with
non-zero self times.
‘print(x)’ and ‘str(x)’ now indicate if an empty list ‘x’ is named.
‘install.packages()’ and ‘remove.packages()’ with ‘lib’ unspecified and
multiple libraries in ‘.libPaths()’ inform the user of the library
location used with a message rather than a warning.
There is limited support for multiple compressed streams on a file: all
of ‘[bgx]zfile()’ allow streams to be appended to an existing file, but
‘bzfile()’ reads only the first stream.
Function ‘person()’ in package ‘utils’ now uses a given/family scheme
in preference to first/middle/last, is vectorized to handle an
arbitrary number of persons, and gains a ‘role’ argument to specify
person roles using a controlled vocabulary (the MARC relator terms).
Package ‘utils’ adds a new ‘"bibentry"’ class for representing and
manipulating bibliographic information in enhanced BibTeX style,
unifying and enhancing the previously existing mechanisms.
A ‘bibstyle()’ function has been added to the ‘tools’ package with
default JSS style for rendering ‘"bibentry"’ objects, and a mechanism
for registering other rendering styles.
Several aspects of the display of text help are now customizable using
the new ‘Rd2txt_options()’ function. options(‘"help_text_width"’) is
no longer used.
Added ‘\href’ tag to the Rd format, to allow hyperlinks to URLs without
displaying the full URL.
Added ‘\newcommand’ and ‘\renewcommand’ tags to the Rd format, to allow
user-defined macros.
New ‘toRd()’ generic in the ‘tools’ package to convert objects to
fragments of Rd code, and added ‘"fragment"’ argument to ‘Rd2txt()’,
‘Rd2HTML()’, and ‘Rd2latex()’ to support it.
Directory ‘R_HOME/share/texmf’ now follows the TDS conventions, so can
be set as a ‘texmf’ tree (‘root directory’ in MiKTeX parlance).
S3 generic functions now use correct S4 inheritance when dispatching on
an S4 object. See ‘?Methods’, section on “Methods for S3 Generic
Functions” for recommendations and details.
‘format.pval()’ gains a ‘...’ argument to pass arguments such as
‘nsmall’ to ‘format()’. (Wish of PR#9574)
‘legend()’ supports ‘title.adj’. (Wish of PR#13415)
Added support for subsetting ‘"raster"’ objects, plus assigning to a
subset, conversion to a matrix (of colour strings), and comparisons
(‘==’ and ‘!=’).
Added a new ‘parseLatex()’ function (and related functions
‘deparseLatex()’ and ‘latexToUtf8()’) to support conversion of
bibliographic entries for display in R.
Text rendering of ‘\itemize’ in help uses a Unicode bullet in UTF-8 and
most single-byte Windows locales.
Added support for polygons with holes to the graphics engine. This is
implemented for the ‘pdf()’, ‘postscript()’, ‘x11(type="cairo")’,
‘windows()’, and ‘quartz()’ devices (and associated raster formats),
but not for ‘x11(type="Xlib")’ or ‘xfig()’ or ‘pictex()’. The
user-level interface is the ‘polypath()’ function in ‘graphics’ and
‘grid.path()’ in ‘grid’.
File ‘NEWS’ is now generated at installation with a slightly different
format: it will be in UTF-8 on platforms using UTF-8, and otherwise in
ASCII. There is also a PDF version, ‘NEWS.pdf’, installed at the
top-level of the R distribution.
‘kmeans(x, 1)’ now works. Further, ‘kmeans’ now returns between and
total sum of squares.
‘arrayInd()’ and ‘which()’ gain an argument ‘useNames’. For
‘arrayInd’, the default is now false, for speed reasons.
As is done for closures, the default ‘print’ method for the formula
class now displays the associated environment if it is not the global
environment.
A new facility has been added for inserting code into a package without
re-installing it, to facilitate testing changes which can be
selectively added and backed out. See ‘?insertSource’.
New function ‘readRenviron’ to (re-)read files in the format of
‘~/.Renviron’ and ‘Renviron.site’.
‘require()’ will now return ‘FALSE’ (and not fail) if loading the
package or one of its dependencies fails.
‘aperm()’ now allows argument ‘perm’ to be a character vector when the
array has named dimnames (as the results of ‘table()’ calls do).
Similarly, ‘array()’ allows ‘MARGIN’ to be a character vector. (Based
on suggestions of Michael Lachmann.)
Package ‘utils’ now exports and documents functions
‘aspell_package_Rd_files()’ and ‘aspell_package_vignettes()’ for spell
checking package Rd files and vignettes using Aspell, Ispell or
Hunspell.
Package news can now be given in Rd format, and ‘news()’ prefers these
‘inst/NEWS.Rd’ files to old-style plain text ‘NEWS’ or ‘inst/NEWS’
files.
New simple function ‘packageVersion()’.
The PCRE library has been updated to version 8.10.
The standard Unix-alike terminal interface declares its name to
readline as 'R', so that can be used for conditional sections in
‘~/.inputrc’ files.
‘Writing R Extensions’ now stresses that the standard sections in ‘.Rd’
files (other than ‘\alias’, ‘\keyword’ and ‘\note’) are intended to be
unique, and the conversion tools now drop duplicates with a warning.
The ‘.Rd’ conversion tools also warn about an unrecognized type in a ‘\docType’ section.
‘ecdf()’ objects now have a ‘quantile()’ method.
‘format()’ methods for date-time objects now attempt to make use of a
‘"tzone"’ attribute with ‘"%Z"’ and ‘"%z"’ formats, but it is not
always possible. (Wish of PR#14358.)
‘tools::texi2dvi(file, clean = TRUE)’ now works in more cases (e.g.
where emulation is used and when ‘file’ is not in the current
directory).
New function ‘droplevels()’ to remove unused factor levels.
‘system(command, intern = TRUE)’ now gives an error on a Unix-alike (as
well as on Windows) if ‘command’ cannot be run. It reports a
non-success exit status from running ‘command’ as a warning.
On a Unix-alike an attempt is made to return the actual exit status of the command in ‘system(intern = FALSE)’: previously this had been system-dependent but on POSIX-compliant systems the value return was 256 times the status.
‘system()’ has a new argument ‘ignore.stdout’ which can be used to
(portably) ignore standard output.
‘system(intern = TRUE)’ and ‘pipe()’ connections are guaranteed to be
available on all builds of R.
‘Sys.which()’ has been altered to return ‘""’ if the command is not
found (even on Solaris).
A facility for defining reference-based S4 classes (in the OOP style of
Java, C++, etc.) has been added experimentally to package ‘methods’;
see ‘?ReferenceClasses’.
The ‘predict’ method for ‘"loess"’ fits gains an ‘na.action’ argument
which defaults to ‘na.pass’ rather than the previous default of
‘na.omit’.
Predictions from ‘"loess"’ fits are now named from the row names of ‘newdata’.
Parsing errors detected during ‘Sweave()’ processing will now be
reported referencing their original location in the source file.
New ‘adjustcolor()’ utility, e.g., for simple translucent color
schemes.
‘qr()’ now has a trivial ‘lm’ method with a simple (fast) validity
check.
An experimental new programming model has been added to package
‘methods’ for reference (OOP-style) classes and methods. See
‘?ReferenceClasses’.
bzip2 has been updated to version 1.0.6 (bug-fix release).
‘--with-system-bzlib’ now requires at least version 1.0.6.
R now provides ‘jss.cls’ and ‘jss.bst’ (the class and bib style file
for the Journal of Statistical Software) as well as ‘RJournal.bib’ and
‘Rnews.bib’, and ‘R CMD’ ensures that the ‘.bst’ and ‘.bib’ files are
found by BibTeX.
Functions using the ‘TAR’ environment variable no longer quote the
value when making ‘system’ calls. This allows values such as ‘tar
--force-local’, but does require additional quotes in, e.g., ‘TAR =
"'/path with spaces/mytar'"’.
Supplying the parser with a character string containing both octal/hex
and Unicode escapes is now an error.
File extension ‘.C’ for C++ code files in packages is now defunct.
‘R CMD check’ no longer supports configuration files containing Perl
configuration variables: use the environment variables documented in ‘R
Internals’ instead.
The ‘save’ argument of ‘require()’ now defaults to ‘FALSE’ and ‘save =
TRUE’ is now deprecated. (This facility is very rarely actually used,
and was superseded by the ‘Depends’ field of the ‘DESCRIPTION’ file
long ago.)
‘R CMD check --no-latex’ is deprecated in favour of ‘--no-manual’.
‘R CMD Sd2Rd’ is formally deprecated and will be removed in R 2.13.0.
‘install.packages()’ has a new argument ‘libs_only’ to optionally pass
‘--libs-only’ to ‘R CMD INSTALL’ and works analogously for Windows
binary installs (to add support for 64- or 32-bit Windows).
When sub-architectures are in use, the installed architectures are
recorded in the ‘Archs’ field of the ‘DESCRIPTION’ file. There is a
new default filter, ‘"subarch"’, in ‘available.packages()’ to make use
of this.
Code is compiled in a copy of the ‘src’ directory when a package is installed for more than one sub-architecture: this avoid problems with cleaning the sources between building sub-architectures.
‘R CMD INSTALL --libs-only’ no longer overrides the setting of locking,
so a previous version of the package will be restored unless
‘--no-lock’ is specified.
‘R CMD Rprof|build|check’ are now based on R rather than Perl scripts.
The only remaining Perl scripts are the deprecated ‘R CMD Sd2Rd’ and
‘install-info.pl’ (used only if ‘install-info’ is not found) as well as
some maintainer-mode-only scripts.
*NB:* because these have been completely rewritten, users should not expect undocumented details of previous implementations to have been duplicated.
‘R CMD’ no longer manipulates the environment variables ‘PERL5LIB’ and ‘PERLLIB’.
‘R CMD check’ has a new argument ‘--extra-arch’ to confine tests to
those needed to check an additional sub-architecture.
Its check for “Subdirectory 'inst' contains no files” is more thorough: it looks for files, and warns if there are only empty directories.
Environment variables such as ‘R_LIBS’ and those used for customization can be set for the duration of checking _via_ a file ‘~/.R/check.Renviron’ (in the format used by ‘.Renviron’, and with sub-architecture specific versions such as ‘~/.R/check.Renviron.i386’ taking precedence).
There are new options ‘--multiarch’ to check the package under all of the installed sub-architectures and ‘--no-multiarch’ to confine checking to the sub-architecture under which ‘check’ is invoked. If neither option is supplied, a test is done of installed sub-architectures and all those which can be run on the current OS are used.
Unless multiple sub-architectures are selected, the install done by ‘check’ for testing purposes is only of the current sub-architecture (_via_ ‘R CMD INSTALL --no-multiarch’).
It will skip the check for non-ascii characters in code or data if the environment variables ‘_R_CHECK_ASCII_CODE_’ or ‘_R_CHECK_ASCII_DATA_’ are respectively set to ‘FALSE’. (Suggestion of Vince Carey.)
‘R CMD build’ no longer creates an ‘INDEX’ file (‘R CMD INSTALL’ does
so), and ‘--force’ removes (rather than overwrites) an existing ‘INDEX’
file.
It supports a file ‘~/.R/build.Renviron’ analogously to ‘check’.
It now runs build-time ‘\Sexpr’ expressions in help files.
‘R CMD Rd2dvi’ makes use of ‘tools::texi2dvi()’ to process the package
manual. It is now implemented entirely in R (rather than partially as
a shell script).
‘R CMD Rprof’ now uses ‘utils::summaryRprof()’ rather than Perl. It
has new arguments to select one of the tables and to limit the number
of entries printed.
‘R CMD Sweave’ now runs R with ‘--vanilla’ so the environment setting
of ‘R_LIBS’ will always be used.
‘lang5()’ and ‘lang6()’ (in addition to pre-existing ‘lang[1-4]()’)
convenience functions for easier construction of ‘eval()’ calls. If
you have your own definition, do wrap it inside ‘#ifndef lang5 ....
#endif’ to keep it working with old and new R.
Header ‘R.h’ now includes only the C headers it itself needs, hence no
longer includes ‘errno.h’. (This helps avoid problems when it is
included from C++ source files.)
Headers ‘Rinternals.h’ and ‘R_ext/Print.h’ include the C++ versions of
‘stdio.h’ and ‘stdarg.h’ respectively if included from a C++ source
file.
A C99 compiler is now required, and more C99 language features will be
used in the R sources.
Tcl/Tk >= 8.4 is now required (increased from 8.3).
System functions ‘access’, ‘chdir’ and ‘getcwd’ are now essential to
configure R. (In practice they have been required for some time.)
‘make check’ compares the output of the examples from several of the
base packages to reference output rather than the previous output (if
any). Expect some differences due to differences in floating-point
computations between platforms.
File ‘NEWS’ is no longer in the sources, but generated as part of the
installation. The primary source for changes is now ‘doc/NEWS.Rd’.
The ‘popen’ system call is now required to build R. This ensures the
availability of ‘system(intern = TRUE)’, ‘pipe()’ connections and
printing from ‘postscript()’.
The ‘pkg-config’ file ‘libR.pc’ now also works when R is installed
using a sub-architecture.
R has always required a BLAS that conforms to IE60559 arithmetic, but
after discovery of more real-world problems caused by a BLAS that did
not, this is tested more thoroughly in this version.
Calls to ‘selectMethod()’ by default no longer cache inherited methods.
This could previously corrupt methods used by ‘as()’.
The densities of non-central chi-squared are now more accurate in some
cases in the extreme tails, e.g. ‘dchisq(2000, 2, 1000)’, as a series
expansion was truncated too early. (PR#14105)
‘pt()’ is more accurate in the left tail for ‘ncp’ large, e.g.
‘pt(-1000, 3, 200)’. (PR#14069)
The default C function (‘R_binary’) for binary ops now sets the S4 bit
in the result if either argument is an S4 object. (PR#13209)
‘source(echo=TRUE)’ failed to echo comments that followed the last
statement in a file.
S4 classes that contained one of ‘"matrix"’, ‘"array"’ or ‘"ts"’ and
also another class now accept superclass objects in ‘new()’. Also
fixes failure to call ‘validObject()’ for these classes.
Conditional inheritance defined by argument ‘test’ in
‘methods::setIs()’ will no longer be used in S4 method selection
(caching these methods could give incorrect results). See ‘?setIs’.
The signature of an implicit generic is now used by ‘setGeneric()’ when
that does not use a definition nor explicitly set a signature.
A bug in ‘callNextMethod()’ for some examples with ‘"..."’ in the
arguments has been fixed. See file
‘src/library/methods/tests/nextWithDots.R’ in the sources.
‘match(x, table)’ (and hence ‘%in%’) now treat ‘"POSIXlt"’ consistently
with, e.g., ‘"POSIXct"’.
Built-in code dealing with environments (‘get()’, ‘assign()’,
‘parent.env()’, ‘is.environment()’ and others) now behave consistently
to recognize S4 subclasses; ‘is.name()’ also recognizes subclasses.
The ‘abs.tol’ control parameter to ‘nlminb()’ now defaults to ‘0.0’ to
avoid false declarations of convergence in objective functions that may
go negative.
The standard Unix-alike termination dialog to ask whether to save the
workspace takes a EOF response as ‘n’ to avoid problems with a damaged
terminal connection. (PR#14332)
Added ‘warn.unused’ argument to ‘hist.default()’ to allow suppression
of spurious warnings about graphical parameters used with ‘plot=FALSE’.
(PR#14341)
‘predict.lm()’, ‘summary.lm()’, and indeed ‘lm()’ itself had issues
with residual DF in zero-weighted cases (the latter two only in
connection with empty models). (Thanks to Bill Dunlap for spotting the
‘predict()’ case.)
‘aperm()’ treated ‘resize = NA’ as ‘resize = TRUE’.
‘constrOptim()’ now has an improved convergence criterion, notably for
cases where the minimum was (very close to) zero; further, other tweaks
inspired from code proposals by Ravi Varadhan.
Rendering of S3 and S4 methods in man pages has been corrected and made
consistent across output formats.
Simple markup is now allowed in ‘\title’ sections in ‘.Rd’ files.
The behaviour of ‘as.logical()’ on factors (to use the levels) was lost
in R 2.6.0 and has been restored.
‘prompt()’ did not backquote some default arguments in the ‘\usage’
section. (Reported by Claudia Beleites.)
‘writeBin()’ disallows attempts to write 2GB or more in a single call.
(PR#14362)
‘new()’ and ‘getClass()’ will now work if Class is a subclass of
‘"classRepresentation"’ and should also be faster in typical calls.
The ‘summary()’ method for data frames makes a better job of names
containing characters invalid in the current locale.
‘[[’ sub-assignment for factors could create an invalid factor
(reported by Bill Dunlap).
‘Negate(f)’ would not evaluate argument ‘f’ until first use of returned
function (reported by Olaf Mersmann).
‘quietly=FALSE’ is now also an optional argument of ‘library()’, and
consequently, ‘quietly’ is now propagated also for loading dependent
packages, e.g., in ‘require(*, quietly=TRUE)’.
If the loop variable in a ‘for’ loop was deleted, it would be recreated
as a global variable. (Reported by Radford Neal; the fix includes his
optimizations as well.)
Task callbacks could report the wrong expression when the task involved
parsing new code. (PR#14368)
‘getNamespaceVersion()’ failed; this was an accidental change in
2.11.0. (PR#14374)
‘identical()’ returned ‘FALSE’ for external pointer objects even when
the pointer addresses were the same.
‘L$a@x[] <- val’ did not duplicate in a case it should have.
‘tempfile()’ now always gives a random file name (even if the directory
is specified) when called directly after startup and before the R RNG
had been used. (PR#14381)
‘quantile(type=6)’ behaved inconsistently. (PR#14383)
‘backSpline(.)’ behaved incorrectly when the knot sequence was
decreasing. (PR#14386)
The reference BLAS included in R was assuming that ‘0*x’ and ‘x*0’ were
always zero (whereas they could be ‘NA’ or ‘NaN’ in IEC 60559
arithmetic). This was seen in results from ‘tcrossprod’, and for
example that ‘log(0) %*% 0’ gave ‘0’.
The calculation of whether text was completely outside the device
region (in which case, you draw nothing) was wrong for screen devices
(which have [0, 0] at top-left). The symptom was (long) text
disappearing when resizing a screen window (to make it smaller).
(PR#14391)
‘model.frame(drop.unused.levels = TRUE)’ did not take into account ‘NA’
values of factors when deciding to drop levels. (PR#14393)
‘library.dynam.unload’ required an absolute path for ‘libpath’.
(PR#14385)
Both ‘library()’ and ‘loadNamespace()’ now record absolute paths for use by ‘searchpaths()’ and ‘getNamespaceInfo(ns, "path")’.
The self-starting model ‘NLSstClosestX’ failed if some deviation was
exactly zero. (PR#14384)
‘X11(type = "cairo")’ (and other devices such as ‘png’ using
cairographics) and which use Pango font selection now work around a bug
in Pango when very small fonts (those with sizes between 0 and 1 in
Pango's internal units) are requested. (PR#14369)
Added workaround for the font problem with ‘X11(type = "cairo")’ and
similar on Mac OS X whereby italic and bold styles were interchanged.
(PR#13463 amongst many other reports.)
‘source(chdir = TRUE)’ failed to reset the working directory if it
could not be determined - that is now an error.
Fix for crash of ‘example(rasterImage)’ on ‘x11(type="Xlib")’.
Force Quartz to bring the on-screen display up-to-date immediately
before the snapshot is taken by ‘grid.cap()’ in the Cocoa
implementation. (PR#14260)
‘model.frame’ had an unstated 500 byte limit on variable names.
(Example reported by Terry Therneau.)
The 256-byte limit on names is now documented.
Subassignment by ‘[’, ‘[[’ or ‘$’ on an expression object with value
‘NULL’ coerced the object to a list.
‘install.packages()’ has a new optional argument ‘INSTALL_opts’ which
can be used to pass options to ‘R CMD INSTALL’ for source-package
installs.
‘R CMD check’ now runs the package-specific tests with ‘LANGUAGE=en’ to
facilitate comparison to ‘.Rout.save’ files.
‘sessionInfo()’ gives more detailed platform information, including
32/64-bit and the sub-architecture if one is used.
The use of Perl configuration variables for ‘R CMD check’ (as
previously documented in ‘Writing R Extensions’) is deprecated and will
be removed in R 2.12.0. Use the environment variables documented in ‘R
Internals’ instead.
‘R CMD Rd2dvi’ failed if run from a path containing space(s). This
also affected ‘R CMD check’, which calls ‘Rd2dvi’.
‘stripchart()’ could fail with an empty factor level. (PR#14317)
Text help rendering of ‘\tabular{}’ has been improved: under some
circumstances leading blank columns were not rendered.
‘strsplit(x, fixed=TRUE)’ marked UTF-8 strings with the local encoding
when no splits were found.
‘weighted.mean(NA, na.rm=TRUE)’ and similar now returns ‘NaN’ again, as
it did prior to R 2.10.0.
‘R CMD’ had a typo in its detection of whether the environment variable
‘TEXINPUTS’ was set (reported by Martin Morgan).
The command-line parser could mistake ‘--file=size...’ for one of the
options for setting limits for Ncells or Vcells.
The internal ‘strptime()’ could corrupt its copy of the timezone which
would then lead to spurious warnings. (PR#14338)
‘dir.create(recursive = TRUE)’ could fail if one of the components
existed but was a directory on a read-only file system. (Seen on
Solaris, where the error code returned is not even listed as possible
on the man page.)
The ‘postscript()’ and ‘pdf()’ devices will now allow ‘lwd’ values less
than 1 (they used to force such values to be 1).
Fixed font face for CID fonts in ‘pdf()’ graphics output. (PR#14326)
‘GERaster()’ now checks for width or height of zero and does nothing in
those cases; previously the behaviour was undefined, probably
device-specific, and possibly dangerous.
‘wilcox.test(x, y, conf.int = TRUE)’ failed with an unhelpful message
if ‘x’ and ‘y’ were constant vectors, and similarly in the one-sample
case. (PR#14329)
Improperly calling ‘Recall()’ from outside a function could cause a
segfault. (Reported by Robert McGehee.)
‘\Sexpr[result=rd]’ in an Rd file added a spurious newline, which was
displayed as extra whitespace when rendered.
‘require(save = TRUE)’ recorded the names of packages it failed to
load.
‘packageStatus()’ could return a data frame with duplicate row names
which could then not be printed.
‘txtProgressBar(style = 2)’ did not work correctly.
‘txtProgressBar(style = 3)’ did not display until a non-minimum value was set.
‘contour()’ did not display dashed line types properly when contour
lines were labelled. (Reported by David B. Thompson.)
‘tools::undoc()’ again detects undocumented data objects. Of course,
this also affects ‘R CMD check’.
‘ksmooth(x,NULL)’ no longer segfaults.
‘approxfun()’, ‘approx()’, ‘splinefun()’ and ‘spline()’ could be
confused by ‘x’ values that were different but so close as to print
identically. (PR#14377)
‘R CMD INSTALL’ checks if dependent packages are available early on in
the installation of source packages, thereby giving clearer error
messages.
‘R CMD INSTALL --build’ now names the file in the format used for Mac
OS X binary files on that platform.
‘BIC()’ in package ‘stats4’ now also works with multiple fitted models,
analogously to ‘AIC()’.
Use of file extension ‘.C’ for C++ code in packages is now deprecated:
it has caused problems for some ‘make’s on case-insensitive file
systems (although it currently works with the recommended toolkits).
Command ‘gnutar’ is preferred to ‘tar’ when configure sets ‘TAR’. This
is needed on Mac OS 10.6, where the default ‘tar’, ‘bsdtar 2.6.2’, has
been reported to produce archives with illegal extensions to tar
(according to the POSIX standard).
The C function ‘mkCharLenCE’ now no longer reads past ‘len’ bytes
(unlikely to be a problem except in user code). (PR#14246)
On systems without any default ‘LD_LIBRARY_PATH’ (not even
‘/usr/local/lib’), ‘[DY]LIB_LIBRARY_PATH’ is now set without a trailing
colon. (PR#13637)
More efficient implementation of ‘utf8ToInt()’ on long multi-byte
strings with many multi-byte characters. (PR#14262)
‘aggregate.ts()’ gave platform-dependent results due to rounding error
for ‘ndeltat != 1’.
‘package.skeleton()’ sometimes failed to fix filenames for ‘.R’ or
‘.Rd’ files to start with an alphanumeric. (PR#14253)
It also failed when only an S4 class without any methods was defined. (PR#14280)
‘splinefun(method = ‘"monoH.FC"’)’ was not quite monotone in rare
cases. (PR#14215)
‘Rhttpd’ no longer crashes due to ‘SIGPIPE’ when the client closes the
connection prematurely. (PR#14266)
‘format.POSIXlt()’ could cause a stack overflow and crash when used on
very long vectors. (PR#14267)
‘Rd2latex()’ incorrectly escaped special characters in ‘\usage’
sections.
‘mcnemar.test()’ could alter the levels (dropping unused levels) if
passed ‘x’ and ‘y’ as factors (reported by Greg Snow).
‘Rd2pdf’ sometimes needed a further ‘pdflatex’ pass to get hyperlinked
pages correct.
‘interaction()’ produced malformed results when levels were duplicated,
causing segfaults in ‘split()’.
‘cut(d, breaks = <n>)’ now also works for ‘"Date"’ or ‘"POSIXt"’
argument ‘d’. (PR#14288)
‘memDecompress()’ could decompress incompletely rare ‘xz’-compressed
input due to incorrect documentation of ‘xz utils’. (Report and patch
from Olaf Mersmann.)
The S4 ‘initialize()’ methods for ‘"matrix"’, ‘"array"’, and ‘"ts"’
have been fixed to call ‘validObject()’. (PR#14284)
‘R CMD INSTALL’ now behaves the same way with or without
‘--no-multiarch’ on platforms with only one installed architecture.
(It used to clean the ‘src’ directory without ‘--no-multiarch’.)
‘[<-.data.frame’ was not quite careful enough in assigning (and
potentially deleting) columns right-to-left. (PR#14263)
‘rbeta(n, a, b)’ no longer occasionally returns ‘NaN’ for ‘a >> 1 > b’.
(PR#14291)
‘pnorm(x, log.p = TRUE)’ could return ‘NaN’ not ‘-Inf’ for ‘x’ near
(minus for ‘lower.tail=TRUE’) the largest representable number.
Compressed data files ‘*.(txt|tab|csv).(gz|bz2|xz)’ were not recognized
for the list of data topics and hence for packages using ‘LazyData’.
(PR#14273)
‘textConnection()’ did an unnecessary translation on strings in a
foreign encoding (e.g. UTF-8 strings on Windows) and so was slower than
it could have been on very long input strings. (PR#14286)
‘tools::Rd2txt()’ did not render poorly written Rd files consistently
with other renderers.
It computed widths of strings that would be ‘print()’ed with escapes incorrectly, for example in the computation of column width for ‘\tabular’.
‘na.action()’ did not extract the ‘na.action’ component as documented.
‘do.call()’ing ‘NextMethod’ in erronous ways no longer segfaults.
(PR#13487)
Packages must have been installed under R >= 2.10.0, as the current
help system is the only one now supported.
A port to 64-bit Windows is now available as well as binary package
repositiories: see the ‘R Administration and Installation Manual’.
Argument matching for primitive functions is now done in the same way
as for interpreted functions except for the deliberate exceptions
call switch .C .Fortran .Call .External
all of which use positional matching for their first argument, and also some internal-use-only primitives.
The default device for command-line R at the console on Mac OS X is now
‘quartz()’ and not ‘X11()’.
The ‘open’ modes for connections are now interpreted more consistently.
‘open = "r"’ is now equivalent to ‘open = "rt"’ for all connections.
The default ‘open = ""’ now means ‘"rt"’ for all connections except the
compressed-file connections ‘gzfile()’, ‘bzfile()’ and ‘xzfile()’ for
which it means ‘"rb"’.
‘R CMD INSTALL’ now uses the internal ‘untar()’ function in package
‘utils’: this ensures that all platforms can install ‘bzip2’- and
‘xz’-compressed tarballs. In case this causes problems (as it has on
some Windows file systems when run from Cygwin tools) it can be
overridden by the environment variable ‘R_INSTALL_TAR’: setting this to
a modern external tar program will speed up unpacking of large (tens of
Mb or more) tarballs.
‘help(try.all.packages = TRUE)’ is much faster (although the time taken
by the OS to find all the packages the first time it is used can
dominate the time).
‘R CMD check’ has a new option ‘--timings’ to record per-example
timings in file ‘<pkg>.Rcheck/<pkg>-Ex.timings’.
The TRE library has been updated to version 0.8.0 (minor bugfixes).
‘grep[l]’, ‘[g]sub’ and ‘[g]regexpr’ now work in bytes in an 8-bit
locales if there is no marked UTF-8 input string: this will be somewhat
faster, and for ‘[g]sub()’ give the result in the native encoding
rather than in UTF-8 (which returns to the behaviour prior to R
2.10.0).
A new argument ‘skipCalls’ has been added to ‘browser()’ so that it can
report the original context when called by other debugging functions.
More validity checking of UTF-8 and MBCS strings is done by ‘agrep()’
and the regular-expression matching functions.
The undocumented restriction on ‘gregexpr()’ to ‘length(text) > 0’ has
been removed.
Package ‘tcltk’ now sends strings to Tcl in UTF-8: this means that
strings with a marked UTF-8 encoding are supported in non-UTF-8
locales.
The graphics engine now supports rendering of raster (bitmap) images,
though not all graphics devices can provide (full) support. Packages
providing graphics devices (e.g., ‘Cairo’, ‘RSvgDevice’, ‘cairoDevice’)
will need to be reinstalled.
There is also support in the graphics engine for capturing raster images from graphics devices (again not supported on all graphics devices).
‘R CMD check’ now also checks if the package and namespace can be
unloaded: this provides a check of the ‘.Last.lib()’ and ‘.onUnload()’
hook functions (unless ‘--install=fake’).
‘prop.table(x)’ now accepts a one-dimensional table for ‘x’.
A new function ‘vapply()’ has been added, based on a suggestion from
Bill Dunlap. It requires that a template for the function value be
specified, and uses it to determine the output type and to check for
consistency in the function values.
The main HTML help page now links to a reformatted copy of this ‘NEWS’
file. (Suggested by Henrik Bengtsson.) Package index files link to
the package ‘DESCRIPTION’ and ‘NEWS’ files and a list of demos when
using dynamic help.
The ‘[’ method for class ‘"AsIs"’ allows the next method to change the
underlying class. (Wish of Jens Oehlschlägel.)
‘write.csv[2]’ no longer allow argument ‘append’ to be changed: as
ever, direct calls to ‘write.table()’ give more flexibility as well as
more room for error.
The index page for HTML help for a package now collapses multiple
signatures for S4 methods into a single entry.
The use of ‘.required’ by ‘require()’ and ‘detach()’ has been replaced
by ‘.Depends’ which is set from the ‘Depends’ field of a package (even
in packages with name spaces). By default ‘detach()’ prevents such
dependencies from being detached: this can be overridden by the
argument ‘force’.
‘bquote()’ has been extended to work on function definitions. (Wish of
PR#14031).
‘detach()’ when applied to an object other than a package returns the
environment that has been detached, to parallel ‘attach()’.
‘readline()’ in non-interactive use returns ‘""’ and does not attempt
to read from the ‘terminal’.
New function ‘file_ext()’ in package ‘tools’.
‘xtfrm()’ is now primitive and internally generic, as this allows S4
methods to be set on it without name-space scoping issues.
There are now ‘"AsIs"’ and ‘"difftime"’ methods, and the default method uses ‘unclass(x)’ if ‘is.numeric(x)’ is true (which will be faster but relies on ‘is.numeric()’ having been set correctly for the class).
‘is.numeric(x)’ is now false for a ‘"difftime"’ object (multiplication
and division make no sense for such objects).
The default method of ‘weighted.mean(x, w)’ coerces ‘w’ to be numeric
(aka double); previously only integer weights were coerced. Zero
weights are handled specially so an infinite value with zero weight
does not force an ‘NaN’ result.
There is now a ‘"difftime"’ method.
‘bug.report()’ now has arguments ‘package’ and ‘lib.loc’ to generate
bug reports about packages. When this is used, it looks for a
‘BugReports’ field in the package ‘DESCRIPTION’ file, which will be
assumed to be a URL at which to submit the report, and otherwise
generates an email to the package maintainer. (Suggested by Barry
Rowlingson.)
‘quantile()’ now has a method for the date-time class ‘"POSIXt"’, and
types 1 and 3 (which never interpolate) work for Dates and ordered
factors.
‘length(<POSIXlt>)’ now returns the length of the corresponding
abstract timedate-vector rather than always 9 (the length of the
underlying list structure). (Wish of PR#14073 and PR#10507.)
The ‘readline’ completion backend no longer sorts possible completions
alphabetically (e.g., function argument names) if R was built with
‘readline >= 6’.
‘select.list()’ gains a ‘graphics’ argument to allow Windows/Mac users
to choose the text interface. This changes the behaviour of
‘new.packages(ask=TRUE)’ to be like ‘update.packages(ask=TRUE)’ on
those platforms in using a text menu: use ask=‘"graphics"’ for a
graphical menu.
New function ‘chooseBioCmirror()’ to set the ‘"BioC_mirror"’ option.
The R grammar now prevents using the argument ‘name’ in signatures of
S4 methods for ‘$’ and ‘$<-’, since they will always be called with a
character string value for ‘name’. The implicit S4 generic functions
have been changed to reflect this: packages which included ‘name’ in
the signature of their methods need to be updated and re-installed.
The handling of the ‘method’ argument of ‘glm()’ has been refined
following suggestions by Ioannis Kosmidis and Heather Turner.
‘str()’ gains a new argument ‘list.len’ with default 99, limiting the
number of ‘list()’ items (per level), thanks to suggestions from David
Winsenius.
Having formal arguments of an S4 method in a different order from the
generic is now an error (the warning having been ignored by some
package maintainers for a long time).
New functions ‘enc2native()’ and ‘enc2utf8()’ convert character vectors
with possibly marked encodings to the current locale and UTF-8
respectively.
Unrecognized escapes and embedded nuls in character strings are now an
error, not just a warning. Thus option ‘"warnEscapes"’ is no longer
needed. ‘rawToChar()’ now removes trailing nuls silently, but other
embedded nuls become errors.
Informational messages about masked objects displayed when a package is
attached are now more compact, using ‘strwrap()’ instead of one object
per line.
‘print.rle()’ gains argument ‘prefix’.
‘download.file()’ gains a ‘"curl"’ method, mainly for use on platforms
which have ‘curl’ but not ‘wget’, but also for some hard-to-access
URLs.
In ‘Rd’, ‘\eqn’ and ‘\deqn’ will render in HTML (and convert to text)
upper- and lower-case Greek letters (entered as ‘\alpha’ ...),
‘\ldots’, ‘...’, ‘\ge’ and ‘\le’.
‘utf8ToInt()’ and ‘intToUtf8()’ now map ‘NA’ inputs to ‘NA’ outputs.
‘file()’ has a new argument ‘raw’ which may help if it is used with
something other than a regular file, e.g. a character device.
New function ‘strtoi()’, a wrapper for the C function ‘strtol’.
‘as.octmode()’ and ‘as.hexmode()’ now allow inputs of length other than
one.
The ‘format()’ and ‘print()’ methods for ‘"octmode"’ now preserve names and dimensions (as those for ‘"hexmode"’ did).
The ‘format()’ methods for classes ‘"octmode"’ and ‘"hexmode"’ gain a ‘width’ argument.
‘seq.int()’ returns an integer result in some further cases where
‘seq()’ does, e.g. ‘seq.int(1L, 9L, by = 2L)’.
Added ‘\subsection{}{}’ macro to Rd syntax, for subsections within
sections.
n-dimensional arrays with dimension names can now be indexed by an
n-column character matrix. The indices are matched against the
dimension names. ‘NA’ indices are propagated to the result. Unmatched
values and ‘""’ are not allowed and result in an error.
‘interaction(drop=TRUE)’ uses less memory (related to PR#14121).
‘summary()’ methods have been added to the ‘"srcref"’ and ‘"srcfile"’
classes, and various encoding issues have been cleaned up.
If option ‘"checkPackageLicense"’ is set to ‘TRUE’ (not currently the
default), users will be asked to agree to non-known-to-be-FOSS package
licences at first use.
Checking ‘setAs(a, b)’ methods only gives a message instead of a
warning, when one of ‘a’ or ‘b’ is unknown.
New function ‘norm()’ to compute a matrix norm. ‘norm()’ and also
‘backsolve()’ and ‘sample()’ have implicit S4 generics.
Files ‘Renviron.site’ and ‘Rprofile.site’ can have
architecture-specific versions on systems with sub-architectures.
‘R CMD check’ now (by default) also checks Rd files for auto-generated
content in need of editing, and missing argument descriptions.
‘aggregate()’ gains a formula method thanks to a contribution by Arni
Magnusson. The data frame method now allows summary functions to
return arbitrarily many values.
‘path.expand()’ now propagates ‘NA’ values rather than converting them
to ‘"NA"’.
‘file.show()’ now disallows ‘NA’ values for file names, headers, and
pager.
The ‘fuzz’ used by ‘seq()’ and ‘seq.int()’ has been reduced from ‘1e-7’
to ‘1e-10’, which should be ample for the double-precision calculations
used in R. It ensures that the fuzz never comes into play with
sequences of integers (wish of PR#14169).
The default value of ‘RSiteSearch(restrict=)’ has been changed to
include vignettes but to exclude R-help. The R-help archives available
have been split, with a new option of ‘"Rhelp10"’ for those from 2010.
New function ‘rasterImage()’ in the ‘graphics’ package for drawing
raster images.
‘stats:::extractAIC.coxph()’ now omits aliased terms when computing the
degrees of freedom (suggestion of Terry Therneau).
‘cor()’ and ‘cov()’ now test for misuse with non-numeric arguments,
such as the non-bug report PR#14207.
‘pchisq(ncp =, log.p = TRUE)’ is more accurate for probabilities near
one. E.g. ‘pchisq(80, 4, ncp=1, log.p=TRUE)’. (Maybe what was meant
in PR#14216.)
‘maintainer()’ has been added, to give convenient access to the name of
the maintainer of a package (contributed by David Scott).
‘sample()’ and ‘sample.int()’ allow zero items to be sampled from a
zero-length input. ‘sample.int()’ gains a default value ‘size=n’ to be
more similar to ‘sample()’.
‘switch()’ returned ‘NULL’ on error (not previously documented on the
help page): it now does so invisibly, analogously to if-without-else.
It is now primitive: this means that argument ‘EXPR’ is always matched to the first argument and there is no danger of partial matching to later named arguments.
Primitive functions ‘UseMethod()’, ‘attr()’, ‘attr<-()’, ‘on.exit()’,
‘retracemem()’ and ‘substitute()’ now use standard argument matching
(rather than positional matching). This means that all multi-argument
primitives which are not internal now use standard argument matching
except where positional matching is desirable (as for ‘switch()’,
‘call()’, ‘.C()’ ...).
All the one-argument primitives now check that any name supplied for
their first argument is a partial match to the argument name as
documented on the help page: this also applies to replacement functions
of two arguments.
‘base::which()’ uses a new ‘.Internal’ function when ‘arr.ind’ is
‘FALSE’ resulting in a 10x speedup. Thanks to Patrick Aboyoun for
implementation suggestions.
Help conversion to text now uses the first part of ‘\enc{}{}’ markup if
it is representable in the current output encoding. On the other hand,
conversion to LaTeX with the default ‘outputEncoding = "ASCII"’ uses
the second part.
A new class ‘"listOfMethods"’ has been introduced to represent the
methods in a methods table, to replace the deprecated class
‘"MethodsList"’.
‘any()’ and ‘all()’ return early if possible. This may speed up
operations on long vectors.
‘strptime()’ now accepts ‘"%z"’ (for the offset from UTC in the RFC822
format of ‘+/-hhmm’).
The PCRE library has been updated to version 8.02, a bug-fix release
which also updates tables to Unicode 5.02.
Functions which may use a graphical ‘select.list()’ (including ‘menu()’
and ‘install.packages()’) now check on a Unix-alike that Tk can be
started (and not just ‘capabilities("tcltk") && capabilities("X11")’).
The parser no longer marks strings containing octal or hex escapes as
being in UTF-8 when entered in a UTF-8 locale.
On platforms with cairo but not Pango (notably Mac OS X) the initial
default ‘X11()’ type is set to ‘"Xlib"’: this avoids several problems
with font selection when done by cairo rather than Pango (at least on
Mac OS X).
New function ‘arrayInd()’ such that ‘which(x, arr.ind = TRUE)’ for an
array 'x' is now equivalent to ‘arrayInd(which(x), dim(x),
dimnames(x))’.
Bundles of packages are defunct.
‘stats::clearNames()’ is defunct: use ‘unname()’.
Basic regular expressions are defunct, and ‘strsplit()’, ‘grep()’,
‘grepl()’, ‘sub()’, ‘gsub()’, ‘regexpr()’ and ‘gregexpr()’ no longer
have an ‘extended’ argument.
‘methods::trySilent()’ is defunct.
‘index.search()’ (which was deprecated in 2.10.0) is no longer exported
and has a different argument list.
Use of multiple arguments to ‘return()’ is now defunct.
The use of ‘UseMethod()’ with more than two arguments is now defunct.
In the ‘methods’ package, the ‘"MethodsList"’ metadata objects which
had been superseded by hash tables (environments) since R 2.8.0 are
being phased out. Objects of this class are no longer assigned or used
as metadata by the package.
‘getMethods()’ is now deprecated, with its internal use replaced by ‘findMethods()’ and other changes. Creating objects from the ‘"MethodsList"’ class is also deprecated.
Parsing strings containing both octal/hex and Unicode escapes now gives
a warning and will become an error in R 2.12.0.
UTF-8 is now used for the reference manual and package manuals. This
requires LaTeX ‘2005/12/01’ or later.
‘configure’ looks for a POSIX compliant ‘tr’, Solaris's ‘/usr/ucb/tr’
having been found to cause ‘Rdiff’ to malfunction.
‘configure’ is now generated with ‘autoconf 2.65’, which works better
on recent systems and on Mac OS X.
Characters in R source which are not translatable to the current locale
are now handled more tolerantly: these will be converted to hex codes
with a warning. Such characters are only really portable if they
appear in comments.
‘R CMD INSTALL’ now tests that the installed package can be loaded (and
backs out the installation if it cannot): this can be suppressed by
‘--no-test-load’. This avoids installing/updating a package that
cannot be used: common causes of failures to load are
missing/incompatible external software and missing/broken dependent
packages.
Package installation on Windows for a package with a ‘src’ directory
now checks if a DLL is created unless there is a ‘src/Makefile.win’
file: this helps catch broken installations where the toolchain has not
reported problems in building the DLL. (Note: this can be any DLL, not
just one named ‘<pkg-name>.dll’.)
Using ‘with()’, ‘eval()’ etc with a list with some unnamed elements now
works. (PR#14035)
The ‘"quick"’ dispatch of S4 methods for primitive functions was not
happening, forcing a search each time. (Dispatch for closures was not
affected.) A side effect is that default values for arguments in a
method that do not have defaults in the generic will now be ignored.
Trying to dispatch S4 methods for primitives during the search for
inherited methods slows that search down and potentially could cause an
infinite recursion. An internal switch was added to turn off all such
methods from ‘findInheritedMethods()’.
R framework installation (on Mac OS X) would not work properly if a
rogue ‘Resources’ directory was present at the top level. Such a
non-symlink will now be renamed to ‘Resources.old’ (and anything
previously named ‘Resources.old’ removed) as part of the framework
installation process.
The checks for conforming S4 method arguments could fail when the
signature of the generic function omitted some of the formal arguments
(in addition to ‘...’). Arguments omitted from the method definition
but conforming (per the documentation) should now be ignored (treated
as ‘"ANY"’) in dispatching.
The computations for S4 method evaluation when ‘...’ was in the
signature could fail, treating ‘...’ as an ordinary symbol. This has
been fixed, for the known cases.
Various ‘ar()’ fitting methods have more protection for singular fits.
‘callNextMethod’ now works again with the ‘drop=’ argument in ‘[’
‘parse()’ and ‘parse_Rd()’ miscounted columns when multibyte UTF-8
characters were present.
Formatting of help pages has had minor improvements: extra blank lines
have been removed from the text format, and empty package labels
removed from HTML.
‘cor(A, B)’ where ‘A’ is n x 1 and ‘B’ a 1-dimensional array segfaulted
or gave an internal error. (The case ‘cor(B, A)’ was PR#7116.)
‘cut.POSIXt()’ applied to a start value after the DST transition on a
DST-change day could give the wrong time for argument ‘breaks’ in units
of days or longer. (PR#14208)
‘do_par()’ ‘UNPROTECT’ed too early (PR#14214)
Subassignment ‘x[[....]] <- y’ didn't check for a zero-length right
hand side, and inserted a rubbish value. (PR#14217)
‘fisher.test()’ no longer gives a P-value *very* slightly > 1, in some
borderline cases.
Internal function ‘matchArgs()’ no longer modifies the general purpose
bits of the ‘SEXP’s that make up the formals list of R functions. This
fixes an invalid error message that would occur when a garbage
collection triggered a second call to matchArgs for the same function
_via_ a finalizer.
‘gsub()’ in 2.10.x could fail from stack overflow for extremely long
strings due to temporary data being allocated on the stack. Also,
‘gsub()’ with ‘fixed=TRUE’ is in some circumstances considerably
faster.
Several primitives, including ‘attributes()’, ‘attr<-()’
‘interactive()’, ‘nargs()’ and ‘proc.time()’, did not check that they
were called with the correct number of arguments.
A potential race condition in ‘list.files()’ when other processes are
operating on the directory has been fixed; the code now dynamically
allocates memory for file listings in a single pass instead of making
an initial count pass.
‘mean(x, trim=, na.rm = FALSE)’ failed to return ‘NA’ if ‘x’ contained
missing values. (Reported by Bill Dunlap.)
Extreme tail behavior of, ‘pbeta()’ {and hence ‘pf()’}, e.g., ‘pbeta(x,
3, 2200, lower.tail=FALSE, log.p=TRUE)’ now returns finite values
instead of jumping to ‘-Inf’ too early. (PR#14230).
‘parse(text=x)’ misbehaved for objects ‘x’ that were not coerced
internally to character, notably symbols. (Reported to R-devel by Bill
Dunlap.)
The internal C function ‘coerceSymbol’ now handles coercion to
character, and warns if coercion fails (rather than silently returning
‘NULL’). This allows a name to be given where a character vector is
required in functions which coerce internally.
The interpretation by ‘strptime()’ of ‘"%c"’ was non-standard (not that
it is ever advisable to use locale- and system-specific input formats).
capabilities(‘"X11"’) now works the same way on Mac OS X as on other
platforms (and as documented: it was always true for R built with
‘--with-aqua’, as the CRAN builds are).
The ‘X11()’ device with cairo but not Pango (notably Mac OS X) now
checks validity of text strings in UTF-8 locales (since Pango does but
cairo it seems does not).
‘read.fwf()’ misread multi-line records when n was specified.
(PR#14241)
‘all.equal(tolerance = e)’ passes the numeric tolerance also to the
comparison of the attributes.
‘pgamma(0, 0)’, a boundary case, now returns 0, its limit from the
left, rather than the limit from the right.
Issuing ‘POST’ requests to the internal web server could stall the
request under certain circumstances.
‘gzcon( <textConnection> )’, an error, no longer damages the connection
(in a way to have it segfault). (PR#14237)
All the results from ‘hist()’ now use the nominal ‘breaks’ not those
adjusted by the numeric ‘fuzz’: in recent versions the nominal ‘breaks’
were reported but the 'density' referred to the intervals used in the
calculation - which mattered very slightly for one of the extreme bins.
(Based on a report by Martin Becker.)
If ‘xy[z].coords’ (used internally by many graphics functions) are
given a list as ‘x’, they now check that the list has suitable names
and give a more informative error message. (PR#13936)
The handling of line textures in the ‘postscript()’ and ‘pdf()’ devices
was set up for round end caps (the only type which existed at the
time): it has now been adjusted for butt endcaps.
‘lchoose(a, k)’ is now defined as ‘log(abs(choose(a,k)))’, analogously
to ‘lfactorial()’.
Although ‘\eqn{}’ in Rd files is defined as a ‘verbatim’ macro, many
packages expected ‘...’ and ‘\ldots’ to be interpreted there (as was
the case in R < 2.10.0), so this is now done (using an ellipsis in HTML
rendering).
Escaping of braces in quoted strings in R-code sections of Rd files is
allowed again. This had been changed for the new Rd format in R 2.10.0
but was only documented on the developer site and was handled
inconsistently by the converters: text and example conversion removed
the escapes but HTML conversion did not.
The PCRE library has been updated to version 8.01, a bug-fix release.
‘tools::readNEWS()’ now accepts a digit as the first character of a
news section.
Using ‘read.table(header=TRUE)’ on a header with an embedded new line
would copy part of the header into the data. (PR#14103)
‘qpois(p = 1, lambda = 0)’ now gives 0 as for all other ‘p’.
(PR#14135)
Functions related to string comparison (e.g. ‘unique()’, ‘match()’)
could cause crashes when used with strings not in the native encoding,
e.g. UTF-8 strings on Windows. (PR#14114 and PR#14125)
‘x[ , drop=TRUE]’ dropped an ‘NA’ level even if it was in use.
The dynamic HTML help system reported the wrong MIME type for the style
sheet.
‘tools::codoc()’ (used by ‘R CMD check’) was missing cases where the
function had no arguments but was documented to have some.
Help links containing special characters (e.g. ‘"?"’) were not
generated correctly when rendered in HTML. (PR#14155)
‘lchoose(a, k)’ no longer wrongly gives ‘NaN’ for negative ‘a’.
‘ks.test()’ could give a p-value that was off by one observation due to
rounding error. (PR#14145)
‘readBin()’/‘readChar()’ when reading millions of character strings in
a single call used excessive amounts of memory (which also slowed them
down).
‘R CMD SHLIB’ could fail if used with paths that were not alphanumeric,
e.g. contained ‘+’. (PR#14168)
‘sprintf()’ was not re-entrant, which potentially caused problems if an
‘as.character()’ method called it.
The ‘quartz()’ device did not restore the clipping region when filling
the background for a new page. This could be observed in multi-page
bitmap output as stale outer regions of the plot.
‘p.adjust(method, n)’ now works correctly for the rare case ‘n >
length(p)’, also when method differs from ‘"bonferroni"’ or ‘"none"’,
thanks to a patch from Gordon Smyth.
‘tools::showNonASCII()’ failed to detect non-ASCII characters if
‘iconv()’ (incorrectly) converted them to different ASCII characters.
(Seen on Windows only.)
‘tcrossprod()’ wrongly failed in some cases when one of the arguments
was a vector and the other a matrix.
‘[cr]bind(..., deparse.level=2)’ was not always giving names when
documented to do so. (Discovered whilst investigating PR#14189.)
‘match(incomparables=<non-NULL>)’ could in rare cases infinite-loop.
‘poisson.test()’ needed to pass argument ‘conf.level’ to
‘binom.test()’. (PR#14195)
The ‘"nls"’ method for ‘df.residual()’ gave incorrect results for
models fitted with ‘na.action = na.exclude’. (PR#14194)
A change to ‘options(scipen=)’ was only implemented when printing next
occurred, even though it should have affected intervening calls to
‘axis()’, ‘contour()’ and ‘filledcontour()’.
‘prettyNum(drop0trailing=TRUE)’ did not handle signs of imaginary parts
of complex numbers correctly (and this was used by ‘str()’: PR#14201).
‘system.time()’ had the ‘sys.child’ component wrong (copied
‘user.child’ instead) on systems with ‘HAVE_GETRUSAGE’. (PR#14210)
Changing both line texture and line cap (end) resulted in the latter to
be omitted form the PDF code. In addition, line cap (end) and join are
now set explicitly in PDF output to ensure correct defaults.
The suppression of auto-rotation in ‘bitmap()’ and ‘dev2bitmap()’ with
the ‘"pdfwrite"’ device was not working correctly.
‘plot(ecdf(), log="x")’ no longer gives an incorrect warning.
‘read.fwf()’ works again when argument ‘file’ is a connection.
Startup files will now be found if their paths exceed 255 bytes.
(PR#14228)
‘contrasts<-’ (in the ‘stats’ package) no longer has an undeclared
dependence on ‘methods’ (introduced in 2.10.0).
The PCRE library has been updated to version 8.00.
‘R CMD INSTALL’ has new options ‘--no-R’, ‘--no-libs’, ‘--no-data’,
‘--no-help’, ‘--no-demo’, ‘--no-exec’, and ‘--no-inst’ to suppress
installation of the specified part of the package. These are intended
for special purposes (e.g. building a database of help pages without
fully installing all packages).
The documented line-length limit of 4095 bytes when reading from the
console now also applies also to ‘parse(file="")’ (which previously had
a limit of around 1024 bytes).
A Bioconductor mirror can be set for use by ‘setRepositories()’ _via_
the option ‘"BioC_mirror"’, e.g. the European mirror can be selected by
‘options(BioC_mirror="http://bioconductor.statistik.tu-dortmund.de")’.
Double-clicking in a ‘tk_select.list()’ list box now selects the item
and closes the list box (as happens on the Windows ‘select.list()’
widget).
‘configure’ will be able to find a usable ‘libtiff’ in some rare
circumstances where it did not previously (where ‘libtiff’ needed to be
linked explicitly against ‘-ljpeg’).
Making ‘refman.pdf’ works around a problem with the indexing with
‘hyperref 6.79d’ and later.
The ‘extended’ argument is deprecated in ‘strsplit()’, ‘grep()’,
‘grepl()’, ‘sub()’, ‘gsub()’, ‘regexpr()’ and ‘gregexpr()’ (not just
the value ‘extended = FALSE’) and will be removed in R 2.11.0.
‘trigamma(x)’ and other ‘psigamma(x, n)’ calls are now accurate for
very large ‘abs(x)’. (PR#14020)
‘[g]sub(perl=FALSE, fixed=FALSE)’ could use excessive stack space when
used with a very long vector containing some non-ASCII strings.
The default method of ‘weighted.mean(na.rm = TRUE)’ did not omit
weights for ‘NA’ observations in 2.10.0. (PR#14032)
‘[g]regexpr(pattern, fixed = TRUE)’ returned match positions in bytes
(not characters) in an MBCS locale if ‘pattern’ was a single byte.
‘[g]sub(fixed = TRUE)’ with a single-byte pattern could conceivably have matched part of a multibyte character in a non-UTF-8 MBCS.
‘findLineNum()’ and ‘setBreakpoint()’ would sometimes fail if the
specified file was not in the current directory.
Package ‘tcltk’'s ‘demo(tkdensity)’ was broken in 2.9.0 when ‘demo()’
was changed to set ‘par(ask = TRUE)’.
‘gsub()’ with backrefs could fail on extremely long strings (hundreds
of thousands of characters) due to integer overflow in a length
calculation.
‘abline(untf=TRUE)’ now uses a better x-grid in log-scale, e.g., for
‘plot(c(1,300), c(1,300), log="xy"); abline(4,1, untf=TRUE)’.
‘detach()’/‘unloadNamespace()’ arrange to flush the package's lazyload
cache of R objects once the package/namespace is no longer needed.
There have been small fixes to the rendering of help, e.g. ‘\command’
is now rendered verbatim (so e.g. ‘--’ is not interpreted, PR#14045).
Also, there are many small changes to help files where the new converters were not rendering them in the same way as before.
‘available.packages()’ would fail when run on a repository with no
packages meeting the filtering conditions. (PR#14042)
‘rep(x, times, each = 2)’ gave invalid results when the ‘times’
argument was a vector longer than ‘x’. Reported by Bill Dunlap.
An error when ‘unloadNamespace()’ attempted to run the ‘.onUnload()’
function gave an error in the reporting function and so was not
reported properly.
Text help rendering did not handle very long input lines properly.
‘promptMethods()’ generated signature documentation improperly.
‘pgamma(x, a, lower.tail=FALSE)’ and ‘qgamma(...)’ are now considerably
more accurate in some regions for very small ‘a’. ‘qgamma()’ now
correctly returns ‘0’ instead of ‘NaN’ in similar extreme cases, and
‘qgamma()’ no longer warns in the case of small ‘a’, see (PR#12324).
‘unname()’ now also removes names from a zero length vector.
Printing results from ‘ls.str()’ no longer evaluates unevaluated calls.
‘complete.cases()’ failed on a 0-column data frame argument.
(Underlies PR#14066.)
It could return nonsensical results if no input determined the number of cases (seen in the no-segfault tests).
An error in ‘nls()’ with a long formula could cause a segfault.
(PR#14059)
‘qchisq(p, df, ncp, lower.tail = FALSE)’ with ‘ncp >= 80’ was
inaccurate for small ‘p’ (as the help page said): it is now less
inaccurate. (In part, PR#13999.)
For ‘ncp’ less than but close to 80, ‘pchisq()’ and ‘qchisq()’ are more accurate for probablilities very close to 1 (a series expansion was truncated slightly too early).
‘pchisq(x, df, ncp)’ can no longer return values just larger than one for large values of ‘ncp’.
‘intToUtf8()’ could fail when asked to produce 10Mb or more strings,
something it was never intended to do: unfortunately Windows crashed R
(other OSes reported a lack of resources). (PR#14068)
‘chisq.test()’ could fail when given argument ‘x’ or ‘y’ which deparsed
to more than one line. (Reported by Laurent Gauthier.)
S4 methods are uncached whenever the name space containing them is
unloaded (by ‘unloadNamespace()’ as well as by ‘detach(unload =
TRUE))’.
The internal record-keeping by ‘dyn.load’/‘dyn.unload’ was incomplete,
which could crash R if a DLL that registered ‘.External’ routines had
earlier been unloaded.
‘bessel[JY](x, nu)’ with ‘nu’ a negative integer (a singular case) is
now correct, analogously to ‘besselI()’, see PR#13556.
‘tools::file_path_as_absolute()’ doubled the file separator when
applied to a file such as ‘"/vmunix"’ or (on Windows) ‘"d:/afile"’ in a
directory for which ‘getwd()’ would return a path with a trailing
separator (largely cosmetic, as reasonable file systems handle such a
path correctly). (Perhaps what was meant by PR#14078.)
‘unsplit(drop = TRUE)’ applied to a data frame failed to pass ‘drop’ to
the computation of row names. (PR#14084)
The ‘"difftime"’ method of ‘mean()’ ignored its ‘na.rm’ argument.
‘tcltk::tk_select.list()’ is now more likely to remove the widget
immediately after selection is complete.
Adding/subtracting a ‘"difftime"’ object to/from a ‘"POSIXt"’ or
‘"Date"’ object works again (it was broken by the addition of
‘Ops.difftime’).
Conversion to latex of an Rd file with no aliases failed.
‘wilcox.test(conf.int=TRUE)’ has achieved.level corrected and, for
‘exact=FALSE’, now returns a ‘estimate’ component which does not depend
on the alternative used.
‘help.search()’ failed when the package argument was specified.
(PR#14113)
‘switch(EXPR = "A")’ now returns ‘NULL’, as does ‘switch(1)’ (which
used to signal an error).
Package help is now converted from ‘Rd’ by the R-based converters that
were first introduced in 2.9.0. This means
• Packages that were installed by R-devel after 2009-08-09 should not be used with earlier versions of R, and most aspects of package help (including the runnable examples) will be missing if they are so used.
• Text, HTML and latex help and examples for packages installed under the new system are converted on-demand from stored parsed Rd files. (Conversions stored in packages installed under R < 2.10.0 are used if no parsed Rd files are found. It is recommended that such packages be re-installed.)
HTML help is now generated dynamically using an HTTP server running in
the R process and listening on the loopback interface.
• Those worried about security implications of such a server can disable it by setting the environment variable ‘R_DISABLE_HTTPD’ to a non-empty value. This disables ‘help.start()’ and HTML help (so text help is shown instead).
• The Java/Javascript search engine has been replaced by an HTML interface to ‘help.search()’. ‘help.start()’ no longer has an argument ‘searchEngine’ as it is no longer needed.
• The HTML help can now locate cross-references of the form ‘\link[pkg]{foo}’ and ‘\link[pkg:foo]{bar}’ where ‘foo’ is an alias in the package, rather than the documented (basename of a) filename (since the documentation has been much ignored).
‘polygon()’, ‘pdf()’ and ‘postscript()’ now have an argument
‘fillOddEven’ (default ‘FALSE’), which controls the mode used for
polygon fills of self-intersecting shapes.
New ‘debugonce()’ function; further, ‘getOption("deparse.max.lines")’
is now observed when debugging, from a code suggestion by John
Brzustowski. (PR#13647/8)
‘plot()’ methods for ‘"stepfun"’ and hence ‘"ecdf"’ no longer plot
points by default for ‘n >= 1000’.
‘[g]sub(perl=TRUE)’ now also supports ‘"\E"’ in order to *end* ‘"\U"’
and ‘"\L"’ case changes, thanks to a patch from Bill Dunlap.
‘factor()’, ‘levels()<-’, etc, now ensure that the resulting factor
levels are unique (as was always the implied intention). Factors with
duplicated levels are still constructible by low-level means, but are
now declared illegal.
New ‘print()’ (S3) method for class ‘"function"’, also used for
auto-printing. Further, ‘.Primitive’ functions now print and
auto-print identically. The new method is based on code suggestions by
Romain François.
The ‘print()’ and ‘toLatex()’ methods for class ‘"sessionInfo"’ now
show the locale in a nicer format and have arguments to suppress locale
information.
In addition to previously only ‘round()’, there are other ‘Math’ group
(S3) methods for ‘"difftime"’, such as ‘floor()’, ‘signif()’, ‘abs()’,
etc.
For completeness, ‘old.packages()’ and ‘available.packages()’ allow
arguments ‘type’ to be specified (you could always specify arguments
‘available’ or ‘contriburl’).
‘available.packages()’ by default only returns information on the
latest versions of packages whose version requirements are satisfied by
the currently running R.
‘tools::write_PACKAGES()’ has a new argument ‘latestOnly’, which
defaults to ‘TRUE’ when only the latest versions in the repository will
be listed in the index.
‘getOption()’ has a new argument ‘default’ that is returned if the
specified option is not set. This simplifies querying a value and
checking whether it is ‘NULL’ or not.
‘parse()’ now warns if the requested encoding is not supported.
The ‘"table"’ method of ‘as.data.frame()’ gains a ‘stringsAsFactors’
argument to allow the classifying factors to be returned as character
vectors rather than the default factor type.
If ‘model.frame.default()’ encounters a character variable where ‘xlev’
indicates a factor, it now converts the variable to a factor (with a
warning).
‘curve()’ now returns a list containing the points that w§ere drawn.
‘spineplot()’ now accepts ‘axes = FALSE’, for consistency with other
functions called by ‘plot.factor()’.
The Kendall and Spearman methods of ‘cor.test()’ can optionally use
continuity correction when not computing exact p-values. (The Kendall
case is the wish of PR#13691.)
R now keeps track of line numbers during execution for code sourced
with ‘options(keep.source = TRUE)’. The source reference is displayed
by debugging functions such as ‘traceback()’, ‘browser()’, ‘recover()’,
and ‘dump.frames()’, and is stored as an attribute on each element
returned by ‘sys.calls()’.
More functions now have an implicit (S4) generic definition.
‘quantile.default()’ now disallows factors (wish of PR#13631) and its
help documents what numeric-like properties its input need to have to
work correctly.
‘weighted.mean()’ is now generic and has ‘"Date"’, ‘"POSIXct"’ and
‘"POSIXlt"’ methods.
Naming subscripts (e.g. ‘x[i=1, j=2]’) in ‘data.frame’ methods for ‘[’
and ‘[[’ now gives a warning. (Names are ignored in the default
method, but could have odd semantics for other methods, and do for the
data.frame ones.)
‘as.data.frame()’ has an ‘"aovproj"’ method. (Wish of PR#13505)
‘as.character(x)’ for numeric ‘x’ no longer produces strings such as
‘"0.30"’, i.e., with trailing zeros. This change also renders levels
construction in ‘factor()’ more consistent.
‘codocClasses()’, which checks consistency of the documentation of S4
class slots, now does so in considerably more cases. The documentation
of inherited slots (from superclasses) is now optional. This affects
‘R CMD check <pkg>’ when the package defines S4 classes.
‘codoc()’ now also checks S4 methods for code/documentation mismatches.
‘for()’, ‘while()’, and ‘repeat()’ loops now always return NULL as
their (invisible) value. This change was needed to address a reference
counting bug without creating performance penalties for some common use
cases.
The ‘print()’ method for ‘ls.str()’ results now obeys an optional
‘digits’ argument.
The ‘method’ argument of ‘glm()’ now allows user-contributed methods.
More general ‘reorder.default()’ replaces functionality of
‘reorder.factor()’ and ‘reorder.character()’.
The function ‘aspell()’ has been added to provide an interface to the
‘Aspell’ spell-checker.
Filters ‘RdTextFilter()’ and ‘SweaveTeXFilter()’ have been added to the
tools package to provide support for ‘aspell()’ or other spell
checkers.
‘xtabs()’ with the new argument ‘sparse = TRUE’ now returns a sparse
Matrix, using package ‘Matrix’.
‘contr.sum()’ etc gain an argument ‘sparse’ which allows sparse
matrices to be returned.
‘contrasts()’ also gains a ‘sparse’ argument which it passes to the actual contrast function if that has a formal argument ‘sparse’.
‘contrasts(f, .) <- val’ now also works when ‘val’ is a sparse Matrix. It is planned that ‘model.matrix()’ will work with such factors ‘f’ in the future.
‘readNEWS()’ will recognize a UTF-8 byte-order mark (BOM) in the ‘NEWS’
file. However, it is safer to use only ASCII code there because not
all editors recognize BOMs.
New utility function ‘inheritedSlotNames()’ for S4 class programming.
‘tabulate()’ now allows NAs to pass through (and be ignored).
If ‘debug()’ is called on an S3 generic function then all methods are
debugged as well.
Outlier symbols drawn by ‘boxplot()’ now obey the ‘outlwd’ argument.
Reported by Jurgen Kluge.
‘svd(x)’ and ‘eigen(x)’ now behave analogously to ‘qr(x)’ in accepting
logical matrices ‘x’.
File ‘NEWS’ is now in UTF-8, and has a BOM (often invisible) on the
first line, and ‘Emacs’ local variables set for UTF-8 at the end.
‘RShowDoc("NEWS")’ should display this correctly, given suitable fonts.
‘terms.formula(simplify = TRUE)’ now does not deparse the LHS and so
preserves non-standard responses such as ‘`a: b`’ (requested by Sundar
Dorai-Raj).
New function ‘news()’ for building and querying R or package news
information.
‘z^n’ for integer ‘n’ and complex ‘z’ is more accurate now if ‘|n| <=
65536’.
‘factor(NULL)’ now returns the same as ‘factor(character(0))’ instead
of an error, and ‘table(NULL)’ consequently does analogously.
‘as.data.frame.vector()’ (and its copies) is slightly faster by
avoiding a copy if there are no names (following a suggestion of Tim
Hesterberg).
‘writeLines()’, ‘writeBin()’ and ‘writeChar()’ have a new argument
‘useBytes’. If false, character strings with marked encodings are
translated to the current locale (as before) but if true they are
written byte-by-byte.
‘iconv()’ has a new argument ‘mark’ which can be used (by experts) to
suppress the declaration of encodings.
‘DESCRIPTION’ file's ‘LinkingTo’ specs are now recognized as
installation dependencies, and included in package management
computations.
Standardized ‘DESCRIPTION’ file ‘License’ specs are now available for
package management computations.
‘"\uxxxx"’ and ‘"\Uxxxxxxxx"’ escapes can now be parsed to a UTF-8
encoded string even in non-UTF-8 locales (this has been implemented on
Windows since R 2.7.0). The semantics have been changed slightly: a
string containing such escapes is always stored in UTF-8 (and hence is
suitable for portably including Unicode text in packages).
New ‘as.raw()’ method for ‘"tclObj"’ objects (wish of PR#13758).
‘Rd.sty’ now makes a better job of setting email addresses, including
using a monospaced font.
‘textConnection()’ gains an ‘encoding’ argument to determine how input
strings with marked encodings will be handled.
‘R CMD Rd2pdf’ is available as a shortcut for ‘R CMD Rd2dvi --pdf’.
‘R CMD check’ now checks links where a package is specified
(‘\link[pkg]{file}’ or ‘\link[pkg:file]{topic}’), if the package is
available. It notes if the package is not available, as in many cases
this is an error in the link.
‘identical()’ gains three logical arguments, which allow for even more
differentiation, notably ‘-0’ and ‘0’.
‘legend()’ now can specify the ‘border’ color of filled boxes, thanks
to a patch from Frederic Schutz.
Indexing with a vector index to ‘[[ ]]’ has now been extended to all
recursive types.
Pairlists may now be assigned as elements of lists. (Lists could
always be created with pairlist elements, but ‘[[<-’ didn't support
assigning them.)
The parser now supports C-preprocessor-like ‘#line’ directives, so
error messages and source references may refer to the original file
rather than an intermediate one.
New functions ‘findLineNum()’ and ‘setBreakpoint()’ work with the
source references to find the location of source lines and set
breakpoints (using ‘trace()’) at those lines.
Namespace importing is more careful about warning on masked generics,
thanks to a patch by Yohan Chalabi.
‘detach()’ now has an argument ‘character.only’ with the same meaning
as for ‘library()’ or ‘require()’.
‘available.packages()’ gains a ‘filters’ argument for specifying the
filtering operations performed on the packages found in the
repositories. A new built-in ‘"license/FOSS"’ filter only retains
packages for which installation can proceed solely based on packages
which can be verified as Free or Open Source Software (FOSS) employing
the available license specifications.
In registering an S3 class by a call to ‘setOldClass()’, the data part
(e.g., the object type) required for the class can be included as one
of the superclasses in the Classes argument.
The argument ‘f’ to ‘showMethods()’ can be an expression evaluating to
a generic function, allowing methods to be shown for non-exported
generics and other nonstandard cases.
‘sprintf()’ now supports ‘%o’ for octal conversions.
New function ‘Sys.readlink()’ for information about symbolic links,
including if a file is a symbolic link.
Package ‘tools’ has new functions ‘checkRdaFiles()’ and
‘resaveRdaFiles()’ to report on the format of ‘.rda’/‘.RData’ data
files, and to re-save them in a different compressed format, including
choosing the most compact format available.
A new ‘INSTALL’ option, ‘--resave-data’, makes use of this.
File ‘~/.R/config’ is used in preference to ‘~/.Rconfig’, and these are
now documented in ‘R Installation and Administration’.
Logic operations with complex numbers now work, as they were always
documented to, and as in S.
‘arrows()’ and ‘segments()’ allow one of ‘x1’ or ‘y1’ to be omitted to
simplify the specification of vertical or horizontal lines (suggestion
of Tim Hesterberg).
‘approxfun()’ is faster by avoiding repeated ‘NA’ checks (diagnosis and
patch by Karline Soetaert & Thomas Petzoldt).
There are the beginnings of a Nynorsk translation by Karl Ove
Hufthammer.
‘stripchart()’ allows ‘par’ ‘bg’ to be passed in for the background
colour for ‘pch = 21’ (wish of PR#13984).
New generic function ‘.DollarNames()’ to enable class authors to
customize completion after the ‘$’ extractor.
‘load()’, ‘save()’, ‘dput()’ and ‘dump()’ now open a not-yet-open
connection in the appropriate mode (as other functions using
connections directly already did).
A different regular expression engine is used for basic and extended
regexps and is also for approximate matching. This is based on the TRE
library of Ville Laurikari, a modified copy of which is included in the
R sources.
This is often faster, especially in a MBCS locale.
Some known differences are that it is less tolerant of invalid inputs in MBCS locales, and in its interpretation of undefined (extended) regexps such as ‘"^*"’. Also, the interpretation of ranges such as ‘[W-z]’ in caseless matching is no longer to map the range to lower case.
This engine may in future be used in ‘literal’ mode for ‘fixed = TRUE’, and there is a compile-time option in ‘src/main/grep.c’ to do so.
The use of repeated boundary regexps in ‘gsub()’ and ‘gregexpr()’ as
warned about in the help page does not work in this engine (it did in
the previous one since 2005).
Extended (and basic) regexps now support same set of options as for
‘fixed = TRUE’ and ‘perl = TRUE’, including ‘useBytes’ and support for
UTF-8-encoded strings in non-UTF-8 locales.
‘agrep()’ now has full support for MBCS locales with a modest speed
penalty. This enables ‘help.search()’ to use approximate matching
character-wise rather than byte-wise.
‘[g]sub’ use a single-pass algorithm instead of matching twice and so
is usually faster.
The ‘perl = TRUE’ versions now work correctly in a non-UTF-8 MBCS
locale, by translating the inputs to UTF-8.
‘useBytes = TRUE’ now inhibits the translation of inputs with marked
encodings.
‘strsplit()’ gains a ‘useBytes’ argument.
The algorithm used by ‘strsplit()’ has been reordered to batch by
elements of ‘split’: this can be much faster for ‘fixed = FALSE’ (as
multiple compilation of regexps is avoided).
The help pages, including ‘?regexp’, have been updated and should be
consulted for details of the new implementations.
A new dynamic HTML help system is used by default, and may be
controlled using ‘tools::startDynamicHelp()’. With this enabled, HTML
help pages will be generated on request, resolving links by searching
through the current ‘.libPaths()’. The user may set
options(‘"help.ports"’) to control which IP port is used by the server.
‘help.start()’ no longer sets ‘options(htmlhelp = TRUE)’ (it used to on
Unix but not on Windows). Nor does it on Unix reset the ‘"browser"’
option if given an argument of that name.
Arguments ‘update’ and ‘remote’ are now available on all platforms: the default is ‘update = FALSE’ since the http server will update the package index at first use.
‘help()’ has a new argument ‘help_type’ (with default set by the option
of that name) to supersede arguments ‘offline’, ‘htmlhelp’ and
‘chmhelp’ (although for now they still work if ‘help_type’ is unset).
There is a new type, ‘"PDF"’ to allow offline PDF (rather than
PostScript).
A function ‘offline_help_helper()’ will be used if this exists in the workspace or further down the search path, otherwise the function of that name in the ‘utils’ name space is used.
Plain text help is now used as the fallback for HTML help (as it always
was for Compiled HTML help on Windows).
It is possible to ask for static HTML pages to be prebuilt _via_ the
configure option ‘--enable-prebuilt-html’. This may be useful for
those who wish to make HTML help available outside R, e.g. on a local
web site.
An experimental tag ‘\Sexpr’ has been added to Rd files, to evaluate
expressions at build, install, or render time. Currently install time
and render time evaluation are supported.
Tags ‘\if’, ‘\ifelse’ and ‘\out’ have been added to allow
format-specific (or more general, using ‘\Sexpr’) conditional text in
man pages.
The ‘parse_Rd()’ parser has been made more tolerant of coding errors in
Rd files: now all syntax errors are reported as warnings, and an
attempt is made to continue parsing.
‘parse_Rd()’ now has an argument ‘fragment’ (default ‘FALSE’) to accept
small fragments of Rd files (so that ‘\Sexpr’ can output Rd code which
is then parsed).
‘parse_Rd()’ now always converts its input to UTF-8. The ‘Rd2*’
rendering functions have a new argument, ‘outputEncoding’, which
controls how their output is encoded.
‘parse_Rd()’ no longer includes the newline as part of a ‘"%"’-style
comment.
There have been various bug fixes and code reorganization in the Rd
renderers ‘Rd2HTML’, ‘Rd2latex’, ‘Rd2txt’, and ‘Rd2ex’.
All example files are now created with either ASCII or UTF-8 encoding, and the encoding is only marked in the file if there is any non-UTF-8 code (previously it was marked if the help file had non-ASCII contents, possibly in other sections).
‘print.Rd()’ now adds necessary escape characters so that printing and
re-parsing an Rd object should produce an equivalent object.
‘parse_Rd()’ was incorrectly handling multiple backslashes in R code
strings, converting 4n+3 backslashes to 2n+1 instead of 2n+2.
‘parse_Rd()’ now recognizes the ‘\var’ tag within a quoted string in
R-like text.
‘parse_Rd()’ now treats the argument of ‘\command’ as LaTeX-like,
rather than verbatim.
New function ‘untar()’ to list or unpack tar archives, possibly
compressed. This uses either an external ‘tar’ command or an internal
implementation.
New function ‘tar()’ to create (possibly compressed) tar archives.
New functions ‘memCompress()’ and ‘memDecompress()’ for in-memory
compression and decompression.
‘bzfile()’ has a ‘compress’ argument to select the amount of effort put
into compression when writing.
New function ‘xzfile()’ for use with ‘xz’-compressed files. (This can
also read files compressed by some versions of ‘lzma’.)
‘gzfile()’ looks at the file header and so can now also read ‘bzip2’-ed
files and ‘xz’-compressed files.
There are the new options of ‘save(compress = "bzip2")’ and ‘"xz"’ to
use ‘bzip2’ or ‘xz’ compression (which will be slower, but can give
substantially smaller files). Argument ‘compression_level’ gives finer
control over the space/time tradeoffs.
‘load()’ can read such saves (but only as from this version of R).
‘R CMD INSTALL’/‘check’ and ‘tools::writePACKAGES’ accept a wider range
of compressed tar archives. Precisely how wide depends on the
capabilities of the host system's ‘tar’ command: they almost always
include ‘.tar.bz2’ archives, and with modern versions of ‘tar’ other
forms of compression such as ‘lzma’ and ‘xz’, and arbitrary extensions.
‘R CMD INSTALL’ has a new option ‘--data-compress’ to control the
compression used when lazy-loading data. New possibilities are
‘--data-compress=bzip2’ which will give ca 15% better compression at
the expense of slower installation times, and ‘--data-compress=xz’,
often giving even better compression on large datasets at the expense
of much longer installation times. (The latter is used for the
recommended packages: it is particularly effective for ‘survival’.)
‘file()’ for open = ‘""’, ‘"r"’ or ‘"rt"’ will automagically detect
compressed files (from ‘gzip’, ‘bzip2’ or ‘xz’). This means that
compressed files can be specified by file name (rather than _via_ a
‘gzfile()’ connection) to ‘read.table()’, ‘readlines()’, ‘scan()’ and
so on.
‘data()’ can handle compressed text files with extensions
‘.{txt,tab,csv}.{gz,bz2,xz}’ .
‘png(type="cairo1")’ is defunct: the value is no longer recognized.
‘tools::Rd_parse()’ is defunct (as this version of R uses only Rd
version 2).
Use of file ‘~/.Rconf’ (which was deprecated in favour of ‘~/.Rconfig’
in 2004) has finally been removed.
Bundles of packages are deprecated. See ‘Writing R Extensions’ for the
steps needed to unbundle a bundle.
‘help()’ arguments ‘offline’, ‘htmlhelp’ and ‘chmhelp’ are deprecated
in favour of ‘help_type’.
‘clearNames()’ (in package ‘stats’) is deprecated for ‘unname()’.
Basic regular expressions (‘extended = FALSE’) are deprecated in
‘strsplit’, ‘grep’ and friends. There is a precise POSIX standard for
them, but it is not what recent RE engines implement, and it seems that
in almost all cases package authors intended ‘fixed = TRUE’ when using
‘extended = FALSE’.
‘methods::trySilent()’ is deprecated in favour of ‘try(silent=TRUE)’ or
- more efficiently and flexibly - something like ‘tryCatch(error =
function(e) e)’.
‘index.search()’ is deprecated: there are no longer directories of
types other than ‘help’.
cairo >= 1.2 is now required (1.2.0 was released in July 2006) for
cairo-based graphics devices (which remain optional).
A suitable ‘iconv()’ is now required: support for configure option
‘--without-iconv’ has been withdrawn (it was deprecated in R 2.5.0).
Perl is no longer ‘essential’. R can be built without it, but scripts
‘R CMD build’, ‘check’, ‘Rprof’ and ‘Sd2d’ currently require it.
A system ‘glob’ function is now essential (a working ‘Sys.glob()’ has
been assumed since R 2.9.0 at least).
C99 support for MBCS is now required, and configure option
‘--disable-mbcs’ has been withdrawn.
Having a version of ‘tar’ capable of automagically detecting compressed
archives is useful for ‘utils::untar()’, and so ‘gtar’ (a common name
for GNU ‘tar’) is preferred to ‘tar’: set environment variable ‘TAR’ to
specify a particular ‘tar’ command.
There is some makefile support for adding/updating translations in
packages: see ‘po/README’ and ‘Writing R Extensions’.
There is support for the use of ‘dngettext’ for C-level translations in packages: see ‘Writing R Extensions’.
Assigning an extra 0-length column to a data frame by ‘DF[, "foo"] <-
value’ now works in most cases (by filling with ‘NA’s) or fails. (It
used to give a corrupt data frame.)
‘validObject()’ avoids an error during evaluation in the case of
various incorrect slot definitions.
‘n:m’ now returns a result of type ‘"integer"’ in a few more boundary
cases.
The ‘zap.ind’ argument to ‘printCoefmat()’ did not usually work as
other code attempted to ensure that non-zero values had a non-zero
representation.
‘printCoefmat()’ formatted groups of columns together, not just the
‘cs.ind’ group but also the ‘zap.ind’ group and a residual group. It
now formats all columns except the ‘cs.ind’ group separately (and zaps
the ‘zap.ind’ group column-by-column). The main effect will be see in
the output from ‘print.anova()’, as this grouped SS-like columns in the
‘zap.ind’ group.
‘R_ReplDLLinit()’ initializes the top-level jump so that some embedded
applications on Windows no longer crash on error.
‘identical()’ failed to take the encoding of character strings into
account, so identical byte patterns are not necessarily identical
strings, and similarly Latin-1 and UTF-8 versions of the same string
differ in byte pattern.
‘methods(f)’ used to warn unnecessarily for an S4 generic ‘f’ which had
been created based on an existing S3 generic.
The check for consistent ordering of superclasses was not ignoring all
conditional relations (the symptom was usually spurious warnings for
classes extending ‘"array"’).
Trying to assign into a raw vector with an index vector containing
‘NA’s could cause a segfault. Reported by Hervé Pagès.
‘Rscript’ could segfault if (by user error) its filename argument was
missing. Reported by Martin Morgan.
‘getAnywhere()’ (and functions that use it, including argument
completion in the console) did not handle special built-in functions.
Reported by Romain Francois.
‘order()’ was missing a ‘PROTECT()’ call and so could segfault when
called on character data under certain (rare) circumstances involving
marked non-native encodings.
‘prettyNum(z, drop0trailing=TRUE)’ did not work correctly when ‘z’ was
a complex vector. Consequently, ‘str(z, ...)’ also did not.
(PR#13985)
‘make distclean’ removed too many files in ‘etc/’ if builddir = srcdir.
‘R CMD’ replaced ‘TEXINPUTS’ rather than appending to it (as documented
and intended).
‘help.start()’ no longer fails on unix when ‘"browser"’ is a function.
‘pbeta(x, ..., log.p = TRUE)’ is sometimes more accurate, e.g., for
very small ‘x’.
Unserializing a pre-2.8 workspace containing pure ASCII character
objects with a Latin-1 or UTF-8 encoding would corrupt the ‘CHARSXP’
cache.
Passing the invalid value ‘lty = NULL’ to ‘axis()’ sent an invalid value to the graphics device, and might cause the device to segfault.
‘Sweave()’ with ‘concordance=TRUE’ could lead to invalid PDF files; ‘Sweave.sty’ has been updated to avoid this.
In some circumstances a one-sided ‘mantelhaen.test()’ reported the p-value for the wrong tail. (PR#14514)
‘max()’ and ‘min()’ work harder to ensure that ‘NA’ has precedence over ‘NaN’, so e.g. ‘min(NaN, NA)’ is ‘NA’. (This was not previously documented except for within a single numeric vector, where compiler optimizations often defeated the code.)
A change to the C function ‘R_tryEval’ had broken error messages in S4 method selection; the error message is now printed.
PDF output with non-RGB color model used RGB for the line stroke color. PR#14511
‘stats4::BIC()’ assumed without checking that an object of class ‘"logLik"’ has an ‘"nobs"’ attribute: ‘glm()’ fits did not and so ‘BIC()’ failed for them.
Files ‘R/sysdata.rda’ of more than 1Mb are now stored in the lazyload database using ‘xz’ compression: this for example halves the installed size of package ‘Imap’.
‘identical()’ could in rare cases generate a warning about non-pairlist attributes on CHARSXPs. As these are used for internal purposes, the attribute check should be skipped. (Reported by Niels Richard Hansen).
If the filename extension (usually ‘.Rnw’) was not included in a call to ‘Sweave()’, source references would not work properly and the ‘keep.source’ option failed. (PR#14459)
The function ‘qlogis(lp, log.p=TRUE)’ no longer prematurely overflows to ‘Inf’ when exp(lp) is close to 1.
‘bug.report()’ was naive about how to extract maintainer email addresses from package descriptions, so would often try mailing to incorrect addresses.
‘prettyNum(c(1i, NA), drop0=TRUE)’ or ‘str(NA_complex_)’ now work correctly.
‘debugger()’ could fail to read the environment of a call to a function with a ‘...’ argument. (Reported by Charlie Roosen.)
‘R CMD check’ now checks for the correct use of ‘$(LAPACK_LIBS)’ (as well as ‘$(BLAS_LIBS)’), since several CRAN recent submissions have ignored ‘Writing R Extensions’.
‘R CMD INSTALL’ now ensures that directories installed from ‘inst’ have search permission for everyone.
It no longer installs files ‘inst/doc/Rplots.ps’ and ‘inst/doc/Rplots.pdf’. These are almost certainly left-overs from ‘Sweave’ runs, and are often large.
Building badly-written vignettes which used the default device
(‘pdf(file = "Rplots.pdf")’ could leave the device open and hence the
file ‘Rplots.pdf’ could not be removed on Windows: all devices are now
closed.
In some circumstances the caret (cursor) could be positioned
incorrectly. (PR#14460)
When loading ‘Rconsole’ from disk, a spurious warning message was
sometimes shown.
In R 2.12.1, ‘system()’ sometimes passed an empty input stream to the
new process rather than allowing user input.
The internal method for ‘untar()’ does a better job of unravelling
symbolic links in the tarball (but still with many limitations).
Building badly-written vignettes which used the default device (‘pdf(file = "Rplots.pdf")’ could leave the device open and hence the file ‘Rplots.pdf’ could not be removed on Windows: all devices are now closed.
In some circumstances the caret (cursor) could be positioned incorrectly. (PR#14460)
When loading ‘Rconsole’ from disk, a spurious warning message was sometimes shown.
In R 2.12.1, ‘system()’ sometimes passed an empty input stream to the new process rather than allowing user input.
The internal method for ‘untar()’ does a better job of unravelling symbolic links in the tarball (but still with many limitations).
Bug fixes for drawing raster objects on ‘windows()’. The symptom was the occasional raster image not being drawn, especially when drawing multiple raster images in a single expression. Thanks to Michael Sumner for report and testing.
Complex arithmetic (notably ‘z^n’ for complex ‘z’ and integer ‘n’) gave
incorrect results since R 2.10.0 on platforms without complex C99
complex support. This and some lesser issues in trignometric functions
have been corrected.
Such platforms were rare (we know of Cygwin and FreeBSD). However, because of new compiler optimizations in the way complex arguments are handled, the same code was selected on x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
There is a workaround for crashes seen with several packages on systems
using ‘zlib 1.2.5’: see the INSTALLATION section.
PCRE has been updated to 8.12 (two bug-fix releases since 8.10).
‘rep()’, ‘seq()’, ‘seq.int()’ and ‘seq_len()’ report more often when
the first element is taken of an argument of incorrect length.
The Cocoa back-end for the ‘quartz()’ graphics device on Mac OS X
provides a way to disable event loop processing temporarily (useful,
e.g., for forked instances of R).
‘kernel()’'s default for ‘m’ was not appropriate if ‘coef’ was a set of
coefficients. (Reported by Pierre Chausse.)
The ‘zlib’ sources in the distribution are now built with all symbols
remapped: this is intended to avoid problems seen with packages such as
‘XML’ and ‘rggobi’ which link to ‘zlib.so.1’ on systems using ‘zlib
1.2.5’.
The default for ‘FFLAGS’ and ‘FCFLAGS’ with ‘gfortran’ on x86_64 Linux
has been changed back to ‘-g -O2’: however, setting ‘-g -O’ may still
be needed for ‘gfortran 4.3.x’.
A ‘LazyDataCompression’ field in the ‘DESCRIPTION’ file will be used to
set the value for the ‘--data-compress’ option of ‘R CMD INSTALL’.
Files ‘R/sysdata.rda’ of more than 1Mb are now stored in the lazyload
daabase using ‘xz’ compression: this for example halves the installed
size of package ‘Imap’.
‘R CMD INSTALL’ now ensures that directories installed from ‘inst’ have
search permission for everyone.
The ‘experimental’ alternative specification of a name space via
‘.Export()’ etc is now deprecated.
‘zip.file.extract()’ is now deprecated.
Zip-ing data sets in packages (and hence ‘R CMD INSTALL --use-zip-data’
and the ‘ZipData: yes’ field in a ‘DESCRIPTION’ file) is deprecated:
using efficiently compressed ‘.rda’ images and lazy-loading of data has
superseded it.
‘identical’ could in rare cases generate a warning about non-pairlist
attributes on CHARSXPs. As these are used for internal purposes, the
attribute check should be skipped. (Reported by Niels Richard Hansen).
If the filename extension (usually ‘.Rnw’) was not included in a call
to ‘Sweave()’, source references would not work properly, and the
‘keep.source’ option failed. (PR#14459)
‘format.data.frame()’ now keeps zero character column names.
‘pretty(x)’ no longer raises an error when ‘x’ contains solely
non-finite values. (PR#14468)
The ‘plot.TukeyHSD()’ function now uses a line width of 0.5 for its
reference lines rather than ‘lwd = 0’ (which caused problems for some
PDF and PostScript viewers).
The ‘big.mark’ argument to ‘prettyNum()’, ‘format()’, etc. was inserted
reversed if it was more than one character long.
‘R CMD check’ failed to check the filenames under ‘man’ for Windows'
reserved names.
The ‘"Date"’ and ‘"POSIXt"’ methods for ‘seq()’ could overshoot when
‘to’ was supplied and ‘by’ was specified in months or years.
The internal method of ‘untar()’ now restores hard links as file copies
rather than symbolic links (which did not work for cross-directory
links).
‘unzip()’ did not handle zip files which contained filepaths with two
or more leading directories which were not in the zipfile and did not
already exist. (It is unclear if such zipfiles are valid and the
third-party C code used did not support them, but PR#14462 created
one.)
‘combn(n, m)’ now behaves more regularly for the border case m = 0.
(PR#14473)
The rendering of numbers in plotmath expressions (e.g.
‘expression(10^2)’) used the current settings for conversion to strings
rather than setting the defaults, and so could be affected by what has
been done before. (PR#14477)
The methods of ‘napredict()’ and ‘naresid()’ for ‘na.action =
na.exclude’ fits did not work correctly in the very rare event that
every case had been omitted in the fit. (Reported by Simon Wood.)
‘weighted.residuals(drop0=TRUE)’ returned a vector when the residuals
were a matrix (e.g. those of class ‘"mlm"’). (Reported by Bill
Dunlap.)
Package HTML index files ‘<pkg>/html/00Index.html’ were generated with
a stylesheet reference that was not correct for static browsing in
libraries.
‘ccf(na.action = na.pass)’ was not implemented.
The parser accepted some incorrect numeric constants, e.g. ‘20x2’.
(Reported by Olaf Mersmann.)
‘format(*, zero.print)’ did not always replace the full zero parts.
Fixes for subsetting or subassignment of ‘"raster"’ objects when not
both ‘i’ and ‘j’ are specified.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a
‘DESCRIPTION’ file (although this is frequently incorrectly specified
for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
‘source(file, echo=TRUE)’ could fail if the file contained ‘#line’
directives. It now recovers more gracefully, but may still display the
wrong line if the directive gives incorrect information.
‘atan(1i)’ returned ‘NaN+Infi’ (rather than ‘0+Infi’) on platforms
without C99 complex support.
‘library()’ failed to cache S4 metadata (unlike ‘loadNamespace()’)
causing failures in S4-using packages without a namespace (e.g. those
using reference classes).
The logit() function ‘qlogis(lp, log.p=TRUE)’ no longer prematurely
overflows to ‘Inf’ when p := exp(lp) is close to 1.
Updating S4 methods for a group generic function requires resetting the
methods tables for the members of the group (patch contributed by
Martin Morgan).
In some circumstances (including for package ‘XML’), ‘R CMD INSTALL’
installed version-control directories from source packages.
Added ‘PROTECT’ calls to some constructed expressions used in C level
‘eval’ calls.
Complex arithmetic (notably ‘z^n’ for complex ‘z’ and integer ‘n’) gave incorrect results since R 2.10.0 on platforms without C99 complex support. This and some lesser issues in trignometric functions have been corrected.
Such platforms were rare (we know of Cygwin and FreeBSD). However, because of new compiler optimizations in the way complex arguments are handled, the same code was selected on x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
There is a workaround for crashes seen with several packages on systems using ‘zlib 1.2.5’: see the INSTALLATION section.
PCRE has been updated to 8.12 (two bug-fix releases since 8.10).
‘rep()’, ‘seq()’, ‘seq.int()’ and ‘seq_len()’ report more often when the first element is taken of an argument of incorrect length.
The Cocoa back-end for the ‘quartz()’ graphics device on Mac OS X provides a way to disable event loop processing temporarily (useful, e.g., for forked instances of R).
‘kernel()’'s default for ‘m’ was not appropriate if ‘coef’ was a set of coefficients. (Reported by Pierre Chausse.)
‘bug.report()’ has been updated for the current R bug tracker, which does not accept emailed submissions.
The ‘zlib’ sources in the distribution are now built with all symbols remapped: this is intended to avoid problems seen with packages such as ‘XML’ and ‘rggobi’ which link to ‘zlib.so.1’ on systems using ‘zlib 1.2.5’.
The default for ‘FFLAGS’ and ‘FCFLAGS’ with ‘gfortran’ on x86_64 Linux has been changed back to ‘-g -O2’: however, setting ‘-g -O’ may still be needed for ‘gfortran 4.3.x’.
A ‘LazyDataCompression’ field in the ‘DESCRIPTION’ file will be used to set the value for the ‘--data-compress’ option of ‘R CMD INSTALL’.
Files ‘R/sysdata.rda’ of more than 1Mb are now stored in the lazyload daabase using ‘xz’ compression: this for example halves the installed size of package ‘Imap’.
‘R CMD INSTALL’ now ensures that directories installed from ‘inst’ have search permission for everyone.
The ‘experimental’ alternative specification of a name space via ‘.Export()’ etc is now deprecated.
‘zip.file.extract()’ is now deprecated.
Zip-ing data sets in packages (and hence ‘R CMD INSTALL --use-zip-data’ and the ‘ZipData: yes’ field in a ‘DESCRIPTION’ file) is deprecated: using efficiently compressed ‘.rda’ images and lazy-loading of data has superseded it.
‘identical’ could in rare cases generate a warning about non-pairlist attributes on CHARSXPs. As these are used for internal purposes, the attribute check should be skipped. (Reported by Niels Richard Hansen).
If the filename extension (usually ‘.Rnw’) was not included in a call to ‘Sweave()’, source references would not work properly, and the ‘keep.source’ option failed. (PR#14459)
‘format.data.frame()’ now keeps zero character column names.
‘pretty(x)’ no longer raises an error when ‘x’ contains solely non-finite values. (PR#14468)
The ‘plot.TukeyHSD()’ function now uses a line width of 0.5 for its reference lines rather than ‘lwd = 0’ (which caused problems for some PDF and PostScript viewers).
The ‘big.mark’ argument to ‘prettyNum()’, ‘format()’, etc. was inserted reversed if it was more than one character long.
‘R CMD check’ failed to check the filenames under ‘man’ for Windows' reserved names.
The ‘"Date"’ and ‘"POSIXt"’ methods for ‘seq()’ could overshoot when ‘to’ was supplied and ‘by’ was specified in months or years.
The internal method of ‘untar()’ now restores hard links as file copies rather than symbolic links (which did not work for cross-directory links).
‘unzip()’ did not handle zip files which contained filepaths with two or more leading directories which were not in the zipfile and did not already exist. (It is unclear if such zipfiles are valid and the third-party C code used did not support them, but PR#14462 created one.)
‘combn(n, m)’ now behaves more regularly for the border case m = 0. (PR#14473)
The rendering of numbers in plotmath expressions (e.g. ‘expression(10^2)’) used the current settings for conversion to strings rather than setting the defaults, and so could be affected by what has been done before. (PR#14477)
The methods of ‘napredict()’ and ‘naresid()’ for ‘na.action = na.exclude’ fits did not work correctly in the very rare event that every case had been omitted in the fit. (Reported by Simon Wood.)
‘weighted.residuals(drop0=TRUE)’ returned a vector when the residuals were a matrix (e.g. those of class ‘"mlm"’). (Reported by Bill Dunlap.)
Package HTML index files ‘<pkg>/html/00Index.html’ were generated with a stylesheet reference that was not correct for static browsing in libraries.
‘ccf(na.action = na.pass)’ was not implemented.
The parser accepted some incorrect numeric constants, e.g. ‘20x2’. (Reported by Olaf Mersmann.)
‘format(*, zero.print)’ did not always replace the full zero parts.
Fixes for subsetting or subassignment of ‘"raster"’ objects when not both ‘i’ and ‘j’ are specified.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a ‘DESCRIPTION’ file (although this is frequently incorrectly specified for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
‘source(file, echo=TRUE)’ could fail if the file contained ‘#line’ directives. It now recovers more gracefully, but may still display the wrong line if the directive gives incorrect information.
‘atan(1i)’ returned ‘NaN+Infi’ (rather than ‘0+Infi’) on platforms without C99 complex support.
‘library()’ failed to cache S4 metadata (unlike ‘loadNamespace()’) causing failures in S4-using packages without a namespace (e.g. those using reference classes).
The logit() function ‘qlogis(lp, log.p=TRUE)’ no longer prematurely overflows to ‘Inf’ when p := exp(lp) is close to 1.
Updating S4 methods for a group generic function requires resetting the methods tables for the members of the group (patch contributed by Martin Morgan).
In some circumstances (including for package ‘XML’), ‘R CMD INSTALL’ installed version-control directories from source packages.
Added ‘PROTECT’ calls to some constructed expressions used in C level ‘eval’ calls.
‘utils:::create.post()’ (used by ‘bug.report()’ and ‘help.request()’) failed to quote arguments to the mailer, and so often failed.
‘R CMD INSTALL’ now ensures that directories installed from ‘inst’ have search permission for everyone.
Added ‘PROTECT’ calls to some constructed expressions used in C level ‘eval’ calls.
A ‘LazyDataCompression’ field in the ‘DESCRIPTION’ file will be used to set the value for the ‘--data-compress’ option of ‘R CMD INSTALL’.
Files ‘R/sysdata.rda’ of more than 1Mb are now stored in the lazyload daabase using ‘xz’ compression: this for example halves the installed size of package ‘Imap’.
Complex arithmetic (notably ‘z^n’ for complex ‘z’ and integer ‘n’) gave incorrect results since R 2.10.0 on platforms without complex C99 complex support. This and some lesser issues in trignometric functions have been corrected.
Such platforms were rare (we know of Cygwin and FreeBSD). However, because of new compiler optimizations in the way complex arguments are handled, the same code was selected on x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
‘rep()’, ‘seq()’, ‘seq.int()’ and ‘seq_len()’ report more often when the first element is taken of an argument of incorrect length.
In some circumstances (including for package ‘XML’), ‘R CMD INSTALL’ installed version-control directories from source packages.
‘library()’ failed to cache S4 metadata (unlike ‘loadNamespace()’) causing failures in S4-using packages without a namespace (e.g. those using reference classes).
Updating S4 methods for a group generic function requires resetting the methods tables for the members of the group (patch contributed by Martin Morgan).
Building badly-written vignettes which used the default device (‘pdf(file = "Rplots.pdf")’ could leave the device open and hence the file ‘Rplots.pdf’ could not be removed on Windows: all devices are now closed.
The logit() function ‘qlogis(lp, log.p=TRUE)’ no longer prematurely overflows to ‘Inf’ when p := exp(lp) is close to 1.
Updating methods for a group generic function requires resetting the methods tables for the members of the group (patch contributed by Martin Morgan).
‘library()’ failed to cache S4 metadata (unlike ‘loadNamespace()’) causing failures in some packages without a namespace (those using reference classes, e.g.).
Complex arithmetic (notably ‘z^n’ for complex ‘z’ and integer ‘n’) gave incorrect results since R 2.10.0 on platforms without complex C99 complex support. This and some lesser issues in trignometric functions have been corrected.
Such platforms were rare (Cygwin, and apparently FreeBSD). However, because of new optimizations in the way complex arguments are handled, the same code was selected on x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
There is a workaround for crashes seen with several packages on systems using ‘zlib 1.2.5’: see the INSTALLATION section.
‘kernel()’'s default for ‘m’ was not appropriate if ‘coef’ was a set of coefficients. (Reported by Pierre Chausse.)
Since R 2.10.0, ‘z^n’ was computed incorrectly for ‘n >= 3’ and ‘n <=
-3’ on platforms for which the macro ‘HAVE_C99_COMPLEX’ was not
defined. Such platforms have been rare (but apparently included
FreeBSD), but now include x86_64 Linux with ‘gcc 4.5.x’ at the default
‘-O2’ optimization (but not at ‘-O’).
‘library()’ failed to cache meta data (unlike ‘loadNamespace()’) causing failures in packages without a namespace.
‘atan(1i)’ returned ‘NaN+Infi’ (rather than ‘0+Infi’) on platforms without C99 complex support.
‘atan(1i)’ returned ‘NaN+Infi’ (rather than the conventional value of ‘0+Infi’) on platforms without C99 complex support.
Since R 2.10.0, ‘z^n’ was computed incorrectly for ‘n >= 3’ and ‘n <= -3’ on platforms for which the macro ‘HAVE_C99_COMPLEX’ was not defined. Such platforms have been rare (but apparently included FreeBSD), but now include x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
‘source(file, echo=TRUE)’ could fail if the file contained ‘#line’ directives. It now recovers more gracefully, but may still display the wrong line if the directive gives incorrect information.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a ‘DESCRIPTION’ file (although this is frequently incorrectly specified for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a ‘DESCRIPTION’ file (although this is frequently incorrectly specified for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
‘source(file, echo=TRUE)’ could fail if the file contained ‘#line’ directives. It now recovers more gracefully, but may still display the wrong line if the directive gives incorrect information.
‘rep()’, ‘seq()’, ‘seq.int()’ and ‘seq_len()’ report more often when the first element of an incorrect length argument is taken.
The Cocoa back-end for the ‘quartz()’ graphics device on Mac OS X provides a way to disable event loop processing temporarily (useful, e.g., for forked instances of R).
Zip-ing data sets in packages (and hence ‘R CMD INSTALL --use-zip-data’ and the ‘ZipData: yes’ field in a ‘DESCRIPTION’ file) is deprecated: using efficiently compressed ‘.rda’ images and lazy-loading of data has superseded it.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a ‘DESCRIPTION’ file (although this is frequently incorrectly specified for packages with no data or which specify lazy-loading of data).
‘R CMD INSTALL --use-zip-data’ was incorrectly implemented as ‘--use-zipdata’ since R 2.9.0.
The ‘experimental’ alternative specification of a name space via ‘.Export()’ etc is now deprecated.
‘zip.file.extract()’ is now deprecated.
The default for ‘FFLAGS’ and ‘FCFLAGS’ with ‘gfortran’ on x86_64 Linux has been changed back to ‘-g -O2’: however, setting ‘-g -O’ may still be needed for ‘gfortran 4.3.x’.
Fixes for subsetting or subassignment of ‘"raster"’ objects when not both ‘i’ and ‘j’ are specified.
‘R CMD INSTALL’ was not always respecting the ‘ZipData: yes’ field of a ‘DESCRIPTION’ file (although this is frequently incorrectly specified for packages with no data or which specify lazy-loading of data).
Since R 2.10.0, ‘z^n’ was computed incorrectly for ‘n >= 3’ and ‘n <= -3’ on platforms for which the macro ‘HAVE_C99_COMPLEX’ was not defined. Such platforms have been rare, but now include x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
Since R 2.10.0, ‘z^n’ was computed incorrectly for ‘n >= 3’ and ‘n <= -3’ on platforms for which the macro ‘HAVE_C99_COMPLEX’ was not defined. Such platforms have been very rare, but now include x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
Since R 2.10.0, ‘z^n’ was computed incorrectly except for ‘n >= 3’ and ‘n <= -3’ on platforms for which the macro ‘HAVE_C99_COMPLEX’ was not defined. Such platforms have been very rare, but now include x86_64 Linux with ‘gcc 4.5.x’ at the default ‘-O2’ optimization (but not at ‘-O’).
The ‘zlib’ sources in the distribution are now built with all symbols remapped: this is intended to avoid problems seen with packages such as ‘XML’ and ‘rggobi’ which link to ‘zlib.so.1’ on systems using ‘zlib 1.2.5’.
‘format(*, zero.print)’ did not always replace the full zero parts.
The parser accepted some incorrect numeric constants, e.g. ‘20x2’. (Reported by Olaf Mersmann.)
The ‘plot.TukeyHSD()’ function now uses a line width of 0.5 for its reference lines rather than ‘lwd = 0’ (which caused problems for some PDF and PostScript viewers).
The rendering of numbers in plotmath expressions (e.g. ‘expression(10^2)’) used the current settings for conversion to strings rather than setting the defaults, and so could be affected by what has been done before. (PR#14477)
Reference S4 class creation could generate ambiguous inheritance patterns under very special circumstances.
PCRE has been updated to 8.12 (two bug-fix releases since 8.10).
Package HTML index files ‘<pkg>/html/00Index.html’ were generated with a stylesheet reference that was not correct for static browsing in libraries.
‘ccf(na.action = na.pass)’ was not implemented.
The methods of ‘napredict()’ and ‘naresid()’ for ‘na.action = na.exclude’ fits did not work correctly in the very rare event that every case had been omitted in the fit. (Reported by Simon Wood.)
‘weighted.residuals(drop0=TRUE)’ returned a vector when the residuals were a matrix (e.g. those of class ‘"mlm"’). (Reported by Bill Dunlap.)
‘identical’ could in rare cases generate a warning about non-pairlist attributes on CHARSXPs. As these are used for internal purposes, the attribute check should be skipped. (Reported by Niels Richard Hansen).
If the filename extension (usually ‘.Rnw’) was not included in a call to ‘Sweave()’, source references would not work properly, and the ‘keep.source’ option failed. (PR#14459)
‘combn(n, m)’ now behaves more regularly for the border case m = 0. (PR#14473)
The rendering of numbers in plotmath expressions (e.g. ‘expression(10^2)’ used the current settings for conversion to strings rather than setting the defaults, and so could be affected by what has been done before. (PR#14477)
‘combn(n,m)’ now behaves more regularly for the border case m = 0. (PR#14473)
Reference class creation could generate ambiguous inheritance patterns under very special circumstances.
‘unzip()’ did not handle zip files which contained filepaths with two or more leading directories which were not in the zipfile and did not already exist. (It is unclear if such zipfiles are valid and the third-party C code used did not support them, but PR#14462 created one.)
The internal method for ‘untar()’ does a better job of unravelling symbolic links in the tarball (but still with many limitations).
The ‘"Date"’ and ‘"POSIXt"’ methods for ‘seq()’ could overshoot when ‘to’ was supplied and ‘by’ was specified in months or years.
The internal method of ‘untar()’ now restores hard links as file copies rather than symbolic links (which did not work for cross-directory links).
‘identical’ could in rare cases generate a warning about non-pairlist attributes on CHARSXPs. As these are used for internal purposes, the attribute check should be skipped. (Reported by Niels Richard Hansen).
The ‘plot.TukeyHSD’ function now uses a line width of 0.5 for its reference lines rather than ‘lwd = 0’ (which caused problems for some PDF and PostScript viewers).
The ‘big.mark’ argument to ‘prettyNum()’, ‘format()’, etc. was inserted reversed if it was more than one character long.
‘R CMD check’ failed to check the filenames under ‘man’ for Windows' reserved names.
New S4 reference class utility methods ‘copy()’, ‘field()’, ‘getRefClass()’ and ‘getClass()’ have been added to package ‘methods’.
‘format.data.frame()’ now keeps zero character column names.
‘pretty(x)’ no longer raises an error when ‘x’ contains solely non-finite values. (PR#14468)
In R 2.12.1, ‘system()’ sometimes passed an empty input stream to the new process rather than allowing user input.
If the extension was not included in a call to ‘Sweave()’, source references would not work properly, and the ‘keep.source’ option failed. (PR#14459)
In some circumstances the caret (cursor) could be positioned incorrectly. (PR#14460)
When loading ‘Rconsole’ from disk, a spurious warning message was sometimes shown.
<URL: http://www.rforge.net> has been added to the default set of repositories known to ‘setRepositories()’.
New reference class utility methods ‘copy()’, ‘field()’, ‘getRefClass()’ and ‘getClass()’ have been added.
The ‘data.frame’ method of ‘format()’ failed if a column name was longer than 256 bytes (the maximum length allowed for an R name).
Use of ‘[[<-’ for S4 subclasses of ‘"environment"’ generated an infinite recursion from the method. The method has been replaced by internal code.
‘[[<-’ turned S4 subclasses of ‘"environment"’ into plain environments.
The internal ‘strptime()’ could corrupt its copy of the timezone which would then lead to spurious warnings. (PR#14338)
‘wilcox.test(x, y, conf.int = TRUE)’ failed with an unhelpful message if ‘x’ and ‘y’ were constant vectors, and similarly in the one-sample case. (PR#14329)
‘callNextMethod’ now works again with the ‘drop=’ argument in ‘[’
‘factor()’, ‘levels()<-’, etc, now ensure that the resulting factor levels are unique (as was always the implied intention). Factors with duplicated levels are still constructible by low-level means, but are now declared illegal.
‘system()’ and ‘system2()’ with output redirected to a character vector
now give a warning if the command returns a non-zero error code. (This
is what a Unix-alike does as from R 2.12.0.)
‘system()’ and ‘system2()’ no longer discard output from the command to
stdout and stderr as often as they used to, and more cases of
‘system2()’ are implemented.
‘stdin’ is now flushed after echoing the input line.
The internal implementation of ‘tar()’ (package ‘utils’) is now
supported on Windows.
The MSI installer is now made by an R script, and there is now support
for 64-bit builds. (Unlike the Inno Setup installer, there are
separate MSI installers for 32- and 64-bit Windows.)
It is now built using ‘WiX 3.x’ rather than ‘WiX 2.0’. (As a result it is about 25% smaller.)
Some warning/error messages from ‘dyn.load()’ could be masked in ‘Rgui’
on Windows 7, as that OS can return messages containing carriage
returns and ‘Rgui’ does not support overwriting.
Filenames could not be specified using backslashes in ‘Sweave()’.
In R 2.12.0, ‘system(intern = TRUE)’ captured ‘stderr’ on ‘Rterm’ when
it was documented to only do so on ‘Rgui’.
‘Rgui’ in R 2.12.0 (only) did not always handle lines containing
carriage returns (‘\r’) correctly: sometimes random characters where
shown.
Since carriage returns have been supported in ‘Rgui’, the cursor positioning after outputting a line containing a carriage return had been unreliable.
‘system()’ and ‘system2()’ with output redirected to a character vector now give a warning if the command returns a non-zero error code. (This is what a Unix-alike does as from R 2.12.0.)
‘system()’ and ‘system2()’ no longer discard output from the command to stdout and stderr as often as they used to, and more cases of ‘system2()’ are implemented.
‘stdout’ is now flushed after echoing the input line.
The internal implementation of ‘tar()’ (package ‘utils’) is now supported on Windows.
The MSI installer is now made by an R script, and there is now support for 64-bit builds. (Unlike the Inno Setup installer, there are separate MSI installers for 32- and 64-bit Windows.)
It is now built using ‘WiX 3.x’ rather than ‘WiX 2.0’. (As a result it is about 25% smaller.)
Some warning/error messages from ‘dyn.load()’ could be masked in ‘Rgui’ on Windows 7, as that OS can return messages containing carriage returns and ‘Rgui’ does not support overwriting.
Filenames could not be specified using backslashes in ‘Sweave()’.
In R 2.12.0, ‘system(intern = TRUE)’ captured ‘stderr’ on ‘Rterm’ when it was documented to only do so on ‘Rgui’.
‘Rgui’ in R 2.12.0 (only) did not always handle lines containing carriage returns (‘\r’) correctly: sometimes random characters where shown.
Since carriage returns have been supported in ‘Rgui’, the cursor positioning after outputting a line containing a carriage return had been unreliable.
The DVI/PDF reference manual now includes the help pages for all the
standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously
omitted (intentionally).
<URL: http://www.rforge.net> has been added to the default set of
repositories known to ‘setRepoositories()’.
xz-utils has been updated to version 5.0.0.
‘reshape()’ now makes use of ‘sep’ when forming names during reshaping
to wide format. (PR#14435)
‘legend()’ allows the length of lines to be set by the end user _via_
the new argument ‘seg.len’.
New reference class utility methods ‘copy’, ‘field’, ‘getRefClass’ and
‘getClass’ have been added.
When a character value is used for the ‘EXPR’ argument in ‘switch()’, a
warning is given if more than one unnamed alternative value is given.
This will become an error in R 2.13.0.
‘StructTS(type = "BSM")’ now allows series with just two seasons.
(Reported by Birgit Erni.)
The PDF reference manual is now built as PDF version 1.5 with object
compression, which on platforms for which this is not the default
(notably MiKTeX) halves its size.
Variable ‘FCLIBS’ can be set during configuration, for any additional
library flags needed when linking a shared object with the Fortran 9x
compiler. (Needed with Solaris Studio 12.2.)
‘seq.int()’ no longer sometimes evaluates arguments twice. (PR#14388)
The ‘data.frame’ method of ‘format’ failed if a column name was longer
than 256 bytes (the maximum length allowed for an R name).
‘predict(<lm object>, type ="terms", ...)’ failed if both ‘terms’ and
‘interval’ were specified. (Reported by Bill Dunlap.)
Also, if ‘se.fit = TRUE’ the standard errors were reported for all terms, not just those selected by a non-null ‘terms’.
The TRE regular expressions engine could terminate R rather than give
an error when given certain invalid regular expressions. (PR#14398)
‘cmdscale(eig = TRUE)’ was documented to return n-1 eigenvalues but in
fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add = TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points. Its return value was described wrongly (it is always a list and contains component ‘ac’).
‘promptClass()’ in package ‘methods’ now works for reference classes
and gives a suitably specialized skeleton of documentation.
Also, ‘callSuper()’ now works via the ‘methods()’ invocation as well as for initially specified methods.
‘download.file()’ could leave the destination file open if the URL was
not able to be opened. (PR#14414)
Assignment of an environment to functions or as an attribute to other
objects now works for S4 subclasses of ‘"environment"’.
Use of ‘`[[<-`’ for S4 subclasses of ‘"environment"’ generated an
infinite recursion from the method. The method has been replaced by
internal code.
In a reference class S4 method, ‘callSuper()’ now works in
‘initialize()’ methods when there is no explicit superclass method.
‘!’ dropped attributes such as names and dimensions from a length-zero
argument. (PR#14424)
When ‘list2env()’ created an environment it was missing a ‘PROTECT’
call and so was vulnerable to garbage collection.
‘Sweave()’ with ‘keep.source=TRUE’ dropped comments at the start and
end of code chunks. It could also fail when ‘\SweaveInput’ was
combined with named chunks.
The Fortran code used by ‘nls(algorithm = "port")’ could infinite-loop
when compiled with high optimization on a modern version of ‘gcc’, and
‘SAFE_FFLAGS’ is now used to make this less likely. (PR#14427, seen
with 32-bit Windows using ‘gcc 4.5.0’ used from R 2.12.0.)
‘sapply()’ with default ‘simplify = TRUE’ and ‘mapply()’ with default
‘SIMPLIFY = TRUE’ wrongly simplified language-like results, as, e.g.,
in ‘mapply(1:2, c(3,7), FUN = function(i,j) call(':',i,j))’.
Backreferences to undefined patterns in ‘[g]sub(pcre = TRUE)’ could
cause a segfault. (PR#14431)
The ‘format()’ (and hence the ‘print()’) method for class ‘"Date"’
rounded fractional dates towards zero: it now always rounds them down.
Reference S4 class creation could generate ambiguous inheritance
patterns under very special circumstances.
‘`[[<-`’ turned S4 subclasses of ‘"environment"’ into plain
environments.
Long titles for help pages were truncated in package indices and a few
other places.
Additional utilities now work correctly with S4 subclasses of
‘"environment"’ (‘rm’, locking tools and active bindings).
‘spec.ar()’ now also work for the ‘"ols"’ method. (Reported by
Hans-Ruedi Kuensch.)
The initialization of objects from S4 subclasses of ‘"environment"’ now
allocates a new environment object.
‘R CMD check’ has more protection against (probably erroneous) example
or test output which is invalid in the current locale.
‘qr.X()’ with column names and pivoting now also pivots the column
names. (PR#14438)
‘unit.pmax()’ and ‘unit.pmin()’ in package ‘grid’ gave incorrect
results when all inputs were of length 1. (PR#14443)
The parser for ‘NAMESPACE’ files ignored misspelled directives, rather
than signalling an error. For 2.12.x a warning will be issued, but
this will be correctly reported as an error in later releases.
(Reported by Charles Berry.)
Fix for subsetting of ‘"raster"’ objects when only one of ‘i’ or ‘j’ is
specified.
‘grid.raster()’ in package ‘grid’ did not accept ‘"nativeRaster"’
objects (like ‘rasterImage()’ does).
Rendering raster images in PDF output was resetting the clipping
region.
Rendering of raster images on Cairo X11 device was wrong, particularly
when a small image was being scaled up using interpolation.
With Cairo < 1.6, will be better than before, though still a little clunky. With Cairo >= 1.6, should be sweet as.
Several bugs fixed in ‘read.DIF()’: single column inputs caused errors,
cells marked as ‘"character"’ could be converted to other types, and
(in Windows) copying from the clipboard failed.
The DVI/PDF reference manual now includes the help pages for all the standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously omitted (intentionally).
<URL: http://www.rforge.net> has been added to the default set of repositories known to ‘setRepoositories()’.
xz-utils has been updated to version 5.0.0.
‘reshape()’ now makes use of ‘sep’ when forming names during reshaping to wide format. (PR#14435)
‘legend()’ allows the length of lines to be set by the end user _via_ the new argument ‘seg.len’.
New reference class utility methods ‘copy’, ‘field’, ‘getRefClass’ and ‘getClass’ have been added.
When a character value is used for the ‘EXPR’ argument in ‘switch()’, a warning is given if more than one unnamed alternative value is given. This will become an error in R 2.13.0.
‘StructTS(type = "BSM")’ now allows series with just two seasons. (Reported by Birgit Erni.)
The PDF reference manual is now built as PDF version 1.5 with object compression, which on platforms for which this is not the default (notably MiKTeX) halves its size.
Variable ‘FCLIBS’ can be set during configuration, for any additional library flags needed when linking a shared object with the Fortran 9x compiler. (Needed with Solaris Studio 12.2.)
‘seq.int()’ no longer sometimes evaluates arguments twice. (PR#14388)
The ‘data.frame’ method of ‘format’ failed if a column name was longer than 256 bytes (the maximum length allowed for an R name).
‘predict(<lm object>, type ="terms", ...)’ failed if both ‘terms’ and ‘interval’ were specified. (Reported by Bill Dunlap.)
Also, if ‘se.fit = TRUE’ the standard errors were reported for all terms, not just those selected by a non-null ‘terms’.
The TRE regular expressions engine could terminate R rather than give an error when given certain invalid regular expressions. (PR#14398)
‘cmdscale(eig = TRUE)’ was documented to return n-1 eigenvalues but in fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add = TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points. Its return value was described wrongly (it is always a list and contains component ‘ac’).
‘promptClass()’ in package ‘methods’ now works for reference classes and gives a suitably specialized skeleton of documentation.
Also, ‘callSuper()’ now works via the ‘methods()’ invocation as well as for initially specified methods.
‘download.file()’ could leave the destination file open if the URL was not able to be opened. (PR#14414)
Assignment of an environment to functions or as an attribute to other objects now works for S4 subclasses of ‘"environment"’.
Use of ‘`[[<-`’ for S4 subclasses of ‘"environment"’ generated an infinite recursion from the method. The method has been replaced by internal code.
In a reference class S4 method, ‘callSuper()’ now works in ‘initialize()’ methods when there is no explicit superclass method.
‘!’ dropped attributes such as names and dimensions from a length-zero argument. (PR#14424)
When ‘list2env()’ created an environment it was missing a ‘PROTECT’ call and so was vulnerable to garbage collection.
‘Sweave()’ with ‘keep.source=TRUE’ dropped comments at the start and end of code chunks. It could also fail when ‘\SweaveInput’ was combined with named chunks.
The Fortran code used by ‘nls(algorithm = "port")’ could infinite-loop when compiled with high optimization on a modern version of ‘gcc’, and ‘SAFE_FFLAGS’ is now used to make this less likely. (PR#14427, seen with 32-bit Windows using ‘gcc 4.5.0’ used from R 2.12.0.)
‘sapply()’ with default ‘simplify = TRUE’ and ‘mapply()’ with default ‘SIMPLIFY = TRUE’ wrongly simplified language-like results, as, e.g., in ‘mapply(1:2, c(3,7), FUN = function(i,j) call(':',i,j))’.
Backreferences to undefined patterns in ‘[g]sub(pcre = TRUE)’ could cause a segfault. (PR#14431)
The ‘format()’ (and hence the ‘print()’) method for class ‘"Date"’ rounded fractional dates towards zero: it now always rounds them down.
Reference S4 class creation could generate ambiguous inheritance patterns under very special circumstances.
‘`[[<-`’ turned S4 subclasses of ‘"environment"’ into plain environments.
Long titles for help pages were truncated in package indices and a few other places.
Additional utilities now work correctly with S4 subclasses of ‘"environment"’ (‘rm’, locking tools and active bindings).
‘spec.ar()’ now also work for the ‘"ols"’ method. (Reported by Hans-Ruedi Kuensch.)
The initialization of objects from S4 subclasses of ‘"environment"’ now allocates a new environment object.
‘R CMD check’ has more protection against (probably erroneous) example or test output which is invalid in the current locale.
‘qr.X()’ with column names and pivoting now also pivots the column names. (PR#14438)
‘unit.pmax()’ and ‘unit.pmin()’ in package ‘grid’ gave incorrect results when all inputs were of length 1. (PR#14443)
The parser for ‘NAMESPACE’ files ignored misspelled directives, rather than signalling an error. For 2.12.x a warning will be issued, but this will be correctly reported as an error in later releases. (Reported by Charles Berry.)
Fix for subsetting of ‘"raster"’ objects when only one of ‘i’ or ‘j’ is specified.
‘grid.raster()’ in package ‘grid’ did not accept ‘"nativeRaster"’ objects (like ‘rasterImage()’ does).
Rendering raster images in PDF output was resetting the clipping region.
Rendering of raster images on Cairo X11 device was wrong, particularly when a small image was being scaled up using interpolation.
With Cairo < 1.6, will be better than before, though still a little clunky. With Cairo >= 1.6, should be sweet as.
Several bugs fixed in ‘read.DIF()’: single column inputs caused errors, cells marked as ‘"character"’ could be converted to other types, and (in Windows) copying from the clipboard failed.
The internal implementation of ‘tar()’ (package ‘utils’) is now supported on Windows.
Several bugs fixed in ‘read.DIF()’: single column inputs caused errors, cells marked as ‘"character"’ could be converted to other types, and (in Windows) copying from the clipboard failed.
‘StructTS(type = "BSM")’ now allows series with just two seasons. (Reported by Birgit Erni.)
Fix for subsetting of ‘"raster"’ objects when only one of ‘i’ or ‘j’ is specified.
‘grid.raster()’ in package ‘grid’ did not accept ‘"nativeRaster"’ objects (like ‘rasterImage()’ does).
Rendering raster images in PDF output was resetting the clipping region.
Rendering of raster images on Cairo X11 device was wrong, particularly when a small image was being scaled up using interpolation.
With Cairo < 1.6, will be better than before, though still a little clunky. With Cairo >= 1.6, should be sweet as.
‘reshape()’ now makes use of ‘sep’ when forming names during reshaping to wide format. (PR#14435)
‘legend()’ allows the length of lines to be set by the end user _via_ the new argument ‘seg.len’.
‘seq.int()’ no longer sometimes evaluates arguments twice. (PR#14388)
When a character value is used for the ‘EXPR’ argument in ‘switch()’, a warning is given if more than one unnamed alternative value is given. This will become an error in R 2.13.0.
New reference class utility methods ‘copy’, ‘field’, ‘getRefClass’ and ‘getClass’ have been added.
The parser for ‘NAMESPACE’ files ignored misspelled directives, rather than signalling an error. For 2.12.x a warning will be issued, but this will be correctly reported as an error in later releases. (Reported by Charles Berry.)
The parser for ‘NAMESPACE’ files ignored misspelled directives, rather than signalling an error. (Reported by Charles Berry.)
New reference class utility methods ‘copy’, ‘getRefClass’ and ‘getClass’ have been added.
‘reshape’ now makes use of ‘sep’ when forming names during reahaping to wide format. (PR#14435)
The PDF reference manual is now built as PDF version 1.5 with object compression, which on platforms for which this is not the default (notably MiKTeX) halves its size.
Variable ‘FCLIBS’ can be set during configuration, for any additional library flags needed when linking a shared object with the Fortran 9x compiler. (Needed with Solaris Studio 12.2.)
‘qr.X()’ with column names and pivoting now also pivots the column names. (PR#14438)
‘unit.pmax()’ and ‘unit.pmin()’ in package ‘grid’ gave incorrect results when all inputs were of length 1. (PR#14443)
The ‘unit.pmax’ and ‘unit.pmin’ in package ‘grid’ gave incorrect results when all inputs were of length 1. (PR#14443)
‘Rgui’ in R 2.12.0 (only) did not always handle lines containing carriage returns (‘\r’) correctly: sometimes random characters where shown.
Since carriage returns have been supported in ‘Rgui’, the cursor positioning after outputting a line containing a carriage return had been unreliable.
‘legend’ allows the length of lines to be set by the end user _via_ the new argument ‘seg.len’.
‘qr.X’ with column names and pivoting now also pivots the column names. (PR#14438)
The DVI/PDF reference manual now includes the help pages for all the standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously omitted (intentionally).
‘R CMD check’ has more protection against (probably erroneous) example or test output which is invalid in the current locale.
‘cmdscale(eig = TRUE)’ was documented to return n-1 eigenvalues but in fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add = TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points. Its return value was described wrongly (it is always a list and contains component ‘ac’).
Backreferences to undefined patterns in ‘[g]sub(pcre = TRUE)’ could cause a segfault. (PR#14431)
The initialization of objects from S4 subclasses of ‘"environment"’ now allocates a new environment object.
The initialization of objects from subclasses of ‘"environment"’ now allocates a new environment object.
‘reshape’ now makes use of ‘sep’ when forming names reahaping to wide format. (PR#14435)
‘reshape’ did not make use of ‘sep’ in all the cases it should have.
(PR#14435)
‘reshape’ did not make use of ‘sep’ in all the cases it should have. (PR#14435)
‘spec.ar()’ now also work for the ‘"ols"’ method. (Reported by Hans-Ruedi Kuensch.)
In R 2.12.0, ‘system(intern = TRUE)’ captured ‘stderr’ on ‘Rterm’ when it was documented to only do so on ‘Rgui’.
Assignment of an environment to functions or as an attribute to other objects now works for S4 subclasses of ‘"environment"’.
‘!’ dropped attributes such as names and dimensions from a length-zero argument. (PR#14424)
The Fortran code used by ‘nls(algorithm = "port")’ could infinite-loop when compiled with high optimization on a modern version of ‘gcc’, and ‘SAFE_FFLAGS’ is now used to make this less likely. (PR#14427, seen with 32-bit Windows using ‘gcc 4.5.0’ used from R 2.12.0.)
Additional utilities now work correctly with S4 subclasses of ‘"environment"’ (‘rm’, locking tools and active bindings).
Reading a package's ‘CITATION’ file now defaults to ASCII rather than Latin-1: a package with a non-ASCII ‘CITATION’ file should declare an encoding in its ‘DESCRIPTION’ file and use that encoding for the ‘CITATION’ file.
There are several small changes to output which ‘zap’ small numbers, e.g. in printing quantiles of residuals in summaries from ‘"lm"’ and ‘"glm"’ fits, and in test statistics in ‘print.anova()’.
‘system(intern = TRUE)’ and ‘pipe()’ connections are guaranteed to be available on all builds of R.
Changing both line texture and line cap (end) resulted in the latter to be omitted form the PDF code. In addition, line cap (end) and join are now set explicitly in PDF output to ensure correct defaults.
‘available.packages()’ by default only returns information on the latest versions of packages whose version requirements are satisfied by the currently running R.
A different regular expression engine is used for basic and extended regexps and is also for approximate matching. This is based on the TRE library of Ville Laurikari, a modified copy of which is included in the R sources.
This is often faster, especially in a MBCS locale.
Some known differences are that it is less tolerant of invalid inputs in MBCS locales, and in its interpretation of undefined (extended) regexps such as ‘"^*"’. Also, the interpretation of ranges such as ‘[W-z]’ in caseless matching is no longer to map the range to lower case.
This engine may in future be used in ‘literal’ mode for ‘fixed = TRUE’, and there is a compile-time option in ‘src/main/grep.c’ to do so.
‘stdin’ is now flushed after echoing the input line.
‘system()’ and ‘system2()’ no longer discard output from the command to stdout and stderr as often as they used to, and more cases of ‘system2()’ are implemented.
The PDF reference manual is now built as PDF version 1.5 with object compression, which on platforms for which this is not the default (notably MiKTeX) halves its size.
Variable ‘FCLIBS’ can be set during configuration, for any additional library flags needed when linking a shared object with the Fortran 9x compiler. (Needed with Solaris Studio 12.2.)
‘sapply()’ with default ‘simplify = TRUE’ and ‘mapply()’ with default ‘SIMPLIFY = TRUE’ wrongly simplified language-like results, as, e.g., in ‘mapply(1:2, c(3,7), FUN = function(i,j) call(':',i,j))’.
Long titles for help pages were truncated in package indices and a few other places.
Additional utilities now work correctly with subclasses of ‘"environment"’ (‘rm’, locking tools and active bindings).
Reference S4 class creation could generate ambiguous inheritance patterns under very special circumstances.
‘`[[<-`’ turned S4 subclasses of ‘"environment"’ into plain environments.
Reference class creation could generate ambiguous inheritance patterns under very special circumstances.
`[[<-` turned subclasses of "environment" into plain environments.
The ‘format()’ (and hence the ‘print()’) method for class ‘"Date"’ rounded fractional dates towards zero: it now always rounds them down.
The DVI/PDF reference manual now includes the help pages for all the
standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously
omitted.
<URL: http://www.rforge.net> has been added to the default set of
repositories known to ‘setRepoositories()’.
The DVI/PDF reference manual now includes the help pages for all the standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously omitted.
<URL: http://www.rforge.net> has been added to the default set of repositories known to ‘setRepoositories()’.
xz-utils has been updated to version 5.0.0.
The PDF reference manual is now built as PDF version 1.5 with object
compression, which on platforms for which this is not the default
(notably MiKTeX) halves its size.
The PDF reference manual is now built as PDF version 1.5 with object compression, which on platforms for which this is not the default (notably MiKTeX) halves its size.
Backreferences to undefined patterns in ‘[g]sub(pcre=TRUE)’ could cause a segfault. (PR#14431)
‘cmdscale(eig=TRUE)’ was documented to return n-1 eigenvalues but in fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add=TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points. Its return value was described wrongly (it is always a list and contains component ‘ac’).
The Fortran code used by ‘nls(algorithm = "port")’ could infinite-loop when compiled with high optimization on a modern version of ‘gcc’, and ‘SAFE_FFLAGS’ is now used to make this less likely. (PR#14427)
‘Sweave()’ with ‘keep.source=TRUE’ dropped comments at the start and end of code chunks. It could also fail when ‘\SweaveInput’ was combined with named chunks.
The MSI installer is now made by an R script, and there is now support for 64-bit builds. (Unlike the Inno Setup installer, there are separate MSI installers for 32- and 64-bit Windows.)
It is now built using ‘WiX 3.x’ rather than ‘WiX 2.0’. (As a result it is about 25% smaller.)
When ‘list2env()’ created an environment it was missing a ‘PROTECT’ call and so was vulnerable to garbage collection.
The DVI/PDF reference manual now includes the help pages for all the standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously omitted.
In a reference class S4 method, ‘callSuper()’ now works in ‘initialize()’ methods when there is no explicit superclass method.
‘!’ dropped attributes such as names and dimensions from a length-zero arguemnt. (PR#14424)
‘promptClass()’ in package ‘methods’ now works for reference classes and gives a suitably specialized skeleton of documentation.
Also, ‘callSuper()’ now works via the ‘methods()’ invocation as well as for initially specified methods.
‘system()’ and ‘system2()’ no longer discard output from the command to stdout and stderr as often as they used to.
The MSI installer is now made by an R script, and there is now support for 64-bit builds.
It is now built using ‘WiX 3.0’ rather than ‘WiX 2.0’. (As a result it is about 25% smaller.)
The 32- and 64-bit distributions have been merged:
There is a combined installer (called ‘R-<version>-win.exe’). When used under 32-bit Windows this works as before and installs 32-bit R. When used under 64-bit Windows there are options to install either or both of 32- and 64-bit R: the default is to install both.
The default package type is ‘"win.binary"’ on both 32- and 64-bit builds: a single repository contains binary packages for both architectures. This is in place for CRAN, CRAN extras and BioC: ‘type = "win64.binary"’ can still be used for any repositories which follow the R 2.11.x convention. With the default filters (see ‘?available.packages’) packages will only be offered if they are available for the current architecture.
The default personal library, e.g. ‘~/R/win-library/2.12’ is now the same for both 32- and 64-bit R.
The recommended 64-bit toolchain has been changed to one that does not add leading underscores. See <URL: http://www.murdoch-sutherland.com/Rtools/> or <URL: http://www.stats.ox.ac.uk/pub/Rtools/>. Any static or import libraries for external software used in installing packages will need to be re-compiled for this toolchain, but the use of DLLs is unaffected.
‘system()’ (and hence ‘shell()’) did not always set the standard file handles properly, so some programs would not run.
The MSI installer is now made by an R script, and there is now support for 64-bit builds.
Some warning/error messages from ‘dyn.load()’ could be masked in ‘Rgui’ on Windows 7, as that OS can return messages containing carriage returns and ‘Rgui’ does not support overwriting.
Filenames could not be specified using backslashes in ‘Sweave()’.
‘cmdscale(eig=TRUE)’ was documented to return n-1 eigenvalues but in fact only returned ‘k’. It now returns all n eigenvalues.
‘cmdscale(add=TRUE)’ failed to centre the return configuration and sometimes lost the labels on the points.
‘download.file()’ could leave the destination file open if the URL was not able to be opened. (PR#14414)
Assignment of an environment to functions or as an attribute to other objects now works for S4 subclases of ‘"environment"’.
Use of ‘`[[<-`’ for S4 subclasses of ‘"environment"’ generated an infinite recursion from the method. The method has been replaced by internal code.
Assignment of an environment to functions or as an attribute to other objects now works for subclases of ‘"environment"’.
Use of ‘`[[<-`’ for subclasses of ‘"environment"’ generated and infinite recursion from the method. The method has been replaced by internal code.
<URL: http://www.rforge.net> has been added to the default set of repositories known to ‘setRepoositories()’.
‘cmdscale(eig=TRUE)’ was documented to return n-1 eigenvalues but in fact only returned ‘k’. It now returns all n eigenvalues.
It failed to centre the return configuration and sometimes lost the labels on the points if ‘add = TRUE’.
‘download.file()’ could leave the destination file open if a http or ftp URL was not able to be opened. (PR#14414)
‘system()’ and ‘system2()’ with output redirected to a character vector now give a warning if the command returns a non-zero error code. (This is what a Unix-alike does as from R 2.12.0.)
‘promptClass()’ now works for reference classes and gives a suitably specialized skeleton of documentation.
Also, ‘callSuper()’ now works via the ‘methods()’ invocation as well as for initially specified methods.
The DVI/PDF reference manual now includes the help page for all the standard packages: ‘splines’, ‘stats4’ and ‘tcltk’ were previously omitted.
The PDF reference manual is now built as PDF version 1.5 with object compression, which on platforms for which this is not the default (notably MiKTeX) halves its size.
‘seq.int’ no longer sometimes evaluates arguments twice. (PR#14388)
The ‘data.frame’ method of ‘format’ failed if a column name was longer than 256 bytes (the maximum length allowed for an R name).
‘predict(<lm object>, type ="terms", ...)’ failed if both ‘terms’ and ‘interval’ were specified. (Reported by Bill Dunlap.)
Also, if ‘se.fit = TRUE’ the standard errors were reported for all terms, not just those selected by a non-null ‘terms’.
The TRE regular expressions engine could terminate R rather than give an error when given certain invalid regular expressions. (PR#14398)
File ‘NEWS’ is now generated at installation with a slightly different format: it will be in UTF-8 on platforms using UTF-8, and otherwise in ASCII. There is also a PDF version, ‘NEWS.pdf’, installed at the top-level of the R distribution.
A new facility has been added for inserting code into a package without re-installing it, to facilitate testing changes which can be selectively added and backed out. See ‘?insertSource’.
‘system(command, intern = TRUE)’ now gives an error on a Unix-alike (as well as on Windows) if ‘command’ cannot be run. It reports a non-success exit status from running ‘command’ as a warning.
On a Unix-alike an attempt is made to return the actual exit status of the command in ‘system(intern = FALSE)’: previously this had been system-dependent but on POSIX-compliant systems the value return was 256 times the status.
New ‘adjustcolor()’ utility, e.g., for simple translucent color schemes.
‘R CMD check’ has a new argument ‘--extra-arch’ to confine tests to those needed to check an additional sub-architecture.
Its check for “Subdirectory 'inst' contains no files” is more thorough: it looks for files, and warns if there are only empty directories.
Environment variables such as ‘R_LIBS’ and those used for customization can be set for the duration of checking _via_ a file ‘~/.R/check.Renviron’ (in the format used by ‘.Renviron’, and with sub-architecture specific versions such as ‘~/.R/check.Renviron.i386’ taking precedence).
There are new options ‘--multiarch’ to check the package under all of the installed sub-architectures and ‘--no-multiarch’ to confine checking to the sub-architecture under which ‘check’ is invoked. If neither option is supplied, a test is done of installed sub-architectures and all those which can be run on the current OS are used.
Unless multiple sub-architectures are selected, the install done by ‘check’ for testing purposes is only of the current sub-architecture (_via_ ‘R CMD INSTALL --no-multiarch’).
It will skip the check for non-ascii characters in code or data if the environment variables ‘_R_CHECK_ASCII_CODE_’ or ‘_R_CHECK_ASCII_DATA_’ are respectively set to ‘FALSE’. (Suggestion of Vince Carey.)
‘R CMD build’ no longer creates an ‘INDEX’ file (‘R CMD INSTALL’ does so), and ‘--force’ removes (rather than overwrites) an existing ‘INDEX’ file.
It supports a file ‘~/.R/build.Renviron’ analogously to ‘check’.
It now runs build-time ‘\Sexpr’ expressions in help files.
‘R CMD Rprof|build|check’ are now based on R rather than Perl scripts. The only remaining Perl scripts are the deprecated ‘R CMD Sd2Rd’ and ‘install-info.pl’ (used only if ‘install-info’ is not found) as well as some maintainer-mode-only scripts.
*NB:* because these have been completely rewritten, users should not expect undocumented details of previous implementations to have been duplicated.
‘R CMD’ no longer manipulates the environment variables ‘PERL5LIB’ and ‘PERLLIB’.
‘R CMD build’ no longer creates an ‘INDEX’ file (‘R CMD INSTALL’ does so), and ‘--force’ removes (rather than overwrites) an existing ‘INDEX’ file.
It supports file ‘~/.R/build.Renviron’ analogously to ‘check’.
It now runs build-time ‘\Sexpr’ expressions in help files.
The 256-byte limit on names is now documented.
Subassignment by ‘[’, ‘[[’ or ‘$’ on an expression object with value ‘NULL’ coerced the object to a list.
‘model.frame’ had an unstated 500 byte limit on variable names. (Example reported by Terry Therneau.)
Force Quartz to bring the on-screen display up-to-date immediately before the snapshot is taken by ‘grid.cap()’ in the Cocoa implementation. (PR#14260)
Added workaround for the font problem with ‘X11(type = "cairo")’ and similar on Mac OS X whereby italic and bold styles were interchanged. (PR#13463 amongst many other reports.)
Functions using the ‘TAR’ environment variable no longer quote the value when making ‘system’ calls. This allows values such as ‘tar --force-local’, but does require additional quotes in, e.g., ‘TAR = "'/path with spaces/mytar'"’.
R has always required a BLAS that conforms to IE60559 arithmetic, but after discovery of more real-world problems caused by a BLAS that did not, this is tested more thoroughly in this version.
Fix for crash of ‘example(rasterImage)’ on ‘x11(type="Xlib")’.
‘R CMD build’ now runs build-time ‘\Sexpr’ expressions.
‘R CMD check’ will skip the check for non-ascii characters in code or
data if the environment variables ‘_R_CHECK_ASCII_CODE_’ or
‘_R_CHECK_ASCII_DATA_’ are respectively set to ‘FALSE’. (Suggestion of
Vince Carey.)
‘R CMD check’ has a new argument ‘--extra-arch’ to confine tests to those needed to check an additional sub-architecture.
Its check for “Subdirectory 'inst' contains no files” is more thorough: it looks for files, and warns if there are only empty directories.
Environment variables such as ‘R_LIBS’ and those used for customization can be set for the duration of checking _via_ a file ‘~/.R/check.Renviron’ (in the format used by ‘.Renviron’, and with sub-architecture specific versions such as ‘~/.R/check.Renviron.i386’ taking precedence).
There are new options ‘--multiarch’ to check the package under all of the installed sub-architectures and ‘--no-multiarch’ to confine checking to the sub-architecture under which ‘check’ is invoked. If neither option is supplied, a test is done of installed sub-architectures and those which can be run on the current OS are used.
Unless multiple sub-architectures are selected, the install done by ‘check’ for testing purposes is only of the current sub-architecture (_via_ ‘R CMD INSTALL --no-multiarch’.
It will skip the check for non-ascii characters in code or data if the environment variables ‘_R_CHECK_ASCII_CODE_’ or ‘_R_CHECK_ASCII_DATA_’ are respectively set to ‘FALSE’. (Suggestion of Vince Carey.)
‘R CMD build’ no longer creates an ‘INDEX’ file (‘R CMD INSTALL’ does so), and ‘--force’ removes (rather than overwrites) an existing ‘INDEX’ file.
It supports file ‘~/.R/build.Renviron’ analogously to ‘check’.
It no longer cleans the supplied directory but rather a copy used to create the tarball.
It now runs build-time ‘\Sexpr’ expressions.
System functions ‘access’, ‘chdir’ and ‘getcwd’ are now essential to configure R. (In practice they have been required for some time.)
The ‘popen’ system call is now required to build R. This ensures the availability of ‘system(intern = TRUE)’, ‘pipe()’ connections and printing from ‘postscript()’.
‘source(chdir = TRUE)’ failed to reset the working directory if it could not be determined - that is now an error.
Added workaround for the font problem with ‘X11(type = "cairo")’ and similar on Mac OS X whereby italic and bold styles were interchanged. (PR13463 amongst many other reports.)
‘X11(type = "cairo")’ (and other devices such as ‘png’ using cairographics) and which use Pango font selection now work around a bug in Pango when very small fonts (those with sizes between 0 and 1 in Pango's internal units) are requested. (PR#14369)
Workaround font problem with ‘X11(type = "cairo")’ and similar on Mac OS X whereby italic and bold styles were interchanged. (PR13463 amongst many other reports.)
The self-starting model ‘NLSstClosestX’ failed if some deviation was exactly zero. (PR#14384)
‘system(intern = FALSE)’ now returns ‘127’ (the same as Unix-alikes) rather than ‘-1’ if the command cannot be run, and (like Unix-alikes) no longer gives a warning.
‘R.exe’ when used in place of ‘Rterm.exe’ set the environment variables set by ‘R CMD’. Conversely, ‘R CMD BATCH’ did not.
‘memory.limit()’ did not allow sizes greater than 4095 on 64 bit builds. (PR#14372)
‘model.frame(drop.unused.levels = TRUE)’ did not take into account ‘NA’ values of factors when deciding to drop levels. (PR#14393)
‘library.dynam.unload’ required an absolute path for ‘libpath’. (PR#14385)
Both ‘library()’ and ‘loadNamespace()’ now record absolute paths for use by ‘searchpaths()’ and ‘getNamespaceInfo(ns, "path")’.
The self-staring model ‘NLSstClosestX’ failed if some deviation was exactly zero. (PR#14384)
The calculation of whether text was completely outside the device region (in which case, you draw nothing) was wrong for screen devices (which have [0, 0] at top-left). The symptom was (long) text disappearing when resizing a screen window (to make it smaller). (PR#14391)
The 32- and 64-bit distributions have been merged:
There is a combined installer (called ‘R-<version>-win.exe’). When used under 32-bit Windows this works as before and installs 32-bit R. When used under 64-bit Windows there are options to install either or both of 32- and 64-bit R: the default is to install both.
The default package type is ‘"win.binary"’ on both 32- and 64-bit builds: a single repository contains binary packages for both architectures. This is in place for CRAN, CRANextras and BioC: ‘type = "win64.binary"’ can still be used for any repositories which follow the R 2.11.x convention. With the default filters (see ‘?available.packages’) packages will only be offered if they are available for the current architecture.
The default personal library, e.g. ‘~/R/win-library/2.12’ is now the same for both 32- and 64-bit R.
The recommended 64-bit toolchain has been changed to one that does not add leading underscores. See <URL: http://www.murdoch-sutherland.com/Rtools/> or <URL: http://www.stats.ox.ac.uk/pub/Rtools/>. Any static or import libraries for external software used in installing packages will need to be re-compiled for this toolchain, but the use of DLLs is unaffected.
‘Rscript -e’ and similar use a temporary file, and now work harder to ensure that filename is not the same as some other simultaneous R process.
The ‘pkg-config’ file ‘libR.pc’ now also works when R is installed using a sub-architecture.