|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
FINDTOOL_OUT="" |
|
function findTool { |
|
DESC=$1 |
|
OPTIONS=$2 |
|
for CMD in ${OPTIONS}; do |
|
if (which $CMD &>/dev/null) then |
|
echo "Found $DESC: $CMD" |
|
FINDTOOL_OUT="$CMD" |
|
return |
|
fi |
|
done |
|
echo "Error: could not find $DESC. One of these should be in your PATH:" |
|
for CMD in ${OPTIONS}; do |
|
echo " * $CMD" |
|
done |
|
exit 1 |
|
} |
|
|
|
IS_CYGWIN=0 |
|
IS_MSYS1=0 |
|
IS_MSYS2=0 |
|
|
|
|
|
|
|
|
|
|
|
|
|
UNIX_LDFLAGS_STATIC='-static -static-libgcc -static-libstdc++' |
|
|
|
|
|
case $(uname -s) in |
|
CYGWIN*) |
|
echo 'uname -s identifies a Cygwin environment.' |
|
IS_CYGWIN=1 |
|
case $(uname -m) in |
|
i686) |
|
echo 'uname -m identifies an i686 environment.' |
|
UNIX_CXX=i686-pc-cygwin-g++ |
|
MINGW_CXX=i686-w64-mingw32-g++ |
|
;; |
|
x86_64) |
|
echo 'uname -m identifies an x86_64 environment.' |
|
UNIX_CXX=x86_64-pc-cygwin-g++ |
|
MINGW_CXX=x86_64-w64-mingw32-g++ |
|
;; |
|
*) |
|
echo 'Error: uname -m did not match either i686 or x86_64.' |
|
exit 1 |
|
;; |
|
esac |
|
;; |
|
MSYS*|MINGW*) |
|
# MSYS2 notes: |
|
# - MSYS2 offers two shortcuts to open an environment: |
|
# - MinGW-w64 Win32 Shell. This env reports a `uname -s` of |
|
# MINGW32_NT-6.1 on 32-bit Win7. The MinGW-w64 compiler |
|
# (i686-w64-mingw32-g++.exe) is in the PATH. |
|
# - MSYS2 Shell. `uname -s` instead reports MSYS_NT-6.1. |
|
# The i686-w64-mingw32-g++ compiler is not in the PATH. |
|
# - MSYS2 appears to use MinGW-w64, not the older mingw.org. |
|
# MSYS notes: |
|
# - `uname -s` is always MINGW32_NT-6.1 on Win7. |
|
echo 'uname -s identifies an MSYS/MSYS2 environment.' |
|
case $(uname -m) in |
|
i686) |
|
echo 'uname -m identifies an i686 environment.' |
|
UNIX_CXX=i686-pc-msys-g++ |
|
if echo "$(uname -r)" | grep '^1[.]' > /dev/null; then |
|
# The MSYS-targeting compiler for the original 32-bit-only |
|
# MSYS does not recognize the -static-libstdc++ flag, and |
|
# it does not work with -static, because it tries to link |
|
# statically with the core MSYS library and fails. |
|
# |
|
# Distinguish between the two using the major version |
|
# number of `uname -r`: |
|
# |
|
# MSYS uname -r: 1.0.18(0.48/3/2) |
|
# MSYS2 uname -r: 2.0.0(0.284/5/3) |
|
# |
|
# This is suboptimal because MSYS2 is not actually the |
|
# second version of MSYS--it's a brand-new fork of Cygwin. |
|
# |
|
IS_MSYS1=1 |
|
UNIX_LDFLAGS_STATIC= |
|
MINGW_CXX=mingw32-g++ |
|
else |
|
IS_MSYS2=1 |
|
MINGW_CXX=i686-w64-mingw32-g++.exe |
|
fi |
|
;; |
|
x86_64) |
|
echo 'uname -m identifies an x86_64 environment.' |
|
IS_MSYS2=1 |
|
UNIX_CXX=x86_64-pc-msys-g++ |
|
MINGW_CXX=x86_64-w64-mingw32-g++ |
|
;; |
|
*) |
|
echo 'Error: uname -m did not match either i686 or x86_64.' |
|
exit 1 |
|
;; |
|
esac |
|
;; |
|
*) |
|
echo 'Error: uname -s did not match either CYGWIN* or MINGW*.' |
|
exit 1 |
|
;; |
|
esac |
|
|
|
# Search the PATH and pick the first match. |
|
findTool "Cygwin/MSYS G++ compiler" "$UNIX_CXX" |
|
UNIX_CXX=$FINDTOOL_OUT |
|
findTool "MinGW G++ compiler" "$MINGW_CXX" |
|
MINGW_CXX=$FINDTOOL_OUT |
|
|
|
# Write config files. |
|
echo Writing config.mk |
|
echo UNIX_CXX=$UNIX_CXX > config.mk |
|
echo UNIX_LDFLAGS_STATIC=$UNIX_LDFLAGS_STATIC >> config.mk |
|
echo MINGW_CXX=$MINGW_CXX >> config.mk |
|
|
|
if test $IS_MSYS1 = 1; then |
|
echo UNIX_CXXFLAGS += -DWINPTY_TARGET_MSYS1 >> config.mk |
|
# The MSYS1 MinGW compiler has a bug that prevents inclusion of algorithm |
|
# and math.h in normal C++11 mode. The workaround is to enable the gnu++11 |
|
# mode instead. The bug was fixed on 2015-07-31, but as of 2016-02-26, the |
|
# fix apparently hasn't been released. See |
|
# http://ehc.ac/p/mingw/bugs/2250/. |
|
echo MINGW_ENABLE_CXX11_FLAG := -std=gnu++11 >> config.mk |
|
fi |
|
|
|
if test -d .git -a -f .git/HEAD -a -f .git/index && git rev-parse HEAD >&/dev/null; then |
|
echo "Commit info: git" |
|
echo 'COMMIT_HASH = $(shell git rev-parse HEAD)' >> config.mk |
|
echo 'COMMIT_HASH_DEP := config.mk .git/HEAD .git/index' >> config.mk |
|
else |
|
echo "Commit info: none" |
|
echo 'COMMIT_HASH := none' >> config.mk |
|
echo 'COMMIT_HASH_DEP := config.mk' >> config.mk |
|
fi |
|
|