[Rd] assign, documentation (PR#1434)

Robert Gentleman rgentlem@jimmy.harvard.edu
Thu, 4 Apr 2002 10:52:07 -0500


On Thu, Apr 04, 2002 at 05:37:18PM +0200, Peter Dalgaard BSA wrote:
> ripley@stats.ox.ac.uk writes:
> 
> > On Thu, 4 Apr 2002 Martin.Schlather@uni-bayreuth.de wrote:
> > 
> > > The help for `assign' says
> > >
> > >  In all the assignment operator expressions, `x' can be a name or
> > >  an expression defining a part of an object to be replaced (e.g.,
> > >  `z[[1]]').  The name does not need to be quoted, though it can be.
> > >
> > > So I would expect that by
> > >  a<-1:4
> > >  assign("a[1]",2)
> > > the first component of a gets the value 2, but the object "a[1]" is
> > > created.
> > > Could this be clarified in the documentation?
> > 
> > Could you suggest how?  You quoted an *expression*, and the page refers to
> > quoting a *name*, so I don't know that I see the crux here.
> 
> Actually, it *is* a name that is getting quoted, it just has these weird
> bracket characters in it, so it is not "syntactically valid". 
> 
> One improvement might be: "the name can be any string of text and may
> be quoted, but this is only necessary if it is not a syntactically
> valid name."
> 
  I think the original point was that he expected that a[1] would be
  changed not that a new variable named "a[1]" would be created. I
  don't think your suggestion will help with this. I think that Brian
  is correct, unless of course you want to spend some amount of time
  figuring out the logic/parsing requirements.

  "Assign treats the quoted string as a symbol, it does not parse it in
  any way", might help.  On the otherhand, in some large number of
  years this is the first person who has had this problem, I'm not
  sure we should be documenting for less than 1% of the population 
  unless of course,
    "we are trying to be as accurate as possible without regard to
  readability"  :-), to quote the views of a certain member of R core
  on documentation.




> We might also emphasize that "assignment operator expressions" does
> not include assign(), only <-, <<-, and =. (And _ until we finally get
> it killed...). On the other hand it is arguably clear enough already,
> if read carefully. (For this reason alone, the posters remark is off
> base, but he might have asked about "a[1]" <- 2.)
> 
> In assign(), `x' must be a character object. As in
> 
> > a <- "b"
> > assign(a,2)
> > a
> [1] "b"
> > b
> [1] 2
> 
> 
> -- 
>    O__  ---- Peter Dalgaard             Blegdamsvej 3  
>   c/ /'_ --- Dept. of Biostatistics     2200 Cph. N   
>  (*) \(*) -- University of Copenhagen   Denmark      Ph: (+45) 35327918
> ~~~~~~~~~~ - (p.dalgaard@biostat.ku.dk)             FAX: (+45) 35327907
> -.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-
> r-devel mailing list -- Read http://www.ci.tuwien.ac.at/~hornik/R/R-FAQ.html
> Send "info", "help", or "[un]subscribe"
> (in the "body", not the subject !)  To: r-devel-request@stat.math.ethz.ch
> _._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._

-- 
+---------------------------------------------------------------------------+
| Robert Gentleman                 phone : (617) 632-5250                   |
| Associate Professor              fax:   (617)  632-2444                   |
| Department of Biostatistics      office: M1B28
| Harvard School of Public Health  email: rgentlem@jimmy.dfci.harvard.edu   |
+---------------------------------------------------------------------------+
-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-
r-devel mailing list -- Read http://www.ci.tuwien.ac.at/~hornik/R/R-FAQ.html
Send "info", "help", or "[un]subscribe"
(in the "body", not the subject !)  To: r-devel-request@stat.math.ethz.ch
_._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._