]> git.cworth.org Git - fips/blob - configure
configure: Move the code which detects compiler warning options
[fips] / configure
1 #! /bin/sh
2
3 PROJECT=fips
4 PROJECT_BLURB="a program for monitoring performance of OpenGL applications"
5
6 # Test whether this shell is capable of parameter substring processing.
7 ( option='a/b'; : ${option#*/} ) 2>/dev/null || {
8     echo "
9 The shell interpreting '$0' is lacking some required features.
10
11 To work around this problem you may try to execute:
12
13     ksh $0 $*
14  or
15     bash $0 $*
16 "
17     exit 1
18 }
19
20 # Store original IFS value so it can be changed (and restored) in many places.
21 readonly DEFAULT_IFS="$IFS"
22
23 srcdir=$(dirname "$0")
24
25 # For a non-srcdir configure invocation (such as ../configure), create
26 # the directory structure and copy Makefiles.
27 if [ "$srcdir" != "." ]; then
28
29     for dir in . $(grep "^subdirs *=" "$srcdir"/Makefile | sed -e "s/subdirs *= *//"); do
30         mkdir -p "$dir"
31         cp "$srcdir"/"$dir"/Makefile.local "$dir"
32         cp "$srcdir"/"$dir"/Makefile "$dir"
33     done
34 fi
35
36 # Set several defaults (optionally specified by the user in
37 # environment variables)
38 CC=${CC:-gcc}
39 CFLAGS=${CFLAGS:--O2}
40 LDFLAGS=${LDFLAGS:-}
41
42 # Set the defaults for values the user can specify with command-line
43 # options.
44 PREFIX=/usr/local
45
46 usage ()
47 {
48     cat <<EOF
49 Usage: ./configure [options]...
50
51 This script configures ${PROJECT} to build on your system.
52
53 It verifies that dependencies are available, determines flags needed
54 to compile and link against various required libraries, and identifies
55 whether various system functions can be used or if locally-provided
56 replacements will be built instead.
57
58 Finally, it allows you to control various aspects of the build and
59 installation process.
60
61 First, some common variables can specified via environment variables:
62
63         CC              The C compiler to use
64         CFLAGS          Flags to pass to the C compiler
65         LDFLAGS         Flags to pass when linking
66
67 Each of these values can further be controlled by specifying them
68 later on the "make" command line.
69
70 Additionally, various options can be specified on the configure
71 command line.
72
73         --prefix=PREFIX Install files in PREFIX [$PREFIX]
74
75 By default, "make install" will install the resulting program to
76 $PREFIX/bin, documentation to $PREFIX/man, etc. You can
77 specify an installation prefix other than $PREFIX using
78 --prefix, for instance:
79
80         ./configure --prefix=\$HOME
81
82 Fine tuning of some installation directories is available:
83
84         --bindir=DIR            Install executables to DIR [PREFIX/bin]
85         --libdir=DIR            Install libraries to DIR [PREFIX/lib]
86         --mandir=DIR            Install man pages to DIR [PREFIX/share/man]
87         --sysconfdir=DIR        Read-only single-machine data [PREFIX/etc]
88
89 Additional options are accepted for compatibility with other
90 configure-script calling conventions, but don't do anything yet:
91
92         --build=<cpu>-<vendor>-<os>     Currently ignored
93         --host=<cpu>-<vendor>-<os>      Currently ignored
94         --infodir=DIR                   Currently ignored
95         --datadir=DIR                   Currently ignored
96         --localstatedir=DIR             Currently ignored
97         --libexecdir=DIR                Currently ignored
98         --disable-maintainer-mode       Currently ignored
99         --disable-dependency-tracking   Currently ignored
100
101 EOF
102 }
103
104 # Given two absolute paths ("from" and "to"), compute a relative path
105 # from "from" to "to". For example:
106 #
107 #       relative_path /foo/bar/baz /foo/qux -> ../../qux
108 relative_path ()
109 {
110     if [ $# -ne 2 ] ; then
111         echo "Internal error: relative_path requires exactly 2 arguments"
112         exit 1;
113     fi
114
115     from="$1"
116     to="$2"
117
118     # Handle trivial case up-front
119     if [ "$from" = "$to" ] ; then
120         echo ""
121     else
122         shared="$from"
123         relative=""
124
125         while [ "${to#$shared}" = "$to" ] && [ "$shared" != "." ] ; do
126             shared="$(dirname $shared)"
127             relative="..${relative:+/${relative}}"
128         done
129
130         echo "${relative:-.}${to#$shared}"
131     fi
132 }
133
134 # Parse command-line options
135 for option; do
136     if [ "${option}" = '--help' ] ; then
137         usage
138         exit 0
139     elif [ "${option%%=*}" = '--prefix' ] ; then
140         PREFIX="${option#*=}"
141     elif [ "${option%%=*}" = '--bindir' ] ; then
142         BINDIR="${option#*=}"
143     elif [ "${option%%=*}" = '--libdir' ] ; then
144         LIBDIR="${option#*=}"
145     elif [ "${option%%=*}" = '--mandir' ] ; then
146         MANDIR="${option#*=}"
147     elif [ "${option%%=*}" = '--sysconfdir' ] ; then
148         SYSCONFDIR="${option#*=}"
149     elif [ "${option%%=*}" = '--build' ] ; then
150         true
151     elif [ "${option%%=*}" = '--host' ] ; then
152         true
153     elif [ "${option%%=*}" = '--infodir' ] ; then
154         true
155     elif [ "${option%%=*}" = '--datadir' ] ; then
156         true
157     elif [ "${option%%=*}" = '--localstatedir' ] ; then
158         true
159     elif [ "${option%%=*}" = '--libexecdir' ] ; then
160         true
161     elif [ "${option}" = '--disable-maintainer-mode' ] ; then
162         true
163     elif [ "${option}" = '--disable-dependency-tracking' ] ; then
164         true
165     else
166         echo "Unrecognized option: ${option}"
167         echo "See:"
168         echo "  $0 --help"
169         echo ""
170         exit 1
171     fi
172 done
173
174 cat <<EOF
175 Welcome to ${PROJECT}, ${PROJECT_BLURB}
176
177 We hope that the process of building and installing ${PROJECT} is quick
178 and smooth.
179
180 If anything goes wrong in the configure process, you can override any
181 decisions it makes by manually editing the Makefile.config file that
182 it creates. Also please do as much as you can to figure out what could
183 be different on your machine compared to those of the ${PROJECT}
184 developers. Then, please email those details to the ${PROJECT} developers so
185 that they can hopefully make future versions of ${PROJECT} easier for you to
186 use.
187
188 We'll now investigate your system to verify that all required
189 dependencies are available:
190
191 EOF
192
193 errors=0
194
195 printf "Checking for pkg-config... "
196 if pkg-config --version > /dev/null 2>&1; then
197     printf "Yes.\n"
198 else
199     printf "No.\n"
200     cat <<EOF
201
202 *** Error: This configure script requires pkg-config to find the
203 compilation flags required to link against the various libraries
204 needed by ${PROJECT}. The pkg-config program can be obtained from:
205
206         http://www.freedesktop.org/wiki/Software/pkg-config/
207
208 Or you may be able install it with a command such as:
209
210         sudo apt-get install pkg-config
211     or:
212         sudo yum install pkgconfig
213
214 EOF
215
216 exit 1
217
218 fi
219
220 printf "Checking for working C compiler (${CC})... "
221 printf "int main(void){return 42;}\n" > minimal.c
222 if ${CC} -o minimal minimal.c > /dev/null 2>&1
223 then
224     printf "Yes.\n"
225 else
226     printf "No.\n"
227     cat <<EOF
228
229 *** Error: No functioning C compiler found. Either set the CC environment
230 to a working C compiler, or else install gcc:
231
232         http://gcc.gnu.org/
233
234 You may be able to install gcc with a command such as:
235
236         sudo apt-get install build-essential
237     or:
238         sudo yum install make automake gcc gcc-c++ kernel-devel
239
240 EOF
241
242 exit 1
243
244 fi
245
246 printf "Checking for libtalloc... "
247 if pkg-config --exists talloc; then
248     printf "Yes.\n"
249     have_talloc=1
250     talloc_cflags=$(pkg-config --cflags talloc)
251     talloc_ldflags=$(pkg-config --libs talloc)
252 else
253     printf "No.\n"
254     have_talloc=0
255     talloc_cflags=
256     errors=$((errors + 1))
257 fi
258
259 printf "Checking for libelf... "
260 printf "#include <gelf.h>\nint main(void){return elf_version (EV_CURRENT);}\n" > elf-minimal.c
261 if ${CC} -o elf-minimal elf-minimal.c -lelf > /dev/null 2>&1
262 then
263     printf "Yes.\n"
264     have_libelf=1
265     libelf_cflags=
266     libelf_ldflags=-lelf
267 else
268     printf "No.\n"
269     have_libelf=0
270     libelf_cflags=
271     libelf_ldflags=
272     errors=$((errors + 1))
273 fi
274 rm -f elf-minimal elf-minimal.c
275
276 printf "Checking for GL/gl.h... "
277 have_gl=0
278 if pkg-config --exists gl; then
279     printf "Yes.\n"
280     have_gl=1
281     gl_cflags=$(pkg-config --cflags gl)
282 else
283     printf "#include <GL/gl.h>\nint main(void){return 0;}\n" > gl-minimal.c
284     if ${CC} -o gl-minimal gl-minimal.c > /dev/null 2>&1
285     then
286         printf "Yes.\n"
287         have_gl=1
288     else
289         printf "No.\n"
290         errors=$((errors + 1))
291     fi
292     rm -f gl-minimal gl-minimal.c
293 fi
294
295 printf "Checking for GL window-system-binding headers:\n"
296 have_gl_winsys=0
297
298 printf "        Checking for GL/glx.h... "
299 have_glx=No
300 printf "#include <GL/glx.h>\nint main(void){return 0;}\n" > glx-minimal.c
301 if ${CC} -o glx-minimal glx-minimal.c ${gl_cflags} > /dev/null 2>&1
302 then
303     printf "Yes.\n"
304     have_gl_winsys=1
305     have_glx=Yes
306 else
307     printf "No.\n"
308 fi
309 rm -f glx-minimal glx-minimal.c
310
311 printf "        Checking for GL/egl.h... "
312 have_egl=No
313 if pkg-config --exists egl; then
314     printf "Yes.\n"
315     have_egl=Yes
316     egl_cflags=$(pkg-config --cflags egl)
317 else
318     printf "#include <GL/egl.h>\nint main(void){return 0;}\n" > egl-minimal.c
319     if ${CC} -o egl-minimal egl-minimal.c ${gl_cflags} > /dev/null 2>&1
320     then
321         printf "Yes.\n"
322         have_gl_winsys=1
323         have_egl=1
324     else
325         printf "No.\n"
326     fi
327     rm -f egl-minimal egl-minimal.c
328 fi
329
330 if [ $have_gl_winsys -eq 0 ]; then
331     errors=$((errors + 1))
332 fi
333
334 printf "int main(void){return 0;}\n" > minimal.c
335
336 WARN_CFLAGS=""
337 printf "Checking for available C compiler warning flags:\n"
338 for flag in -Wall -Wextra -Wmissing-declarations; do
339     if ${CC} $flag -o minimal minimal.c > /dev/null 2>&1
340     then
341         WARN_CFLAGS="${WARN_CFLAGS}${WARN_CFLAGS:+ }${flag}"
342     fi
343 done
344 printf "\t${WARN_CFLAGS}\n"
345
346 rm -f minimal minimal.c
347
348 if [ $errors -gt 0 ]; then
349     cat <<EOF
350
351 *** Error: The dependencies of ${PROJECT} could not be satisfied. You will
352 need to install the following packages before being able to compile
353 ${PROJECT}:
354
355 EOF
356     if [ $have_talloc -eq 0 ]; then
357         echo "  The talloc library (including development files such as headers)"
358         echo "  http://talloc.samba.org/"
359         echo
360     fi
361     if [ $have_libelf -eq 0 ]; then
362         echo "  The libelf library (including development files such as headers)"
363         echo "  http://http://sourceforge.net/projects/elftoolchain/"
364         echo
365     fi
366     if [ $have_gl -eq 0 ]; then
367         echo "  Open GL header files (GL/gl.h)"
368         echo "  http://www.mesa3d.org/"
369         echo
370     fi
371     if [ $have_gl_winsys -eq 0 ]; then
372         echo "  OpenGL window-system-bindings header files (GL/glx.h and/or GL/egl.h)"
373         echo "  http://www.mesa3d.org/"
374         echo
375     fi
376     cat <<EOF
377 With any luck, you're using a modern, package-based operating system
378 that has all of these packages available in the distribution. In that
379 case a simple command will install everything you need. For example:
380
381 On Debian and similar systems:
382
383         sudo apt-get install libtalloc-dev libelf-dev \\
384         libgl1-mesa-dev libgles2-mesa-dev
385
386 Or on Fedora and similar systems:
387
388         sudo yum install libtalloc-devel libelf-devel \\
389         mesa-libGL-devel mesa-libGLES-devel
390
391 On other systems, similar commands can be used, but the details of the
392 package names may be different.
393
394 When you have installed the necessary dependencies, you can run
395 configure again to ensure the packages can be found, or simply run
396 "make" to compile.
397
398 EOF
399     exit 1
400 fi
401
402 cat <<EOF
403
404 All required packages were found.
405
406 The following OpenGL window-system bindings will be supported:
407
408         GLX: ${have_glx}
409         EGL: ${have_egl}
410
411 You may now run the following commands to compile and install ${PROJECT}:
412
413         make
414         sudo make install
415
416 EOF
417
418 # construct the Makefile.config
419 cat > Makefile.config <<EOF
420 # This Makefile.config was automatically generated by the ./configure
421 # script of ${PROJECT}. If the configure script identified anything
422 # incorrectly, then you can edit this file to try to correct things,
423 # but be warned that if configure is run again it will destroy your
424 # changes, (and this could happen by simply calling "make" if the
425 # configure script is updated).
426
427 # The top-level directory for the source, (the directory containing
428 # the configure script). This may be different than the build
429 # directory (the current directory at the time configure was run).
430 srcdir = ${srcdir}
431
432 configure_options = $@
433
434 # We use vpath directives (rather than the VPATH variable) since the
435 # VPATH variable matches targets as well as prerequisites, (which is
436 # not useful since then a target left-over from a srcdir build would
437 # cause a target to not be built in the non-srcdir build).
438 #
439 # Also, we don't use a single "vpath % \$(srcdir)" here because we
440 # don't want the vpath to trigger for our emacs lisp compilation,
441 # (unless we first find a way to convince emacs to build the .elc
442 # target in a directory other than the directory of the .el
443 # prerequisite). In the meantime, we're actually copying in the .el
444 # files, (which is quite ugly).
445 vpath %.c \$(srcdir)
446 vpath %.cc \$(srcdir)
447 vpath %.1 \$(srcdir)
448 vpath Makefile.% \$(srcdir)
449
450 # The C compiler to use
451 CC = ${CC}
452
453 # Default FLAGS for C compiler (can be overridden by user such as "make CFLAGS=-g")
454 CFLAGS = ${CFLAGS}
455
456 # Default FLAGS for the linker (can be overridden by user such as "make LDFLAGS=-znow")
457 LDFLAGS = ${LDFLAGS}
458
459 # Flags to enable warnings when using the C compiler
460 WARN_CFLAGS=${WARN_CFLAGS}
461
462 # The prefix to which ${PROJECT} should be installed
463 prefix = ${PREFIX}
464
465 # The directory to which executables should be installed
466 bindir = ${BINDIR:=\$(prefix)/bin}
467
468 # The directory to which libraries should be installed
469 libdir = ${LIBDIR:=\$(prefix)/lib}
470
471 # The directory to which man pages should be installed
472 mandir = ${MANDIR:=\$(prefix)/share/man}
473
474 # The directory to which read-only (configuration) files should be installed
475 sysconfdir = ${SYSCONFDIR:=\$(prefix)/etc}
476
477 # Flags needed to compile and link against talloc
478 TALLOC_CFLAGS = ${talloc_cflags}
479 TALLOC_LDFLAGS = ${talloc_ldflags}
480
481 # Flags needed to compile and link against libelf
482 LIBELF_CFLAGS = ${libelf_cflags}
483 LIBELF_LDFLAGS = ${libelf_ldflags}
484
485 # Whether GLX headers are available
486 HAVE_GLX = ${have_glx}
487
488 # Flags needed to find GL and GLX header files (GL/gl.h and GL/glx.h)
489 GL_CFLAGS = ${gl_cflags}
490
491 # Whether EGL headers are available
492 HAVE_EGL = ${have_egl}
493
494 # Flags needed to find EGL header files (EGL/egl.h)
495 EGL_CFLAGS = ${egl_cflags}
496
497 # Flags needed to have linker link only to necessary libraries
498 AS_NEEDED_LDFLAGS = ${as_needed_ldflags}
499
500 # Combined flags for compiling and linking against all of the above
501 CONFIGURE_CFLAGS = \$(TALLOC_CFLAGS) \$(LIBELF_CFLAGS) \$(GL_CFLAGS) \$(EGL_CFLAGS)
502 CONFIGURE_LDFLAGS = \$(TALLOC_LDFLAGS) \$(LIBELF_LDFLAGS)
503 EOF
504
505 # construct config.h
506 cat > config.h <<EOF
507 /* Generated by configure. */
508
509 /* Relative path from ${bindir} to ${libdir} */
510 #define BINDIR_TO_LIBFIPSDIR "$(relative_path ${BINDIR} ${LIBDIR})/fips"
511 EOF