% File src/library/base/man/deparseOpts.Rd % Part of the R package, http://www.R-project.org % Copyright 1995-2014 R Core Team % Distributed under GPL 2 or later \name{deparseOpts} \alias{.deparseOpts} \title{Options for Expression Deparsing} \description{ Process the deparsing options for \code{deparse}, \code{dput} and \code{dump}. } \usage{ .deparseOpts(control) } \arguments{ \item{control}{character vector of deparsing options.} } \details{ This is called by \code{\link{deparse}}, \code{\link{dput}} and \code{\link{dump}} to process their \code{control} argument. The \code{control} argument is a vector containing zero or more of the following strings. Partial string matching is used. \describe{ \item{\code{keepInteger}}{ Either surround integer vectors by \code{as.integer()} or use suffix \code{L}, so they are not converted to type double when parsed. This includes making sure that integer \code{NA}s are preserved (via \code{NA_integer_} if there are no non-\code{NA} values in the vector, unless \code{"S_compatible"} is set). } \item{\code{quoteExpressions}}{ Surround expressions with \code{quote()}, so they are not evaluated when re-parsed. } \item{\code{showAttributes}}{ If the object has attributes (other than a \code{source} attribute), use \code{structure()} to display them as well as the object value. This is the default for \code{\link{deparse}} and \code{\link{dput}}. } \item{\code{useSource}}{ If the object has a \code{source} attribute, display that instead of deparsing the object. Currently only applies to function definitions. } \item{\code{warnIncomplete}}{ Some exotic objects such as \link{environment}s, external pointers, etc. can not be deparsed properly. This option causes a warning to be issued if the deparser recognizes one of these situations. Also, the parser in \R < 2.7.0 would only accept strings of up to 8192 bytes, and this option gives a warning for longer strings. } \item{\code{keepNA}}{ Integer, real and character \code{NA}s are surrounded by coercion functions where necessary to ensure that they are parsed to the same type. Since e.g.\sspace{}\code{NA_real_} can be output in \R, this is mainly used in connection with \code{S_compatible}. } \item{\code{all}}{ An abbreviated way to specify all of the options listed above. This is the default for \code{dump}, and the options used by \code{\link{edit}} (which are fixed). } \item{\code{delayPromises}}{ Deparse promises in the form rather than evaluating them. The value and the environment of the promise will not be shown and the deparsed code cannot be sourced. } \item{\code{S_compatible}}{ Make deparsing as far as possible compatible with S and \R < 2.5.0. For compatibility with S, integer values of double vectors are deparsed with a trailing decimal point. Backticks are not used. } \item{\code{hexNumeric}}{ Real and finite complex numbers are output in \samp{"\%a"} format as binary fractions (coded as hexadecimal: see \code{\link{sprintf}}) with maximal opportunity to be recorded exactly to full precision. Complex numbers with one or both non-finite components are output as if this option were not set. All platforms can \code{source} this format as from \R 2.7.0. } \item{\code{digits17}}{ Real and finite complex numbers are output using format \samp{"\%.17g"} which may give more precision than the default (but the output will depend on the platform and there may be loss of precision when read back). Complex numbers with one or both non-finite components are output as if this option were not set. } } For the most readable (but perhaps incomplete) display, use \code{control = NULL}. This displays the object's value, but not its attributes. The default in \code{\link{deparse}} is to display the attributes as well, but not to use any of the other options to make the result parseable. (\code{\link{dput}} and \code{\link{dump}} do use more default options, and printing of functions without sources uses \code{c("keepInteger", "keepNA")}.) Using \code{control = "all"} comes closest to making \code{deparse()} an inverse of \code{parse()}. However, not all objects are deparse-able even with this option. A warning will be issued if the function recognizes that it is being asked to do the impossible. Also, representing double and complex numbers as decimals may well not be exact. Only one of \code{"hexNumeric"} and \code{"digits17"} can be specified. } \value{ A numerical value corresponding to the options selected. } \keyword{programming}