[R-SIG-Mac] Starting tcltk without Tk
Simon Urbanek
simon.urbanek at r-project.org
Tue May 6 15:29:56 CEST 2008
On May 6, 2008, at 3:06 AM, Philippe Grosjean wrote:
> Simon Urbanek wrote:
>> It turns out that the behavior of starting just Tcl was actually a
>> bug.
>
> Not completely. At least, loading of tcltk was correct when the
> "bug" was there, but I totally agree that the mechanism used
> (according to the presence or not of the DISPLAY variable is not the
> best one). It is not true that there was no intention to allow
> loading tcltk without Tk. Otherwise, why would you have this
> (tcltk.c, tcltk_init(), line 643 in the R 2.7.0 source):
>
> warning(_("no DISPLAY variable so Tk is not available"));
>
> This message strongly suggests that starting tcltk without Tk is
> allowed, and it also suggests the mechanism: by eliminating the
> DISPLAY environment variable before starting tcltk. It is certainly
> undocumented, most probably underused, and certainly requires a
> better way to specify that the user does want to load Tk,... but at
> least, it worked for me up to now.
>
Philippe, you missed the one important line - please read the whole
code - there is
#if !defined(Win32) && !defined(HAVE_AQUA)
before that and that is the crucial part.
Cheers,
Simon
>> Apparently the intention was to attempt to start Tk regardless of
>> the DISPLAY variable, because some TclTk implementation such as
>> Aqua Tcl/Tk don't require DISPLAY and thus would not be loaded. Due
>> to a bug (HAVE_AQUA was not included in Rconfig.h before R 2.7.0),
>> though, this was not the case. I'll leave it to tcltk users/
>> maintainers to decide the right way forward. Essentially I see two
>> options:
>> 1) status quo: tcltk always attempts to load Tk and fails on an error
>> 2) allow some (possibly cross-platform) way of specifying that it
>> is ok to not load Tk - essentially make failure to load Tk non-fatal.
>
> I vote for the second option.
> Many thanks,
>
> Philippe
>
>> Right now there is no (semantically correct) way to inhibit the
>> loading of Tk (DISPLAY is a sort of abuse and not a solution).
>> Cheers,
>> Simon
>> (CC to R-devel where this started...)
>> On May 5, 2008, at 9:12 AM, Simon Urbanek wrote:
>>> Philippe,
>>>
>>> I'm not quite sure why you are asking on a Mac list, but the error
>>> comes from Tcl/Tk. I'd suggest asking on R-devel, the Tcl/Tk used
>>> in the R binary is the same for R 2.6.x and 2.7.0 so it must be a
>>> change in tcltk.
>>>
>>> Cheers,
>>> Simon
>>>
>>>
>>> On May 4, 2008, at 7:01 AM, Philippe Grosjean wrote:
>>>
>>>> Hello,
>>>>
>>>> Up to R 2.6.2, I used to start Tcl *without Tk* (I need only Tcl
>>>> for some part of my work, like a socket server written in Tcl
>>>> only, for instance) with this code under Mac OS X (particularly
>>>> on this system, because I don't want to start X11 just to use Tcl
>>>> code, which is required for Tk!):
>>>>
>>>> > Sys.unsetenv("DISPLAY")
>>>> > library(tcltk)
>>>>
>>>> I got then the message "no DISPLAY variable so Tk is not
>>>> available", but could work with Tcl without problems.
>>>>
>>>> Now, with R 2.7.0, I got the following and Tcl failed to load:
>>>> Loading Tcl/Tk interface ... Error in fun(...) : no display name
>>>> and no $DISPLAY environment variable
>>>> Error : .onLoad failed in 'loadNamespace' for 'tcltk'
>>>> Error: package/namespace load failed for 'tcltk'
>>>>
>>>> I try to locate the message "no display name and no $DISPLAY
>>>> environment variable" in the code but I cannot find it. Could
>>>> someone help me please?
>>>>
>>>> I understand that starting Tcl without Tk from R is not an
>>>> intended behaviour, but would it be possible to include an option
>>>> to do so?
>>>>
>>>> > sessionInfo()
>>>> R version 2.7.0 Patched (2008-04-22 r45460)
>>>> i386-apple-darwin8.10.1
>>>>
>>>> locale:
>>>> en_US.UTF-8/en_US.UTF-8/C/C/en_US.UTF-8/en_US.UTF-8
>>>>
>>>> attached base packages:
>>>> [1] stats graphics grDevices utils datasets methods
>>>> base
>>>>
>>>> Many thanks,
>>>>
>>>> Philippe Grosjean
>>>> --
>>>> ..............................................<°}))><........
>>>> ) ) ) ) )
>>>> ( ( ( ( ( Prof. Philippe Grosjean
>>>> ) ) ) ) )
>>>> ( ( ( ( ( Numerical Ecology of Aquatic Systems
>>>> ) ) ) ) ) Mons-Hainaut University, Belgium
>>>> ( ( ( ( (
>>>> ..............................................................
>>>>
>>>> _______________________________________________
>>>> R-SIG-Mac mailing list
>>>> R-SIG-Mac at stat.math.ethz.ch
>>>> https://stat.ethz.ch/mailman/listinfo/r-sig-mac
>>>>
>>>>
>>>
>>> _______________________________________________
>>> R-SIG-Mac mailing list
>>> R-SIG-Mac at stat.math.ethz.ch
>>> https://stat.ethz.ch/mailman/listinfo/r-sig-mac
>>>
>>>
>
>
More information about the R-SIG-Mac
mailing list