Merge commit 'a34a885031fcb1797621e8968497561a4837e06a' as 'third_party/mason'
This commit is contained in:
+60
@@ -0,0 +1,60 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
MASON_NAME=boost
|
||||
MASON_VERSION=system
|
||||
MASON_SYSTEM_PACKAGE=true
|
||||
|
||||
. ${MASON_DIR}/mason.sh
|
||||
|
||||
if [ -d '/usr/local/include/boost' ]; then
|
||||
BOOST_ROOT='/usr/local'
|
||||
elif [ -d '/usr/include/boost' ]; then
|
||||
BOOST_ROOT='/usr'
|
||||
else
|
||||
mason_error "Cannot find Boost"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
function mason_system_version {
|
||||
# Use host compiler to produce a binary that can run on the host
|
||||
HOST_CXX=`MASON_PLATFORM= mason env CXX`
|
||||
HOST_CFLAGS=`MASON_PLATFORM= mason env CFLAGS`
|
||||
|
||||
mkdir -p "${MASON_PREFIX}"
|
||||
cd "${MASON_PREFIX}"
|
||||
if [ ! -f version ]; then
|
||||
echo "#include <boost/version.hpp>
|
||||
#include <stdio.h>
|
||||
int main() {
|
||||
printf(\"%d.%d.%d\", BOOST_VERSION / 100000, BOOST_VERSION / 100 % 1000, BOOST_VERSION % 100);
|
||||
return 0;
|
||||
}
|
||||
" > version.cpp && ${HOST_CXX} ${HOST_CFLAGS} version.cpp $(mason_cflags) -o version
|
||||
fi
|
||||
./version
|
||||
}
|
||||
|
||||
function mason_build {
|
||||
if [ ${MASON_PLATFORM} = 'ios' ]; then
|
||||
mkdir -p ${MASON_PREFIX}/include
|
||||
ln -sf ${BOOST_ROOT}/include/boost ${MASON_PREFIX}/include/
|
||||
else
|
||||
mkdir -p ${MASON_PREFIX}/{include,lib}
|
||||
ln -sf ${BOOST_ROOT}/include/boost ${MASON_PREFIX}/include/
|
||||
ln -sf ${BOOST_ROOT}/lib/libboost_* ${MASON_PREFIX}/lib/
|
||||
fi
|
||||
}
|
||||
|
||||
function mason_cflags {
|
||||
echo "-I${MASON_PREFIX}/include"
|
||||
}
|
||||
|
||||
function mason_ldflags {
|
||||
if [ ${MASON_PLATFORM} = 'ios' ]; then
|
||||
echo ""
|
||||
else
|
||||
echo "-L${MASON_PREFIX}/lib"
|
||||
fi
|
||||
}
|
||||
|
||||
mason_run "$@"
|
||||
Reference in New Issue
Block a user