[R] R package: Where to put code to Run Once Only?

Martin Morgan mtmorgan at fhcrc.org
Tue Apr 7 06:11:44 CEST 2009


Rolf Turner <r.turner at auckland.ac.nz> writes:

> On 7/04/2009, at 3:34 PM, Ken-JP wrote:
>
> 	<snip>
>
>> Using NAMESPACE, I was able to hide my globals behind a  "." (eg
>> .myGlobal
>> <<- 72) and use exportPattern("^[^\\.]*") to prevent users from
>> seeing my
>> globals, yet I was able to access their values inside my package.
>
> 	<snip>
>
> 	WHY do you want to ``prevent users from seeing [your] globals''?
>
> 	The whole point of R (well, maybe not the whole point, but a major
> 	point) is to be adaptable.  If something doesn't work the way a user
> 	wants, then the user can change things.  When the inner workings
> 	are hidden so deeply that the user can't see what to change, this
> 	becomes effectively impossible, and the user might as well go and
> 	use SAS.
>
> 	I exaggerate but slightly.
>
> 	Nevertheless, this syndrome of hiding things and making them
> 	effectively
> 	inaccessible --- which seems to have become an obsession with some

ls(getNamespace("<pkg>"), all=TRUE)

gets all the symbol names.

<pkg>:::symbol

gets non-exported values. What does the 'user' get in return? A
cleaner interface to the important functionality of the package,
faster symbol lookup, reduced opportunities for symbol masking between
packages. And with use of Imports:, unambiguous symbol look-up within
the package and shorter symbol search path.

Martin

> 	of the
> 	R community, particularly many of the senior members --- bugs the
> 	living
> 	Drambuie out of me.
>
> 		cheers,
>
> 			Rolf Turner
>
> ######################################################################
> Attention:\ This e-mail message is privileged and confid...{{dropped:9}}
>
> ______________________________________________
> R-help at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
> and provide commented, minimal, self-contained, reproducible code.

-- 
Martin Morgan
Computational Biology / Fred Hutchinson Cancer Research Center
1100 Fairview Ave. N.
PO Box 19024 Seattle, WA 98109

Location: Arnold Building M1 B861
Phone: (206) 667-2793




More information about the R-help mailing list