[Rd] attach/detach asymmetry

From: Barry Rowlingson <b.rowlingson_at_lancaster.ac.uk>
Date: Wed, 16 May 2007 19:54:38 +0100

Is there a good reason why arguments to 'attach' and 'detach' differ so much? Yes, I know this is the documented behaviour, it just seems to violate the principle of least surprise.


  file = "foo.RData"
  df = data.frame(x=1:10,y=1:10)

  attach(file) # attaches the RData file 'foo.RData'   attach(df) # attaches the object df

  Not surprising in an OO system that a function operating on different things does different things. However:

  detach(df) - works as expected

  Error in detach(file) : invalid name

  That's surprise number 1.

  Oh well, lets type the filename out:

  Error in detach("foo.RData") :

          invalid name

  Surprise number 2.

  Check the search() list, and you see that R has stuck 'file:' on the start of your file path. So try that:


  and that works nicely. No surprise there, except perhaps that nothing surprising happened.

  So, maybe you can attach() with a 'file:' prefix?

  Error in attach("file:foo.RData") :

         file 'file:foo.RData' not found

This is all documented behaviour (actually, I cant find any documentation on the 'file:' prefixing), but am I the only person who finds it inelegant? Or even downright ugly that the help page for detach() gives this example code for attaching and detaching by name?

attach_and_detach <- function(db, pos=2)

         name <- deparse(substitute(db))
         attach(db, pos=pos, name=name)
         eval(substitute(detach(n), list(n=name)))

  I think this could be solved by changing detach(foo) to do something different if foo is a character string, and adding the 'file:' prefix internally. Or maybe they need rewriting as proper methods?

  Perhaps I'm just being over-sensitive about a matter of aesthetics...


R-devel_at_r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-devel Received on Wed 16 May 2007 - 18:54:40 GMT

Archive maintained by Robert King, hosted by the discipline of statistics at the University of Newcastle, Australia.
Archive generated by hypermail 2.2.0, at Wed 16 May 2007 - 19:32:48 GMT.

Mailing list information is available at https://stat.ethz.ch/mailman/listinfo/r-devel. Please read the posting guide before posting to the list.