|
[Rivet] Minor bug in rivet-bootstrap [Re: Rivet 1.5.0 released]Ben Waugh waugh at hep.ucl.ac.ukTue Mar 15 21:57:07 GMT 2011
waugh> python Python 2.4.3 (#1, Jan 14 2011, 22:42:01) [GCC 4.1.2 20080704 (Red Hat 4.1.2-48)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> import distutils.sysconfig >>> print distutils.sysconfig.get_python_lib(prefix='/foo') /foo/lib/python2.4/site-packages If I understand correctly after a few minutes with Goole, this is a long-standing bug in distutils. See e.g. http://mail.python.org/pipermail/distutils-sig/2005-April/004466.html Cheers, Ben On 15/03/11 18:11, Andy Buckley wrote: > On 15/03/11 13:14, Ben Waugh wrote: >> On 15/03/11 12:51, Andy Buckley wrote: >>> On 15/03/11 12:38, Ben Waugh wrote: >>>> There is only one minor bug that I have discovered so far. The generated >>>> rivetenv.sh sets PYTHONPATH to >>>> $INSTALLDIR/lib/python2.4/site-packages >>>> but the Python libraries are actually in >>>> $INSTALLDIR/lib64/python2.4/site-packages >>>> >>>> So just running Rivet out of the box gives the infamous "No module named >>>> rivet" error. >>> >>> Damn, so close! Hmm, I *thought* that I was now taking the generated >>> rivetenv scripts from the Rivet build, in which case the installation >>> directory is actually generated (in configure.ac) by Python's own >>> installation system! I'll have to check the bootstrap script again. >>> >>> In the meantime, can you take a look at the generated rivetenv.sh which >>> should be in the Rivet build directory on your system (i.e. not >>> necessarily the one that rivet-bootstrap tells you to use) and see if it >>> also specifies lib rather than lib64? It would certainly be strange if >>> Python reports that it'll be installing into one directory and then >>> actually copies the files into another... >> >> Unfortunately... >> >> waugh> grep PYTHONPATH build/rivet/rivetenv.sh >> export >> PYTHONPATH="/tmp/waugh/rivet/local/lib/python2.4/site-packages:$PYTHONPATH" > > Hmmm! Can you now try running a python prompt on the machine with which > you did the installation, run this: > > import distutils.sysconfig > print distutils.sysconfig.get_python_lib(prefix='/foo') > > and post the output? This should be the method used by Python to do the > module installation, and is the method used to generate that PYTHONPATH > entry in the rivetenv.sh script, so it *really* should be returning a > value with "lib64" in it if that's the dir name that Python is choosing > to install the libraries into! > > Cheers, > Andy > -- Dr Ben Waugh Tel. +44 (0)20 7679 7223 Dept of Physics and Astronomy Internal: 37223 University College London London WC1E 6BT
More information about the Rivet mailing list |