[Rd] RAqua package installation on Panther
Stefano Iacus
stefano.iacus at unimi.it
Thu Nov 6 10:22:21 MET 2003
From the RAqua faq just uploaded to CRAN (so it will take until
tomorrow to appear)
Panther notes
After installing Panther (MacOSX 10.3) it turns out that package
installation (either from sources or from binaries) can fail. If you
get an error "like" this (this comes from source package installation)
dyld: gcc version mismatch for library: /usr/local/lib/libiconv.2.dylib
(compatibility version of user: 5.0.0 greater than library's version:
4.0.0)
i.e. you get an incompatibility error for the libiconv library, this is
probably due to the fact that you have the "libiconv" dll in the
"/usr/local/lib" path. It seems that this library is installed on
Jaguar (MacOSX 10.2.x) with the distribution of teTex that comes from
the "i-installer 2". If you install the same te TeX distribution on
Panther and you didn't have a previous installed one on Jaguar, then
this library is not installed in "/usr/local/bin". So this is not a
i-installer bug or a RAqua bug. The problem comes from GNU based
command line tools (for example gcc and tar) that use this dll which is
installed in "/usr/lib" under Panther.
The fix
If you only need to install packages from binaries, you just need to
write the following command in a R session <i>before</i> attempting to
install packages
dyld <- Sys.getenv("DYLD_LIBRARY_PATH")<br>
Sys.putenv("DYLD_LIBRARY_PATH"=paste("/usr/lib",dyld,sep=":"))
This fix is for non-expert unix user and only fix binary installation
and should be done each time you need to install packages from binaries
(on a per-session basis, i.e. only one time a session).
The more robust fix that also fixes source package installation is to
edit the main R script file which is
/Applications/StartR.app/RAqua.app/Contents/MacOS/R
in order to have /usr/bin as the first path entry in the
DYLD_LIBRARY_PATH environment variable. For example transform this
piece of script from
if test -z "${DYLD_LIBRARY_PATH}"; then
DYLD_LIBRARY_PATH="${R_LD_LIBRARY_PATH}"
else<br>
DYLD_LIBRARY_PATH="${R_LD_LIBRARY_PATH}:${DYLD_LIBRARY_PATH}"
fi
export DYLD_LIBRARY_PATH<br>
into the following one
if test -z "${DYLD_LIBRARY_PATH}"; then
DYLD_LIBRARY_PATH="${R_LD_LIBRARY_PATH}"
else
DYLD_LIBRARY_PATH="${R_LD_LIBRARY_PATH}:${DYLD_LIBRARY_PATH}"
fi
DYLD_LIBRARY_PATH="/usr/bin:${DYLD_LIBRARY_PATH}" ## just this line
added
export DYLD_LIBRARY_PATH
Thanks to Thomas L. and other users to stop this and suggest fixes.
Thomas is still claiming that it is also configure that fails on
panther because of the same problem.
My own experience is that
* on a fresh Panther installation (i.e. removing jaguar, tex etc...I
formatted my boot disk)
* using g77 from the RAqua page
* installing teTeX with the i-installer
* configuring for RAqua
I get not problem and all went smoothly for yesterday (nov 5th) R-devel.
Please let us know, possibly before the end of the next week (i.e. in
time for R.1.8.1), if you have other problems with Panther.
stefano
More information about the R-devel
mailing list