Skip to content
Snippets Groups Projects
Commit f588cac6 authored by Manuel Günther's avatar Manuel Günther
Browse files

Fixed bootstrap.py; changed setup.py to use pkg-config to find hdf5

parent 9be85c21
No related branches found
No related tags found
No related merge requests found
...@@ -20,9 +20,9 @@ before_install: ...@@ -20,9 +20,9 @@ before_install:
- if [ -n "${NUMPYSPEC}" ]; then sudo apt-get install -qq gfortran; fi - if [ -n "${NUMPYSPEC}" ]; then sudo apt-get install -qq gfortran; fi
- if [ -n "${NUMPYSPEC}" ]; then pip install --upgrade pip setuptools; fi - if [ -n "${NUMPYSPEC}" ]; then pip install --upgrade pip setuptools; fi
- if [ -n "${NUMPYSPEC}" ]; then pip install --find-links http://wheels.astropy.org/ --find-links http://wheels2.astropy.org/ --use-wheel numpy$NUMPYSPEC; fi - if [ -n "${NUMPYSPEC}" ]; then pip install --find-links http://wheels.astropy.org/ --find-links http://wheels2.astropy.org/ --use-wheel numpy$NUMPYSPEC; fi
- pip install --find-links http://wheels.astropy.org/ --find-links http://wheels2.astropy.org/ --use-wheel sphinx nose==1.3.0 jinja2==2.6 cpp-coveralls pygments==1.6 setuptools==7.0 - pip install --find-links http://wheels.astropy.org/ --find-links http://wheels2.astropy.org/ --use-wheel sphinx nose==1.3.0 jinja2==2.6 cpp-coveralls pygments==1.6
install: install:
- python bootstrap.py - python bootstrap-buildout.py
- CFLAGS=-coverage ./bin/buildout - CFLAGS=-coverage ./bin/buildout
script: script:
- ./bin/python -c 'from bob.io.base import get_config; print(get_config())' - ./bin/python -c 'from bob.io.base import get_config; print(get_config())'
......
...@@ -56,6 +56,11 @@ parser.add_option("-c", "--config-file", ...@@ -56,6 +56,11 @@ parser.add_option("-c", "--config-file",
"file to be used.")) "file to be used."))
parser.add_option("-f", "--find-links", parser.add_option("-f", "--find-links",
help=("Specify a URL to search for buildout releases")) help=("Specify a URL to search for buildout releases"))
parser.add_option("--allow-site-packages",
action="store_true", default=False,
help=("Let bootstrap.py use existing site packages"))
parser.add_option("--setuptools-version",
help="use a specific setuptools version")
options, args = parser.parse_args() options, args = parser.parse_args()
...@@ -63,45 +68,42 @@ options, args = parser.parse_args() ...@@ -63,45 +68,42 @@ options, args = parser.parse_args()
###################################################################### ######################################################################
# load/install setuptools # load/install setuptools
to_reload = False
try: try:
import pkg_resources if options.allow_site_packages:
import setuptools import setuptools
import pkg_resources
from urllib.request import urlopen
except ImportError: except ImportError:
ez = {} from urllib2 import urlopen
try:
from urllib.request import urlopen
except ImportError:
from urllib2 import urlopen
# XXX use a more permanent ez_setup.py URL when available.
exec(urlopen('https://bitbucket.org/pypa/setuptools/raw/0.7.2/ez_setup.py'
).read(), ez)
setup_args = dict(to_dir=tmpeggs, download_delay=0)
ez['use_setuptools'](**setup_args)
if to_reload:
reload(pkg_resources)
import pkg_resources
# This does not (always?) update the default working set. We will
# do it.
for path in sys.path:
if path not in pkg_resources.working_set.entries:
pkg_resources.working_set.add_entry(path)
###################################################################### ez = {}
# Try to best guess the version of buildout given setuptools exec(urlopen('https://bootstrap.pypa.io/ez_setup.py').read(), ez)
if options.version is None:
if not options.allow_site_packages:
try: # ez_setup imports site, which adds site packages
from distutils.version import LooseVersion # this will remove them from the path to ensure that incompatible versions
package = pkg_resources.require('setuptools')[0] # of setuptools are not in the path
v = LooseVersion(package.version) import site
if v < LooseVersion('0.7'): # inside a virtualenv, there is no 'getsitepackages'.
options.version = '2.1.1' # We can't remove these reliably
except: if hasattr(site, 'getsitepackages'):
pass for sitepackage_path in site.getsitepackages():
sys.path[:] = [x for x in sys.path if sitepackage_path not in x]
setup_args = dict(to_dir=tmpeggs, download_delay=0)
if options.setuptools_version is not None:
setup_args['version'] = options.setuptools_version
ez['use_setuptools'](**setup_args)
import setuptools
import pkg_resources
# This does not (always?) update the default working set. We will
# do it.
for path in sys.path:
if path not in pkg_resources.working_set.entries:
pkg_resources.working_set.add_entry(path)
###################################################################### ######################################################################
# Install buildout # Install buildout
...@@ -132,10 +134,15 @@ if version is None and not options.accept_buildout_test_releases: ...@@ -132,10 +134,15 @@ if version is None and not options.accept_buildout_test_releases:
_final_parts = '*final-', '*final' _final_parts = '*final-', '*final'
def _final_version(parsed_version): def _final_version(parsed_version):
for part in parsed_version: try:
if (part[:1] == '*') and (part not in _final_parts): return not parsed_version.is_prerelease
return False except AttributeError:
return True # Older setuptools
for part in parsed_version:
if (part[:1] == '*') and (part not in _final_parts):
return False
return True
index = setuptools.package_index.PackageIndex( index = setuptools.package_index.PackageIndex(
search_path=[setuptools_path]) search_path=[setuptools_path])
if find_links: if find_links:
...@@ -162,8 +169,7 @@ cmd.append(requirement) ...@@ -162,8 +169,7 @@ cmd.append(requirement)
import subprocess import subprocess
if subprocess.call(cmd, env=dict(os.environ, PYTHONPATH=setuptools_path)) != 0: if subprocess.call(cmd, env=dict(os.environ, PYTHONPATH=setuptools_path)) != 0:
raise Exception( raise Exception(
"Failed to execute command:\n%s", "Failed to execute command:\n%s" % repr(cmd)[1:-1])
repr(cmd)[1:-1])
###################################################################### ######################################################################
# Import and run buildout # Import and run buildout
...@@ -181,4 +187,3 @@ if options.config_file is not None: ...@@ -181,4 +187,3 @@ if options.config_file is not None:
zc.buildout.buildout.main(args) zc.buildout.buildout.main(args)
shutil.rmtree(tmpeggs) shutil.rmtree(tmpeggs)
...@@ -7,7 +7,6 @@ bob_packages = ['bob.core'] ...@@ -7,7 +7,6 @@ bob_packages = ['bob.core']
from setuptools import setup, find_packages, dist from setuptools import setup, find_packages, dist
dist.Distribution(dict(setup_requires=['bob.extension', 'bob.blitz'] + bob_packages)) dist.Distribution(dict(setup_requires=['bob.extension', 'bob.blitz'] + bob_packages))
from bob.extension.utils import egrep, find_header, find_library
from bob.blitz.extension import Extension, Library, build_ext from bob.blitz.extension import Extension, Library, build_ext
from bob.extension.utils import load_requirements from bob.extension.utils import load_requirements
...@@ -16,119 +15,9 @@ build_requires = load_requirements() ...@@ -16,119 +15,9 @@ build_requires = load_requirements()
# Define package version # Define package version
version = open("version.txt").read().rstrip() version = open("version.txt").read().rstrip()
packages = ['boost'] packages = ['boost', 'hdf5']
boost_modules = ['system', 'filesystem'] boost_modules = ['system', 'filesystem']
import os
def libhdf5_version(header):
vv = egrep(header, r"#\s*define\s+H5_VERSION\s+\"([\d\.]+)\"")
if not len(vv): return None
return vv[0].group(1)
class hdf5:
def __init__ (self, requirement='', only_static=False):
"""
Searches for libhdf5 in stock locations. Allows user to override.
If the user sets the environment variable BOB_PREFIX_PATH, that prefixes
the standard path locations.
Parameters:
requirement, str
A string, indicating a version requirement for this library. For example,
``'>= 8.2'``.
only_static, boolean
A flag, that indicates if we intend to link against the static library
only. This will trigger our library search to disconsider shared
libraries when searching.
"""
import os
self.name = 'hdf5'
header = 'hdf5.h'
candidates = find_header(header)
if not candidates:
raise RuntimeError("could not find %s's `%s' - have you installed %s on this machine?" % (self.name, header, self.name))
found = False
if not requirement:
self.include_directory = os.path.dirname(candidates[0])
directory = os.path.dirname(candidates[0])
version_header = os.path.join(directory, 'H5pubconf.h')
self.version = libhdf5_version(version_header)
found = True
else:
# requirement is 'operator' 'version'
operator, required = [k.strip() for k in requirement.split(' ', 1)]
# now check for user requirements
for candidate in candidates:
directory = os.path.dirname(candidate)
version_header = os.path.join(directory, 'H5pubconf.h')
vv = libhdf5_version(version_header)
available = LooseVersion(vv)
if (operator == '<' and available < required) or \
(operator == '<=' and available <= required) or \
(operator == '>' and available > required) or \
(operator == '>=' and available >= required) or \
(operator == '==' and available == required):
self.include_directory = os.path.dirname(candidate)
self.version = vv
found = True
break
if not found:
raise RuntimeError("could not find the required (%s) version of %s on the file system (looked at: %s)" % (requirement, self.name, ', '.join(candidates)))
# normalize
self.include_directory = os.path.normpath(self.include_directory)
# find library
prefix = os.path.dirname(os.path.dirname(self.include_directory))
module = 'hdf5'
candidates = find_library(module, version=self.version, prefixes=[prefix], only_static=only_static)
if not candidates:
raise RuntimeError("cannot find required %s binary module `%s' - make sure libhdf5 is installed on `%s'" % (self.name, module, prefix))
# libraries
self.libraries = []
name, ext = os.path.splitext(os.path.basename(candidates[0]))
if ext in ['.so', '.a', '.dylib', '.dll']:
self.libraries.append(name[3:]) #strip 'lib' from the name
else: #link against the whole thing
self.libraries.append(':' + os.path.basename(candidates[0]))
# library path
self.library_directory = os.path.dirname(candidates[0])
def macros(self):
return [
('HAVE_%s' % self.name.upper(), '1'),
('%s_VERSION' % self.name.upper(), '"%s"' % self.version),
]
hdf5_pkg = hdf5()
system_include_dirs = [hdf5_pkg.include_directory]
library_dirs = [hdf5_pkg.library_directory]
libraries = hdf5_pkg.libraries
define_macros = hdf5_pkg.macros()
setup( setup(
name='bob.io.base', name='bob.io.base',
...@@ -158,8 +47,6 @@ setup( ...@@ -158,8 +47,6 @@ setup(
[ [
"bob/io/base/version.cpp", "bob/io/base/version.cpp",
], ],
define_macros = define_macros,
system_include_dirs = system_include_dirs,
version = version, version = version,
bob_packages = bob_packages, bob_packages = bob_packages,
packages = packages, packages = packages,
...@@ -188,10 +75,6 @@ setup( ...@@ -188,10 +75,6 @@ setup(
"bob/io/base/cpp/array_type.cpp", "bob/io/base/cpp/array_type.cpp",
"bob/io/base/cpp/blitz_array.cpp", "bob/io/base/cpp/blitz_array.cpp",
], ],
libraries = libraries,
library_dirs = library_dirs,
system_include_dirs = system_include_dirs,
define_macros = define_macros,
version = version, version = version,
bob_packages = bob_packages, bob_packages = bob_packages,
packages = packages, packages = packages,
...@@ -206,10 +89,6 @@ setup( ...@@ -206,10 +89,6 @@ setup(
"bob/io/base/hdf5.cpp", "bob/io/base/hdf5.cpp",
"bob/io/base/main.cpp", "bob/io/base/main.cpp",
], ],
library_dirs = library_dirs,
libraries = libraries,
define_macros = define_macros,
system_include_dirs = system_include_dirs,
version = version, version = version,
bob_packages = bob_packages, bob_packages = bob_packages,
packages = packages, packages = packages,
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment