|
1 #!/bin/sh |
|
2 |
|
3 # These variables are automatically filled in by the configure script. |
|
4 name="@PACKAGE_TARNAME@" |
|
5 version="@PACKAGE_VERSION@" |
|
6 |
|
7 show_usage() |
|
8 { |
|
9 echo "Usage: gtest-config [OPTIONS...]" |
|
10 } |
|
11 |
|
12 show_help() |
|
13 { |
|
14 show_usage |
|
15 cat <<\EOF |
|
16 |
|
17 The `gtest-config' script provides access to the necessary compile and linking |
|
18 flags to connect with Google C++ Testing Framework, both in a build prior to |
|
19 installation, and on the system proper after installation. The installation |
|
20 overrides may be issued in combination with any other queries, but will only |
|
21 affect installation queries if called on a built but not installed gtest. The |
|
22 installation queries may not be issued with any other types of queries, and |
|
23 only one installation query may be made at a time. The version queries and |
|
24 compiler flag queries may be combined as desired but not mixed. Different |
|
25 version queries are always combined with logical "and" semantics, and only the |
|
26 last of any particular query is used while all previous ones ignored. All |
|
27 versions must be specified as a sequence of numbers separated by periods. |
|
28 Compiler flag queries output the union of the sets of flags when combined. |
|
29 |
|
30 Examples: |
|
31 gtest-config --min-version=1.0 || echo "Insufficient Google Test version." |
|
32 |
|
33 g++ $(gtest-config --cppflags --cxxflags) -o foo.o -c foo.cpp |
|
34 g++ $(gtest-config --ldflags --libs) -o foo foo.o |
|
35 |
|
36 # When using a built but not installed Google Test: |
|
37 g++ $(../../my_gtest_build/scripts/gtest-config ...) ... |
|
38 |
|
39 # When using an installed Google Test, but with installation overrides: |
|
40 export GTEST_PREFIX="/opt" |
|
41 g++ $(gtest-config --libdir="/opt/lib64" ...) ... |
|
42 |
|
43 Help: |
|
44 --usage brief usage information |
|
45 --help display this help message |
|
46 |
|
47 Installation Overrides: |
|
48 --prefix=<dir> overrides the installation prefix |
|
49 --exec-prefix=<dir> overrides the executable installation prefix |
|
50 --libdir=<dir> overrides the library installation prefix |
|
51 --includedir=<dir> overrides the header file installation prefix |
|
52 |
|
53 Installation Queries: |
|
54 --prefix installation prefix |
|
55 --exec-prefix executable installation prefix |
|
56 --libdir library installation directory |
|
57 --includedir header file installation directory |
|
58 --version the version of the Google Test installation |
|
59 |
|
60 Version Queries: |
|
61 --min-version=VERSION return 0 if the version is at least VERSION |
|
62 --exact-version=VERSION return 0 if the version is exactly VERSION |
|
63 --max-version=VERSION return 0 if the version is at most VERSION |
|
64 |
|
65 Compilation Flag Queries: |
|
66 --cppflags compile flags specific to the C-like preprocessors |
|
67 --cxxflags compile flags appropriate for C++ programs |
|
68 --ldflags linker flags |
|
69 --libs libraries for linking |
|
70 |
|
71 EOF |
|
72 } |
|
73 |
|
74 # This function bounds our version with a min and a max. It uses some clever |
|
75 # POSIX-compliant variable expansion to portably do all the work in the shell |
|
76 # and avoid any dependency on a particular "sed" or "awk" implementation. |
|
77 # Notable is that it will only ever compare the first 3 components of versions. |
|
78 # Further components will be cleanly stripped off. All versions must be |
|
79 # unadorned, so "v1.0" will *not* work. The minimum version must be in $1, and |
|
80 # the max in $2. TODO(chandlerc@google.com): If this ever breaks, we should |
|
81 # investigate expanding this via autom4te from AS_VERSION_COMPARE rather than |
|
82 # continuing to maintain our own shell version. |
|
83 check_versions() |
|
84 { |
|
85 major_version=${version%%.*} |
|
86 minor_version="0" |
|
87 point_version="0" |
|
88 if test "${version#*.}" != "${version}"; then |
|
89 minor_version=${version#*.} |
|
90 minor_version=${minor_version%%.*} |
|
91 fi |
|
92 if test "${version#*.*.}" != "${version}"; then |
|
93 point_version=${version#*.*.} |
|
94 point_version=${point_version%%.*} |
|
95 fi |
|
96 |
|
97 min_version="$1" |
|
98 min_major_version=${min_version%%.*} |
|
99 min_minor_version="0" |
|
100 min_point_version="0" |
|
101 if test "${min_version#*.}" != "${min_version}"; then |
|
102 min_minor_version=${min_version#*.} |
|
103 min_minor_version=${min_minor_version%%.*} |
|
104 fi |
|
105 if test "${min_version#*.*.}" != "${min_version}"; then |
|
106 min_point_version=${min_version#*.*.} |
|
107 min_point_version=${min_point_version%%.*} |
|
108 fi |
|
109 |
|
110 max_version="$2" |
|
111 max_major_version=${max_version%%.*} |
|
112 max_minor_version="0" |
|
113 max_point_version="0" |
|
114 if test "${max_version#*.}" != "${max_version}"; then |
|
115 max_minor_version=${max_version#*.} |
|
116 max_minor_version=${max_minor_version%%.*} |
|
117 fi |
|
118 if test "${max_version#*.*.}" != "${max_version}"; then |
|
119 max_point_version=${max_version#*.*.} |
|
120 max_point_version=${max_point_version%%.*} |
|
121 fi |
|
122 |
|
123 test $(($major_version)) -lt $(($min_major_version)) && exit 1 |
|
124 if test $(($major_version)) -eq $(($min_major_version)); then |
|
125 test $(($minor_version)) -lt $(($min_minor_version)) && exit 1 |
|
126 if test $(($minor_version)) -eq $(($min_minor_version)); then |
|
127 test $(($point_version)) -lt $(($min_point_version)) && exit 1 |
|
128 fi |
|
129 fi |
|
130 |
|
131 test $(($major_version)) -gt $(($max_major_version)) && exit 1 |
|
132 if test $(($major_version)) -eq $(($max_major_version)); then |
|
133 test $(($minor_version)) -gt $(($max_minor_version)) && exit 1 |
|
134 if test $(($minor_version)) -eq $(($max_minor_version)); then |
|
135 test $(($point_version)) -gt $(($max_point_version)) && exit 1 |
|
136 fi |
|
137 fi |
|
138 |
|
139 exit 0 |
|
140 } |
|
141 |
|
142 # Show the usage line when no arguments are specified. |
|
143 if test $# -eq 0; then |
|
144 show_usage |
|
145 exit 1 |
|
146 fi |
|
147 |
|
148 while test $# -gt 0; do |
|
149 case $1 in |
|
150 --usage) show_usage; exit 0;; |
|
151 --help) show_help; exit 0;; |
|
152 |
|
153 # Installation overrides |
|
154 --prefix=*) GTEST_PREFIX=${1#--prefix=};; |
|
155 --exec-prefix=*) GTEST_EXEC_PREFIX=${1#--exec-prefix=};; |
|
156 --libdir=*) GTEST_LIBDIR=${1#--libdir=};; |
|
157 --includedir=*) GTEST_INCLUDEDIR=${1#--includedir=};; |
|
158 |
|
159 # Installation queries |
|
160 --prefix|--exec-prefix|--libdir|--includedir|--version) |
|
161 if test -n "${do_query}"; then |
|
162 show_usage |
|
163 exit 1 |
|
164 fi |
|
165 do_query=${1#--} |
|
166 ;; |
|
167 |
|
168 # Version checking |
|
169 --min-version=*) |
|
170 do_check_versions=yes |
|
171 min_version=${1#--min-version=} |
|
172 ;; |
|
173 --max-version=*) |
|
174 do_check_versions=yes |
|
175 max_version=${1#--max-version=} |
|
176 ;; |
|
177 --exact-version=*) |
|
178 do_check_versions=yes |
|
179 exact_version=${1#--exact-version=} |
|
180 ;; |
|
181 |
|
182 # Compiler flag output |
|
183 --cppflags) echo_cppflags=yes;; |
|
184 --cxxflags) echo_cxxflags=yes;; |
|
185 --ldflags) echo_ldflags=yes;; |
|
186 --libs) echo_libs=yes;; |
|
187 |
|
188 # Everything else is an error |
|
189 *) show_usage; exit 1;; |
|
190 esac |
|
191 shift |
|
192 done |
|
193 |
|
194 # These have defaults filled in by the configure script but can also be |
|
195 # overridden by environment variables or command line parameters. |
|
196 prefix="${GTEST_PREFIX:-@prefix@}" |
|
197 exec_prefix="${GTEST_EXEC_PREFIX:-@exec_prefix@}" |
|
198 libdir="${GTEST_LIBDIR:-@libdir@}" |
|
199 includedir="${GTEST_INCLUDEDIR:-@includedir@}" |
|
200 |
|
201 # We try and detect if our binary is not located at its installed location. If |
|
202 # it's not, we provide variables pointing to the source and build tree rather |
|
203 # than to the install tree. This allows building against a just-built gtest |
|
204 # rather than an installed gtest. |
|
205 bindir="@bindir@" |
|
206 this_relative_bindir=`dirname $0` |
|
207 this_bindir=`cd ${this_relative_bindir}; pwd -P` |
|
208 if test "${this_bindir}" = "${this_bindir%${bindir}}"; then |
|
209 # The path to the script doesn't end in the bindir sequence from Autoconf, |
|
210 # assume that we are in a build tree. |
|
211 build_dir=`dirname ${this_bindir}` |
|
212 src_dir=`cd ${this_bindir}/@top_srcdir@; pwd -P` |
|
213 |
|
214 # TODO(chandlerc@google.com): This is a dangerous dependency on libtool, we |
|
215 # should work to remove it, and/or remove libtool altogether, replacing it |
|
216 # with direct references to the library and a link path. |
|
217 gtest_libs="${build_dir}/lib/libgtest.la @PTHREAD_CFLAGS@ @PTHREAD_LIBS@" |
|
218 gtest_ldflags="" |
|
219 |
|
220 # We provide hooks to include from either the source or build dir, where the |
|
221 # build dir is always preferred. This will potentially allow us to write |
|
222 # build rules for generated headers and have them automatically be preferred |
|
223 # over provided versions. |
|
224 gtest_cppflags="-I${build_dir}/include -I${src_dir}/include" |
|
225 gtest_cxxflags="@PTHREAD_CFLAGS@" |
|
226 else |
|
227 # We're using an installed gtest, although it may be staged under some |
|
228 # prefix. Assume (as our own libraries do) that we can resolve the prefix, |
|
229 # and are present in the dynamic link paths. |
|
230 gtest_ldflags="-L${libdir}" |
|
231 gtest_libs="-l${name} @PTHREAD_CFLAGS@ @PTHREAD_LIBS@" |
|
232 gtest_cppflags="-I${includedir}" |
|
233 gtest_cxxflags="@PTHREAD_CFLAGS@" |
|
234 fi |
|
235 |
|
236 # Do an installation query if requested. |
|
237 if test -n "$do_query"; then |
|
238 case $do_query in |
|
239 prefix) echo $prefix; exit 0;; |
|
240 exec-prefix) echo $exec_prefix; exit 0;; |
|
241 libdir) echo $libdir; exit 0;; |
|
242 includedir) echo $includedir; exit 0;; |
|
243 version) echo $version; exit 0;; |
|
244 *) show_usage; exit 1;; |
|
245 esac |
|
246 fi |
|
247 |
|
248 # Do a version check if requested. |
|
249 if test "$do_check_versions" = "yes"; then |
|
250 # Make sure we didn't receive a bad combination of parameters. |
|
251 test "$echo_cppflags" = "yes" && show_usage && exit 1 |
|
252 test "$echo_cxxflags" = "yes" && show_usage && exit 1 |
|
253 test "$echo_ldflags" = "yes" && show_usage && exit 1 |
|
254 test "$echo_libs" = "yes" && show_usage && exit 1 |
|
255 |
|
256 if test "$exact_version" != ""; then |
|
257 check_versions $exact_version $exact_version |
|
258 # unreachable |
|
259 else |
|
260 check_versions ${min_version:-0.0.0} ${max_version:-9999.9999.9999} |
|
261 # unreachable |
|
262 fi |
|
263 fi |
|
264 |
|
265 # Do the output in the correct order so that these can be used in-line of |
|
266 # a compiler invocation. |
|
267 output="" |
|
268 test "$echo_cppflags" = "yes" && output="$output $gtest_cppflags" |
|
269 test "$echo_cxxflags" = "yes" && output="$output $gtest_cxxflags" |
|
270 test "$echo_ldflags" = "yes" && output="$output $gtest_ldflags" |
|
271 test "$echo_libs" = "yes" && output="$output $gtest_libs" |
|
272 echo $output |
|
273 |
|
274 exit 0 |