aboutsummaryrefslogtreecommitdiffstats
path: root/Library
diff options
context:
space:
mode:
authorTim D. Smith2014-07-19 15:37:25 -0700
committerTim D. Smith2014-09-26 23:49:54 -0700
commit5254f8f510fb30484f8fac8be3d38e388a4392e2 (patch)
treea3d37bfcb3ae082b0c48945b6f88f74fa4c40916 /Library
parent6ed9ec0119f55b2a36f22fc4eea583f93a4c99ac (diff)
downloadhomebrew-5254f8f510fb30484f8fac8be3d38e388a4392e2.tar.bz2
Split out Boost.Python
Diffstat (limited to 'Library')
-rw-r--r--Library/Formula/boost-python.rb127
-rw-r--r--Library/Formula/boost.rb75
2 files changed, 136 insertions, 66 deletions
diff --git a/Library/Formula/boost-python.rb b/Library/Formula/boost-python.rb
new file mode 100644
index 000000000..12fe398ed
--- /dev/null
+++ b/Library/Formula/boost-python.rb
@@ -0,0 +1,127 @@
+require "formula"
+
+class UniversalPython < Requirement
+ satisfy(:build_env => false) { archs_for_command("python").universal? }
+
+ def message; <<-EOS.undent
+ A universal build was requested, but Python is not a universal build
+
+ Boost compiles against the Python it finds in the path; if this Python
+ is not a universal build then linking will likely fail.
+ EOS
+ end
+end
+
+class UniversalPython3 < Requirement
+ satisfy(:build_env => false) { archs_for_command("python3").universal? }
+
+ def message; <<-EOS.undent
+ A universal build was requested, but Python 3 is not a universal build
+
+ Boost compiles against the Python 3 it finds in the path; if this Python
+ is not a universal build then linking will likely fail.
+ EOS
+ end
+end
+
+class BoostPython < Formula
+ homepage "http://www.boost.org"
+ url "https://downloads.sourceforge.net/project/boost/boost/1.56.0/boost_1_56_0.tar.bz2"
+ sha1 "f94bb008900ed5ba1994a1072140590784b9b5df"
+ head "https://github.com/boostorg/boost.git"
+
+ option :universal
+ option :cxx11
+
+ depends_on :python => :recommended
+ depends_on :python3 => :optional
+ depends_on UniversalPython if build.universal? and build.with? "python"
+ depends_on UniversalPython3 if build.universal? and build.with? "python3"
+
+ if build.cxx11?
+ depends_on "boost" => "c++11"
+ else
+ depends_on "boost"
+ end
+
+ fails_with :llvm do
+ build 2335
+ cause "Dropped arguments to functions when linking with boost"
+ end
+
+ def install
+ ENV.universal_binary if build.universal?
+
+ # "layout" should be synchronized with boost
+ args = ["--prefix=#{prefix}",
+ "--libdir=#{lib}",
+ "-d2",
+ "-j#{ENV.make_jobs}",
+ "--layout=tagged",
+ "--user-config=user-config.jam",
+ "threading=multi,single",
+ "link=shared,static"]
+
+ args << "address-model=32_64" << "architecture=x86" << "pch=off" if build.universal?
+
+ # Build in C++11 mode if boost was built in C++11 mode.
+ # Trunk starts using "clang++ -x c" to select C compiler which breaks C++11
+ # handling using ENV.cxx11. Using "cxxflags" and "linkflags" still works.
+ if build.cxx11?
+ args << "cxxflags=-std=c++11"
+ if ENV.compiler == :clang
+ args << "cxxflags=-stdlib=libc++" << "linkflags=-stdlib=libc++"
+ end
+ elsif Tab.for_name("boost").cxx11?
+ odie "boost was built in C++11 mode so boost-python must be built with --c++11."
+ end
+
+ # disable python detection in bootstrap.sh; it guesses the wrong include directory
+ # for Python 3 headers, so we configure python manually in user-config.jam below.
+ inreplace "bootstrap.sh", "using python", "#using python"
+
+ Language::Python.each_python(build) do |python, version|
+ py_prefix = `#{python} -c "from __future__ import print_function; import sys; print(sys.prefix)"`.strip
+ py_include = `#{python} -c "from __future__ import print_function; import distutils.sysconfig; print(distutils.sysconfig.get_python_inc(True))"`.strip
+ open("user-config.jam", "w") do |file|
+ # Force boost to compile with the desired compiler
+ file.write "using darwin : : #{ENV.cxx} ;\n"
+ file.write <<-EOS.undent
+ using python : #{version}
+ : #{python}
+ : #{py_include}
+ : #{py_prefix}/lib ;
+ EOS
+ end
+
+ system "./bootstrap.sh", "--prefix=#{prefix}", "--libdir=#{lib}", "--with-libraries=python",
+ "--with-python=#{python}", "--with-python-root=#{py_prefix}"
+
+ system "./b2", "--build-dir=build-#{python}", "--stagedir=stage-#{python}",
+ "python=#{version}", *args
+ end
+
+ lib.install Dir["stage-python3/lib/*py*"] if build.with?("python3")
+ lib.install Dir["stage-python/lib/*py*"] if build.with?("python")
+ end
+
+ test do
+ (testpath/"hello.cpp").write <<-EOS.undent
+ #include <boost/python.hpp>
+ char const* greet() {
+ return "Hello, world!";
+ }
+ BOOST_PYTHON_MODULE(hello)
+ {
+ boost::python::def("greet", greet);
+ }
+ EOS
+ Language::Python.each_python(build) do |python, version|
+ pycflags = `#{python}-config --includes`.strip
+ pyldflags = `#{python}-config --ldflags`.strip
+ system "#{ENV.cxx} -shared hello.cpp #{pycflags} #{pyldflags} -lboost_#{python} -o hello.so"
+ output = `#{python} -c "from __future__ import print_function; import hello; print(hello.greet())"`
+ assert output.include?("Hello, world!")
+ end
+ end
+end
diff --git a/Library/Formula/boost.rb b/Library/Formula/boost.rb
index 6326ff226..4448826bd 100644
--- a/Library/Formula/boost.rb
+++ b/Library/Formula/boost.rb
@@ -1,29 +1,5 @@
require 'formula'
-class UniversalPython < Requirement
- satisfy(:build_env => false) { archs_for_command("python").universal? }
-
- def message; <<-EOS.undent
- A universal build was requested, but Python is not a universal build
-
- Boost compiles against the Python it finds in the path; if this Python
- is not a universal build then linking will likely fail.
- EOS
- end
-end
-
-class UniversalPython3 < Requirement
- satisfy(:build_env => false) { archs_for_command("python3").universal? }
-
- def message; <<-EOS.undent
- A universal build was requested, but Python 3 is not a universal build
-
- Boost compiles against the Python 3 it finds in the path; if this Python
- is not a universal build then linking will likely fail.
- EOS
- end
-end
-
class Boost < Formula
homepage 'http://www.boost.org'
url 'https://downloads.sourceforge.net/project/boost/boost/1.56.0/boost_1_56_0.tar.bz2'
@@ -47,15 +23,6 @@ class Boost < Formula
option 'with-mpi', 'Build with MPI support'
option :cxx11
- depends_on :python => :optional
- depends_on :python3 => :optional
- depends_on UniversalPython if build.universal? and build.with? "python"
- depends_on UniversalPython3 if build.universal? and build.with? "python3"
-
- if build.with?("python3") && build.with?("python")
- odie "boost: --with-python3 cannot be specified when using --with-python"
- end
-
if build.with? 'icu'
if build.cxx11?
depends_on 'icu4c' => 'c++11'
@@ -87,49 +54,26 @@ class Boost < Formula
EOS
end
- if build.cxx11? and build.with? 'mpi' and (build.with? 'python' \
- or build.with? 'python3')
- raise <<-EOS.undent
- Building MPI support for Python using C++11 mode results in
- failure and hence disabled. Please don't use this combination
- of options.
- EOS
- end
-
ENV.universal_binary if build.universal?
- # Force boost to compile using the appropriate GCC version.
+ # Force boost to compile with the desired compiler
open("user-config.jam", "a") do |file|
file.write "using darwin : : #{ENV.cxx} ;\n"
file.write "using mpi ;\n" if build.with? 'mpi'
-
- # Link against correct version of Python if python3 build was requested
- if build.with? 'python3'
- py3executable = `which python3`.strip
- py3version = `python3 -c "import sys; print(sys.version[:3])"`.strip
- py3prefix = `python3 -c "import sys; print(sys.prefix)"`.strip
-
- file.write <<-EOS.undent
- using python : #{py3version}
- : #{py3executable}
- : #{py3prefix}/include/python#{py3version}m
- : #{py3prefix}/lib ;
- EOS
- end
end
- # we specify libdir too because the script is apparently broken
- bargs = ["--prefix=#{prefix}", "--libdir=#{lib}"]
+ # libdir should be set by --prefix but isn't
+ bootstrap_args = ["--prefix=#{prefix}", "--libdir=#{lib}"]
if build.with? 'icu'
icu4c_prefix = Formula['icu4c'].opt_prefix
- bargs << "--with-icu=#{icu4c_prefix}"
+ bootstrap_args << "--with-icu=#{icu4c_prefix}"
else
- bargs << '--without-icu'
+ bootstrap_args << '--without-icu'
end
# Handle libraries that will not be built.
- without_libraries = []
+ without_libraries = ["python"]
# The context library is implemented as x86_64 ASM, so it
# won't build on PPC or 32-bit builds
@@ -143,12 +87,11 @@ class Boost < Formula
# Boost.Log cannot be built using Apple GCC at the moment. Disabled
# on such systems.
without_libraries << "log" if ENV.compiler == :gcc || ENV.compiler == :llvm
- without_libraries << "python" if (build.without? 'python' \
- and build.without? 'python3')
without_libraries << "mpi" if build.without? 'mpi'
- bargs << "--without-libraries=#{without_libraries.join(',')}"
+ bootstrap_args << "--without-libraries=#{without_libraries.join(',')}"
+ # layout should be synchronized with boost-python
args = ["--prefix=#{prefix}",
"--libdir=#{lib}",
"-d2",
@@ -180,7 +123,7 @@ class Boost < Formula
end
end
- system "./bootstrap.sh", *bargs
+ system "./bootstrap.sh", *bootstrap_args
system "./b2", *args
end