Necessary changes to gtest-config.in for supporting the up-coming release of Google C++ Mocking Framework. By Chandler Carruth.
This commit is contained in:
parent
5145e0fb20
commit
fab8c18a00
@ -1,56 +1,61 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# These variables are automatically filled in by the configure script.
|
# These variables are automatically filled in by the configure script.
|
||||||
prefix="@prefix@"
|
|
||||||
exec_prefix="@exec_prefix@"
|
|
||||||
libdir="@libdir@"
|
|
||||||
includedir="@includedir@"
|
|
||||||
name="@PACKAGE_TARNAME@"
|
name="@PACKAGE_TARNAME@"
|
||||||
version="@PACKAGE_VERSION@"
|
version="@PACKAGE_VERSION@"
|
||||||
|
|
||||||
gtest_ldflags="-L${libdir}"
|
|
||||||
gtest_libs="-l${name}"
|
|
||||||
gtest_cppflags="-I${includedir}"
|
|
||||||
gtest_cxxflags=""
|
|
||||||
|
|
||||||
show_usage()
|
show_usage()
|
||||||
{
|
{
|
||||||
cat <<EOF
|
echo "Usage: gtest-config [OPTIONS...]"
|
||||||
Usage: gtest-config [OPTIONS...]
|
|
||||||
EOF
|
|
||||||
}
|
}
|
||||||
|
|
||||||
show_help()
|
show_help()
|
||||||
{
|
{
|
||||||
show_usage
|
show_usage
|
||||||
cat <<EOF
|
cat <<\EOF
|
||||||
|
|
||||||
The \`gtest-config' script provides access to the necessary compile and linking
|
The `gtest-config' script provides access to the necessary compile and linking
|
||||||
flags to connect with Google C++ Testing framework. The installation queries
|
flags to connect with Google C++ Testing Framework, both in a build prior to
|
||||||
may only be issued one at a time, and may not be issued with any other types of
|
installation, and on the system proper after installation. The installation
|
||||||
queries. The version queries and compiler flag queries may be combined as
|
overrides may be issued in combination with any other queries, but will only
|
||||||
desired but not mixed. Different version queries are always combined with "and"
|
affect installation queries if called on a built but not installed gtest. The
|
||||||
logical semantics, and only the last of any particular query is used and all
|
installation queries may not be issued with any other types of queries, and
|
||||||
previous ones ignored. All versions must be specified as a sequence of numbers
|
only one installation query may be made at a time. The version queries and
|
||||||
separated by periods. Compiler flag queries output the union of the sets of
|
compiler flag queries may be combined as desired but not mixed. Different
|
||||||
flags when combined.
|
version queries are always combined with logical "and" semantics, and only the
|
||||||
|
last of any particular query is used while all previous ones ignored. All
|
||||||
|
versions must be specified as a sequence of numbers separated by periods.
|
||||||
|
Compiler flag queries output the union of the sets of flags when combined.
|
||||||
|
|
||||||
Examples:
|
Examples:
|
||||||
gtest-config --min-version=1.0 || echo "Insufficient Google Test version."
|
gtest-config --min-version=1.0 || echo "Insufficient Google Test version."
|
||||||
|
|
||||||
gcc \$(gtest-config --cppflags --cxxflags) -o foo.o -c foo.cpp
|
g++ $(gtest-config --cppflags --cxxflags) -o foo.o -c foo.cpp
|
||||||
gcc \$(gtest-config --ldflags --libs) -o foo foo.o
|
g++ $(gtest-config --ldflags --libs) -o foo foo.o
|
||||||
|
|
||||||
|
# When using a built but not installed Google Test:
|
||||||
|
g++ $(../../my_gtest_build/scripts/gtest-config ...) ...
|
||||||
|
|
||||||
|
# When using an installed Google Test, but with installation overrides:
|
||||||
|
export GTEST_PREFIX="/opt"
|
||||||
|
g++ $(gtest-config --libdir="/opt/lib64" ...) ...
|
||||||
|
|
||||||
Help:
|
Help:
|
||||||
--usage brief usage information
|
--usage brief usage information
|
||||||
--help display this help message
|
--help display this help message
|
||||||
|
|
||||||
|
Installation Overrides:
|
||||||
|
--prefix=<dir> overrides the installation prefix
|
||||||
|
--exec-prefix=<dir> overrides the executable installation prefix
|
||||||
|
--libdir=<dir> overrides the library installation prefix
|
||||||
|
--includedir=<dir> overrides the header file installation prefix
|
||||||
|
|
||||||
Installation Queries:
|
Installation Queries:
|
||||||
--prefix installation prefix
|
--prefix installation prefix
|
||||||
--exec-prefix executable installation prefix
|
--exec-prefix executable installation prefix
|
||||||
--libdir library installation directory
|
--libdir library installation directory
|
||||||
--includedir header file installation directory
|
--includedir header file installation directory
|
||||||
--version the version of the INC installation
|
--version the version of the Google Test installation
|
||||||
|
|
||||||
Version Queries:
|
Version Queries:
|
||||||
--min-version=VERSION return 0 if the version is at least VERSION
|
--min-version=VERSION return 0 if the version is at least VERSION
|
||||||
@ -68,11 +73,13 @@ EOF
|
|||||||
|
|
||||||
# This function bounds our version with a min and a max. It uses some clever
|
# This function bounds our version with a min and a max. It uses some clever
|
||||||
# POSIX-compliant variable expansion to portably do all the work in the shell
|
# POSIX-compliant variable expansion to portably do all the work in the shell
|
||||||
# and avoid any dependency on a particular "sed" implementation. Notable is
|
# and avoid any dependency on a particular "sed" or "awk" implementation.
|
||||||
# that it will only ever compare the first 3 components of versions. Further
|
# Notable is that it will only ever compare the first 3 components of versions.
|
||||||
# components will be cleanly stripped off. All versions must be unadorned, so
|
# Further components will be cleanly stripped off. All versions must be
|
||||||
# "v1.0" will *not* work. The minimum version must be in $1, and the max in
|
# unadorned, so "v1.0" will *not* work. The minimum version must be in $1, and
|
||||||
# $2.
|
# the max in $2. TODO(chandlerc@google.com): If this ever breaks, we should
|
||||||
|
# investigate expanding this via autom4te from AS_VERSION_COMPARE rather than
|
||||||
|
# continuing to maintain our own shell version.
|
||||||
check_versions()
|
check_versions()
|
||||||
{
|
{
|
||||||
major_version=${version%%.*}
|
major_version=${version%%.*}
|
||||||
@ -142,11 +149,23 @@ while test $# -gt 0; do
|
|||||||
case $1 in
|
case $1 in
|
||||||
--usage) show_usage; exit 0;;
|
--usage) show_usage; exit 0;;
|
||||||
--help) show_help; exit 0;;
|
--help) show_help; exit 0;;
|
||||||
--prefix) echo $prefix; exit 0;;
|
|
||||||
--exec-prefix) echo $exec_prefix; exit 0;;
|
# Installation overrides
|
||||||
--libdir) echo $libdir; exit 0;;
|
--prefix=*) GTEST_PREFIX=${1#--prefix=};;
|
||||||
--includedir) echo $includedir; exit 0;;
|
--exec-prefix=*) GTEST_EXEC_PREFIX=${1#--exec-prefix=};;
|
||||||
--version) echo $version; exit 0;;
|
--libdir=*) GTEST_LIBDIR=${1#--libdir=};;
|
||||||
|
--includedir=*) GTEST_INCLUDEDIR=${1#--includedir=};;
|
||||||
|
|
||||||
|
# Installation queries
|
||||||
|
--prefix|--exec-prefix|--libdir|--includedir|--version)
|
||||||
|
if test -n "${do_query}"; then
|
||||||
|
show_usage
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
do_query=${1#--}
|
||||||
|
;;
|
||||||
|
|
||||||
|
# Version checking
|
||||||
--min-version=*)
|
--min-version=*)
|
||||||
do_check_versions=yes
|
do_check_versions=yes
|
||||||
min_version=${1#--min-version=}
|
min_version=${1#--min-version=}
|
||||||
@ -159,6 +178,8 @@ while test $# -gt 0; do
|
|||||||
do_check_versions=yes
|
do_check_versions=yes
|
||||||
exact_version=${1#--exact-version=}
|
exact_version=${1#--exact-version=}
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
# Compiler flag output
|
||||||
--cppflags) echo_cppflags=yes;;
|
--cppflags) echo_cppflags=yes;;
|
||||||
--cxxflags) echo_cxxflags=yes;;
|
--cxxflags) echo_cxxflags=yes;;
|
||||||
--ldflags) echo_ldflags=yes;;
|
--ldflags) echo_ldflags=yes;;
|
||||||
@ -170,6 +191,60 @@ while test $# -gt 0; do
|
|||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# These have defaults filled in by the configure script but can also be
|
||||||
|
# overridden by environment variables or command line parameters.
|
||||||
|
prefix="${GTEST_PREFIX:-@prefix@}"
|
||||||
|
exec_prefix="${GTEST_EXEC_PREFIX:-@exec_prefix@}"
|
||||||
|
libdir="${GTEST_LIBDIR:-@libdir@}"
|
||||||
|
includedir="${GTEST_INCLUDEDIR:-@includedir@}"
|
||||||
|
|
||||||
|
# We try and detect if our binary is not located at its installed location. If
|
||||||
|
# it's not, we provide variables pointing to the source and build tree rather
|
||||||
|
# than to the install tree. This allows building against a just-built gtest
|
||||||
|
# rather than an installed gtest.
|
||||||
|
bindir="@bindir@"
|
||||||
|
this_relative_bindir=`dirname $0`
|
||||||
|
this_bindir=`cd ${this_relative_bindir}; pwd -P`
|
||||||
|
if test "${this_bindir}" = "${this_bindir%${bindir}}"; then
|
||||||
|
# The path to the script doesn't end in the bindir sequence from Autoconf,
|
||||||
|
# assume that we are in a build tree.
|
||||||
|
build_dir=`dirname ${this_bindir}`
|
||||||
|
src_dir=`cd ${this_bindir}/@top_srcdir@; pwd -P`
|
||||||
|
|
||||||
|
# TODO(chandlerc@google.com): This is a dangerous dependency on libtool, we
|
||||||
|
# should work to remove it, and/or remove libtool altogether, replacing it
|
||||||
|
# with direct references to the library and a link path.
|
||||||
|
gtest_libs="${build_dir}/lib/libgtest.la"
|
||||||
|
gtest_ldflags=""
|
||||||
|
|
||||||
|
# We provide hooks to include from either the source or build dir, where the
|
||||||
|
# build dir is always preferred. This will potentially allow us to write
|
||||||
|
# build rules for generated headers and have them automatically be preferred
|
||||||
|
# over provided versions.
|
||||||
|
gtest_cppflags="-I${build_dir}/include -I${src_dir}/include"
|
||||||
|
gtest_cxxflags=""
|
||||||
|
else
|
||||||
|
# We're using an installed gtest, although it may be staged under some
|
||||||
|
# prefix. Assume (as our own libraries do) that we can resolve the prefix,
|
||||||
|
# and are present in the dynamic link paths.
|
||||||
|
gtest_ldflags="-L${libdir}"
|
||||||
|
gtest_libs="-l${name}"
|
||||||
|
gtest_cppflags="-I${includedir}"
|
||||||
|
gtest_cxxflags=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Do an installation query if requested.
|
||||||
|
if test -n "$do_query"; then
|
||||||
|
case $do_query in
|
||||||
|
prefix) echo $prefix; exit 0;;
|
||||||
|
exec-prefix) echo $exec_prefix; exit 0;;
|
||||||
|
libdir) echo $libdir; exit 0;;
|
||||||
|
includedir) echo $includedir; exit 0;;
|
||||||
|
version) echo $version; exit 0;;
|
||||||
|
*) show_usage; exit 1;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
# Do a version check if requested.
|
# Do a version check if requested.
|
||||||
if test "$do_check_versions" = "yes"; then
|
if test "$do_check_versions" = "yes"; then
|
||||||
# Make sure we didn't receive a bad combination of parameters.
|
# Make sure we didn't receive a bad combination of parameters.
|
||||||
|
Loading…
Reference in New Issue
Block a user