better python library detection on linux
parent
96c644c5f9
commit
605b3062e2
|
@ -30,7 +30,7 @@ if needsBuildDependencies and not os.path.exists(GetBuildPath('#dependencies')):
|
||||||
print 'at http://www.mitsuba-renderer.org/docs.html for details on how to get them.\n'
|
print 'at http://www.mitsuba-renderer.org/docs.html for details on how to get them.\n'
|
||||||
Exit(1)
|
Exit(1)
|
||||||
|
|
||||||
python_versions = ["2.6", "2.7", "3.0", "3.1", "3.2", "3.3"]
|
python_versions = ["2.6", "2.7", "3.0", "3.1", "3.2", "3.3", "3.4"]
|
||||||
|
|
||||||
# Parse configuration options
|
# Parse configuration options
|
||||||
vars = Variables(configFile)
|
vars = Variables(configFile)
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import fnmatch
|
import fnmatch
|
||||||
|
|
||||||
Import('env', 'os', 'sys', 'plugins', 'dist',
|
Import('env', 'os', 'sys', 'plugins', 'dist',
|
||||||
'MTS_VERSION', 'hasQt', 'hasCollada', 'hasPython', 'hasBreakpad')
|
'MTS_VERSION', 'hasQt', 'hasCollada', 'hasPython', 'hasBreakpad')
|
||||||
|
|
||||||
installTargets = []
|
installTargets = []
|
||||||
|
@ -73,7 +73,7 @@ if sys.platform == 'win32':
|
||||||
install(distDir, ['libcore/libmitsuba-core.dll', 'libhw/libmitsuba-hw.dll',
|
install(distDir, ['libcore/libmitsuba-core.dll', 'libhw/libmitsuba-hw.dll',
|
||||||
'librender/libmitsuba-render.dll', 'libbidir/libmitsuba-bidir.dll'])
|
'librender/libmitsuba-render.dll', 'libbidir/libmitsuba-bidir.dll'])
|
||||||
install(sdkLibDir, ['libcore/mitsuba-core.lib', 'libhw/mitsuba-hw.lib',
|
install(sdkLibDir, ['libcore/mitsuba-core.lib', 'libhw/mitsuba-hw.lib',
|
||||||
'librender/mitsuba-render.lib', 'libbidir/mitsuba-bidir.lib'])
|
'librender/mitsuba-render.lib', 'libbidir/mitsuba-bidir.lib'])
|
||||||
for entry in os.walk(os.path.join(basePath, "include")):
|
for entry in os.walk(os.path.join(basePath, "include")):
|
||||||
includeDir = entry[0][len(basePath)+1:]
|
includeDir = entry[0][len(basePath)+1:]
|
||||||
installTargets += env.Install(os.path.join(sdkDir, includeDir),
|
installTargets += env.Install(os.path.join(sdkDir, includeDir),
|
||||||
|
|
|
@ -23,20 +23,13 @@ COLLADAINCLUDE = ['/usr/include/collada-dom', '/usr/include/collada-dom/1.4']
|
||||||
COLLADALIB = ['collada14dom', 'xml2']
|
COLLADALIB = ['collada14dom', 'xml2']
|
||||||
FFTWLIB = ['fftw3_threads', 'fftw3']
|
FFTWLIB = ['fftw3_threads', 'fftw3']
|
||||||
|
|
||||||
# The following assumes that the Mitsuba bindings should be built for the
|
# The following runs a helper script to search for installed Python
|
||||||
# "default" Python version. It is also possible to build bindings for multiple
|
# packages that have a Boost Python library of matching version.
|
||||||
# versions at the same time by explicitly specifying e.g. PYTHON27INCLUDE,
|
# A Mitsuba binding library will be compiled for each such pair.
|
||||||
# PYTHON27LIB, PYTHON27LIBDIR and PYTHON32INCLUDE, PYTHON32LIB, PYTHON32LIBDIR
|
# Alternatively, you could also specify the paths and libraries manually
|
||||||
|
# using the variables PYTHON27INCLUDE, PYTHON27LIB, PYTHON27LIBDIR etc.
|
||||||
pyver = os.popen("python --version 2>&1 | grep -oE '([[:digit:]].[[:digit:]])'").read().strip().replace('.', '')
|
|
||||||
env = locals()
|
|
||||||
|
|
||||||
env['PYTHON'+pyver+'INCLUDE'] = []
|
|
||||||
env['PYTHON'+pyver+'LIB'] = ['boost_python-mt-py'+pyver]
|
|
||||||
|
|
||||||
for entry in os.popen("python-config --cflags --libs").read().split():
|
|
||||||
if entry[:2] == '-I':
|
|
||||||
env['PYTHON'+pyver+'INCLUDE'] += [entry[2:]]
|
|
||||||
if entry[:2] == '-l':
|
|
||||||
env['PYTHON'+pyver+'LIB'] += [entry[2:]]
|
|
||||||
|
|
||||||
|
import sys, os
|
||||||
|
sys.path.append(os.path.abspath('../data/scons'))
|
||||||
|
from detect_python import detect_python
|
||||||
|
locals().update(detect_python())
|
||||||
|
|
|
@ -23,19 +23,14 @@ COLLADAINCLUDE = ['/usr/include/collada-dom', '/usr/include/collada-dom/1.4']
|
||||||
COLLADALIB = ['collada14dom', 'xml2']
|
COLLADALIB = ['collada14dom', 'xml2']
|
||||||
FFTWLIB = ['fftw3_threads', 'fftw3']
|
FFTWLIB = ['fftw3_threads', 'fftw3']
|
||||||
|
|
||||||
# The following assumes that the Mitsuba bindings should be built for the
|
# The following runs a helper script to search for installed Python
|
||||||
# "default" Python version. It is also possible to build bindings for multiple
|
# packages that have a Boost Python library of matching version.
|
||||||
# versions at the same time by explicitly specifying e.g. PYTHON27INCLUDE,
|
# A Mitsuba binding library will be compiled for each such pair.
|
||||||
# PYTHON27LIB, PYTHON27LIBDIR and PYTHON32INCLUDE, PYTHON32LIB, PYTHON32LIBDIR
|
# Alternatively, you could also specify the paths and libraries manually
|
||||||
|
# using the variables PYTHON27INCLUDE, PYTHON27LIB, PYTHON27LIBDIR etc.
|
||||||
|
|
||||||
pyver = os.popen("python --version 2>&1 | grep -oE '([[:digit:]].[[:digit:]])'").read().strip().replace('.', '')
|
import sys, os
|
||||||
env = locals()
|
sys.path.append(os.path.abspath('../data/scons'))
|
||||||
|
from detect_python import detect_python
|
||||||
|
locals().update(detect_python())
|
||||||
|
|
||||||
env['PYTHON'+pyver+'INCLUDE'] = []
|
|
||||||
env['PYTHON'+pyver+'LIB'] = ['boost_python-mt-py'+pyver]
|
|
||||||
|
|
||||||
for entry in os.popen("python-config --cflags --libs").read().split():
|
|
||||||
if entry[:2] == '-I':
|
|
||||||
env['PYTHON'+pyver+'INCLUDE'] += [entry[2:]]
|
|
||||||
if entry[:2] == '-l':
|
|
||||||
env['PYTHON'+pyver+'LIB'] += [entry[2:]]
|
|
||||||
|
|
|
@ -23,19 +23,13 @@ COLLADAINCLUDE = ['/usr/include/collada-dom', '/usr/include/collada-dom/1.4']
|
||||||
COLLADALIB = ['collada14dom', 'xml2']
|
COLLADALIB = ['collada14dom', 'xml2']
|
||||||
FFTWLIB = ['fftw3_threads', 'fftw3']
|
FFTWLIB = ['fftw3_threads', 'fftw3']
|
||||||
|
|
||||||
# The following assumes that the Mitsuba bindings should be built for the
|
# The following runs a helper script to search for installed Python
|
||||||
# "default" Python version. It is also possible to build bindings for multiple
|
# packages that have a Boost Python library of matching version.
|
||||||
# versions at the same time by explicitly specifying e.g. PYTHON27INCLUDE,
|
# A Mitsuba binding library will be compiled for each such pair.
|
||||||
# PYTHON27LIB, PYTHON27LIBDIR and PYTHON32INCLUDE, PYTHON32LIB, PYTHON32LIBDIR
|
# Alternatively, you could also specify the paths and libraries manually
|
||||||
|
# using the variables PYTHON27INCLUDE, PYTHON27LIB, PYTHON27LIBDIR etc.
|
||||||
|
|
||||||
pyver = os.popen("python --version 2>&1 | grep -oE '([[:digit:]].[[:digit:]])'").read().strip().replace('.', '')
|
import sys, os
|
||||||
env = locals()
|
sys.path.append(os.path.abspath('../data/scons'))
|
||||||
|
from detect_python import detect_python
|
||||||
env['PYTHON'+pyver+'INCLUDE'] = []
|
locals().update(detect_python())
|
||||||
env['PYTHON'+pyver+'LIB'] = ['boost_python-mt-py'+pyver]
|
|
||||||
|
|
||||||
for entry in os.popen("python-config --cflags --libs").read().split():
|
|
||||||
if entry[:2] == '-I':
|
|
||||||
env['PYTHON'+pyver+'INCLUDE'] += [entry[2:]]
|
|
||||||
if entry[:2] == '-l':
|
|
||||||
env['PYTHON'+pyver+'LIB'] += [entry[2:]]
|
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
# Detect present Python & Boost-python libraries on Linux
|
||||||
|
import os
|
||||||
|
|
||||||
|
class PkgConfig(dict):
|
||||||
|
_paths = ['/usr/lib/pkgconfig', '/usr/lib/x86_64-linux-gnu/pkgconfig']
|
||||||
|
|
||||||
|
def __init__(self, name):
|
||||||
|
for path in self._paths:
|
||||||
|
fn = os.path.join(path, '%s.pc' % name)
|
||||||
|
if os.path.exists(fn):
|
||||||
|
self._parse(fn)
|
||||||
|
break
|
||||||
|
|
||||||
|
def _parse(self, filename):
|
||||||
|
from string import Template
|
||||||
|
|
||||||
|
lines = open(filename).readlines()
|
||||||
|
localVariables = {}
|
||||||
|
|
||||||
|
for line in lines:
|
||||||
|
line = line.strip()
|
||||||
|
if not line or line.startswith('#'):
|
||||||
|
continue
|
||||||
|
elif ':' in line:
|
||||||
|
name, val = line.split(':')
|
||||||
|
val = val.strip()
|
||||||
|
if '$' in val:
|
||||||
|
val = Template(val).substitute(localVariables)
|
||||||
|
self[name] = val
|
||||||
|
elif '=' in line:
|
||||||
|
name, val = line.split('=')
|
||||||
|
val = val.strip()
|
||||||
|
if '$' in val:
|
||||||
|
val = Template(val).substitute(localVariables)
|
||||||
|
localVariables[name] = val
|
||||||
|
|
||||||
|
def find_boost_python(version):
|
||||||
|
libnames = [
|
||||||
|
'boost_python-mt-py%s' % version,
|
||||||
|
'boost_python-py%s' % version,
|
||||||
|
'boost_python' + ('3' if version.startswith('3') else '')
|
||||||
|
]
|
||||||
|
basepaths = ['/lib', '/usr/lib']
|
||||||
|
|
||||||
|
for basepath in basepaths:
|
||||||
|
for libname in libnames:
|
||||||
|
if os.path.isfile(os.path.join(basepath, "lib" + libname + ".so")):
|
||||||
|
return libname
|
||||||
|
return None
|
||||||
|
|
||||||
|
def detect_python():
|
||||||
|
pyver = ['2.6', '2.7', '3.0', '3.1', '3.2', '3.3', '3.4']
|
||||||
|
pyenv = {}
|
||||||
|
|
||||||
|
for version in pyver:
|
||||||
|
pkgconfig = PkgConfig('python-%s' % version)
|
||||||
|
version = version.replace('.', '')
|
||||||
|
flags = []
|
||||||
|
if 'Cflags' in pkgconfig:
|
||||||
|
flags += pkgconfig['Cflags'].split()
|
||||||
|
if 'Libs' in pkgconfig:
|
||||||
|
flags += pkgconfig['Libs'].split()
|
||||||
|
if len(flags) == 0:
|
||||||
|
continue
|
||||||
|
boost_libname = find_boost_python(version)
|
||||||
|
print(boost_libname)
|
||||||
|
if boost_libname == None:
|
||||||
|
continue
|
||||||
|
pyenv['PYTHON' + version + 'INCLUDE'] = []
|
||||||
|
pyenv['PYTHON' + version + 'LIBDIR'] = []
|
||||||
|
pyenv['PYTHON' + version + 'LIB'] = [ boost_libname ]
|
||||||
|
for flag in flags:
|
||||||
|
if flag.startswith('-I'):
|
||||||
|
pyenv['PYTHON' + version + 'INCLUDE'] += [flag[2:]]
|
||||||
|
elif flag.startswith('-L'):
|
||||||
|
pyenv['PYTHON' + version + 'LIBDIR'] += [flag[2:]]
|
||||||
|
elif flag.startswith('-l'):
|
||||||
|
pyenv['PYTHON' + version + 'LIB'] += [flag[2:]]
|
||||||
|
return pyenv
|
Loading…
Reference in New Issue