[Rd] conditionally import a namespace?

Duncan Murdoch murdoch at stats.uwo.ca
Thu Oct 30 16:03:53 CET 2008


On 10/30/2008 10:44 AM, Duncan Murdoch wrote:
> On 10/30/2008 10:15 AM, Martin Maechler wrote:
>>>>>>> "FA" == Felix Andrews <felix at nfrac.org>
>>>>>>>     on Thu, 30 Oct 2008 17:40:17 +1100 writes:
>> 
>>     FA> Dear R-devel,
>>     FA> I have a problem defining the dependencies for a package.
>> 
>>     FA> My package (latticist, not yet released) "Suggests" RGtk2, but
>>     FA> specifically does not require it. If RGtk2 is available, the user can
>>     FA> call a function that builds a GUI with RGtk2. However, I do not want
>>     FA> to attach the RGtk2 namespace, because it is irrelevant to the user
>>     FA> and exports about 7500 symbols.
>> 
>>     FA> Last time I asked a similar question to this, Professor Ripley noted
>>     FA> that the usual method to get around this situation is the use an
>>     FA> explicit package prefix to function calls (the `::` operator). But
>>     FA> this is not so easy with non-standard functions. Take this chunk of
>>     FA> code:
>> 
>>     FA> widg <- gtkComboBoxEntryNewText()
>>     FA> widg$show()
>>     FA> widg["width-request"] <- 100
>> 
>>     FA> The first call is easy to prefix, as RGtk2::gtkComboBoxEntryNewText()
>>     FA> but the others, `$.RGtkObject` and `[<-.RGtkObject` are not.
>> 
>> indeed.
>> 
>>     FA> While I *could* rewrite all the code to use explicit functions, I
>>     FA> think, the resulting code would be much less clear.
>> 
>>     FA> Essentially what I want to do is conditionally import the RGtk2 namespace.
>>     FA> Any suggestions?
>> 
>> Maybe something along the line of
>> 
>> if(is.function(try(RGtk2::gtkComboBoxEntryNewText))) {
>>    library(RGtk2)
>>    ....
>>    ....
>> }
>> 
>> ??
> 
> I think the problem is that that puts the namespace on the user's search 
> list, which is what Felix wanted to avoid.  He would like to 
> import(RGtk2), but only if it exists.
> 
> There are conditionals allowed in NAMESPACE files, but I don't know if 
> they are allowed to be used to control imports.  They are not well 
> documented -- they were called "experimental" when introduced in 1.9.0.
> 
> If this is allowed, then something like
> 
> if( "RGtk2" %in% rownames(installed.packages()) ) {
>    import(RGtk2)
> }
> 
> should work.

I just did a little test, and it does appear to work if you use 
utils::installed.packages in the condition.  And one clarification: 
those lines go into your NAMESPACE file, not into R code.

Duncan Murdoch



More information about the R-devel mailing list