diff options
| author | Holger Kohr <h.kohr@cwi.nl> | 2016-11-23 10:21:55 +0100 | 
|---|---|---|
| committer | Willem Jan Palenstijn <Willem.Jan.Palenstijn@cwi.nl> | 2016-11-25 13:04:36 +0100 | 
| commit | eeffd2d9748b8912b384a5764b808f5bfc850ade (patch) | |
| tree | 5d257bcde2688d3d4ec84191cd5ac60af918f85a /python/conda | |
| parent | 3a68fbe656c1984b6cf1b921d29225807d4d4ca0 (diff) | |
| download | astra-eeffd2d9748b8912b384a5764b808f5bfc850ade.tar.gz astra-eeffd2d9748b8912b384a5764b808f5bfc850ade.tar.bz2 astra-eeffd2d9748b8912b384a5764b808f5bfc850ade.tar.xz astra-eeffd2d9748b8912b384a5764b808f5bfc850ade.zip  | |
Separate C++ and python builds & make conda work nicely
- make builder (= advanced user or us ourselves) choose compilers
  and CUDA
- add a check for the C++11 flag for nvcc to work around the
  infamous boost bug if necessary
- use conda boost to build the C++ library
- simplify python bindings conda recipe to only build the bindings;
  the C++ library is now a build and runtime dependency
- add runtime dependencies to python bindings recipe
- some small adjustments to builder.py
Diffstat (limited to 'python/conda')
| -rw-r--r-- | python/conda/build.sh | 12 | ||||
| -rw-r--r-- | python/conda/libastra/build.sh | 28 | ||||
| -rw-r--r-- | python/conda/libastra/meta.yaml | 10 | ||||
| -rw-r--r-- | python/conda/meta.yaml | 13 | 
4 files changed, 40 insertions, 23 deletions
diff --git a/python/conda/build.sh b/python/conda/build.sh index fb3760c..951fd88 100644 --- a/python/conda/build.sh +++ b/python/conda/build.sh @@ -1,8 +1,4 @@ -cd build/linux -./autogen.sh -./configure --with-python --with-cuda=$CUDA_ROOT --prefix=$PREFIX -if [ $MAKEOPTS == '<UNDEFINED>' ] -  then -    MAKEOPTS="" -fi -make $MAKEOPTS install +#!/bin/sh + +cd $SRC_DIR/python/ +CPPFLAGS="-DASTRA_CUDA -DASTRA_PYTHON $CPPFLAGS -I$SRC_DIR/ -I$SRC_DIR/include -I$CUDA_ROOT/include" CC=$CC python ./builder.py build install diff --git a/python/conda/libastra/build.sh b/python/conda/libastra/build.sh index e1d9700..5807697 100644 --- a/python/conda/libastra/build.sh +++ b/python/conda/libastra/build.sh @@ -1,15 +1,23 @@ -cd build/linux -./autogen.sh -./configure --with-cuda=$CUDA_ROOT --prefix=$PREFIX -if [ $MAKEOPTS == '<UNDEFINED>' ] -  then -    MAKEOPTS="" -fi -make $MAKEOPTS install-libraries +#!/bin/sh + +cd $SRC_DIR/build/linux + +$SRC_DIR/build/linux/autogen.sh + +# Add C++11 to compiler flags if nvcc supports it, mostly to work around a boost bug +NVCC=$CUDA_ROOT/bin/nvcc +echo "int main(){return 0;}" > $CONDA_PREFIX/test.cu +$NVCC $CONDA_PREFIX/test.cu -ccbin $CC --std=c++11 -o $CONDA_PREFIX/test.out > /dev/null && EXTRA_NVCCFLAGS="--std=c++11" || /bin/true +rm -f $CONDA_PREFIX/test.out + +$SRC_DIR/build/linux/configure --with-install-type=prefix --with-cuda=$CUDA_ROOT --prefix=$CONDA_PREFIX NVCCFLAGS="-ccbin $CC $EXTRA_NVCCFLAGS" CC=$CC CXX=$CXX CFLAGS="-I$CONDA_PREFIX/include/boost" CXXFLAGS="-I$CONDA_PREFIX/include/boost" + +make install-libraries +  LIBPATH=lib  if [ $ARCH == 64 ]    then      LIBPATH+=64  fi -cp -P $CUDA_ROOT/$LIBPATH/libcudart.so.* $PREFIX/lib -cp -P $CUDA_ROOT/$LIBPATH/libcufft.so.* $PREFIX/lib +cp -P $CUDA_ROOT/$LIBPATH/libcudart.so.* $CONDA_PREFIX/lib +cp -P $CUDA_ROOT/$LIBPATH/libcufft.so.* $CONDA_PREFIX/lib diff --git a/python/conda/libastra/meta.yaml b/python/conda/libastra/meta.yaml index 73fa0d7..7c92e04 100644 --- a/python/conda/libastra/meta.yaml +++ b/python/conda/libastra/meta.yaml @@ -4,13 +4,19 @@ package:  source:    git_url: https://github.com/astra-toolbox/astra-toolbox.git -  #git_tag: v1.7.1 # Change to 1.8 after release +  git_rev: master  # for testing +  # git_tag: 1.8  # TODO: change to this for next release  build:    number: 0    script_env: +    - CC +    - CXX      - CUDA_ROOT -    - MAKEOPTS + +requirements: +  build: +    - boost  about:    home: http://www.astra-toolbox.com diff --git a/python/conda/meta.yaml b/python/conda/meta.yaml index e6a7f52..94ce12f 100644 --- a/python/conda/meta.yaml +++ b/python/conda/meta.yaml @@ -4,32 +4,39 @@ package:  source:    git_url: https://github.com/astra-toolbox/astra-toolbox.git -  #git_tag: v1.7.1 # Change to 1.8 after release +  git_rev: master  # for testing +  # git_tag: 1.8  # TODO: change to this for next release  build:    number: 0    script_env: +    - CC      - CUDA_ROOT -    - MAKEOPTS  test:    imports:      - astra +  requires: +    # To avoid large downloads just for testing after build phase +    - nomkl # [not win] +  requirements:    build:      - python      - cython >=0.13 +    - nomkl # [not win]      - numpy      - scipy      - six +    - libastra ==1.8b  # TODO: change to release version    run:      - python      - numpy      - scipy      - six -    - libastra ==1.8b +    - libastra ==1.8b  # TODO: change to release version  about:  | 
