]> git.cworth.org Git - fips/blob - configure
Stop processing command-line options at first non-option argument
[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 EGL/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 <EGL/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 printf "#include <features.h>\nint main(void){return 0;}\n" > arch-minimal.c
349
350 printf "Checking for machine-dependent compiler support:\n"
351
352 printf "        Compiler can create 32-bit binaries... "
353 have_m32=Yes
354 if ${CC} -m32 -o arch-minimal arch-minimal.c > /dev/null 2>&1
355 then
356     printf "Yes.\n"
357 else
358     printf "No.\n"
359     have_m32=No
360 fi
361
362 printf "        Compiler can create 64-bit binaries... "
363 have_m64=Yes
364 if ${CC} -m64 -o arch-minimal arch-minimal.c > /dev/null 2>&1
365 then
366     printf "Yes.\n"
367 else
368     printf "No.\n"
369     have_m64=No
370 fi
371
372 if [ "$have_m32" = "No" ] || [ "$have_m64" = "No" ]; then
373     cat <<EOF
374
375 * Warning: Cannot create both 32 and 64-bit fips libraries. Fips will not
376            support applications of the non-native size. Fixing this may be
377            as simple as running a command such as:
378
379                 sudo apt-get install gcc-multilib
380 EOF
381 fi
382
383 rm -f arch-minimal arch-minimal.c
384
385 if [ $errors -gt 0 ]; then
386     cat <<EOF
387
388 *** Error: The dependencies of ${PROJECT} could not be satisfied. You will
389 need to install the following packages before being able to compile
390 ${PROJECT}:
391
392 EOF
393     if [ $have_talloc -eq 0 ]; then
394         echo "  The talloc library (including development files such as headers)"
395         echo "  http://talloc.samba.org/"
396         echo
397     fi
398     if [ $have_libelf -eq 0 ]; then
399         echo "  The libelf library (including development files such as headers)"
400         echo "  http://http://sourceforge.net/projects/elftoolchain/"
401         echo
402     fi
403     if [ $have_gl -eq 0 ]; then
404         echo "  Open GL header files (GL/gl.h)"
405         echo "  http://www.mesa3d.org/"
406         echo
407     fi
408     if [ $have_gl_winsys -eq 0 ]; then
409         echo "  OpenGL window-system-bindings header files (GL/glx.h and/or GL/egl.h)"
410         echo "  http://www.mesa3d.org/"
411         echo
412     fi
413     cat <<EOF
414 With any luck, you're using a modern, package-based operating system
415 that has all of these packages available in the distribution. In that
416 case a simple command will install everything you need. For example:
417
418 On Debian and similar systems:
419
420         sudo apt-get install libtalloc-dev libelf-dev \\
421         libgl1-mesa-dev libgles2-mesa-dev
422
423 Or on Fedora and similar systems:
424
425         sudo yum install libtalloc-devel libelf-devel \\
426         mesa-libGL-devel mesa-libGLES-devel
427
428 On other systems, similar commands can be used, but the details of the
429 package names may be different.
430
431 When you have installed the necessary dependencies, you can run
432 configure again to ensure the packages can be found, or simply run
433 "make" to compile.
434
435 EOF
436     exit 1
437 fi
438
439 cat <<EOF
440
441 All required packages were found.
442
443 The following OpenGL window-system bindings will be supported:
444
445         GLX: ${have_glx}
446         EGL: ${have_egl}
447
448 You may now run the following commands to compile and install ${PROJECT}:
449
450         make
451         sudo make install
452
453 EOF
454
455 # construct the Makefile.config
456 cat > Makefile.config <<EOF
457 # This Makefile.config was automatically generated by the ./configure
458 # script of ${PROJECT}. If the configure script identified anything
459 # incorrectly, then you can edit this file to try to correct things,
460 # but be warned that if configure is run again it will destroy your
461 # changes, (and this could happen by simply calling "make" if the
462 # configure script is updated).
463
464 # The top-level directory for the source, (the directory containing
465 # the configure script). This may be different than the build
466 # directory (the current directory at the time configure was run).
467 srcdir = ${srcdir}
468
469 configure_options = $@
470
471 # We use vpath directives (rather than the VPATH variable) since the
472 # VPATH variable matches targets as well as prerequisites, (which is
473 # not useful since then a target left-over from a srcdir build would
474 # cause a target to not be built in the non-srcdir build).
475 #
476 # Also, we don't use a single "vpath % \$(srcdir)" here because we
477 # don't want the vpath to trigger for our emacs lisp compilation,
478 # (unless we first find a way to convince emacs to build the .elc
479 # target in a directory other than the directory of the .el
480 # prerequisite). In the meantime, we're actually copying in the .el
481 # files, (which is quite ugly).
482 vpath %.c \$(srcdir)
483 vpath %.cc \$(srcdir)
484 vpath %.1 \$(srcdir)
485 vpath Makefile.% \$(srcdir)
486
487 # The C compiler to use
488 CC = ${CC}
489
490 # Default FLAGS for C compiler (can be overridden by user such as "make CFLAGS=-g")
491 CFLAGS = ${CFLAGS}
492
493 # Default FLAGS for the linker (can be overridden by user such as "make LDFLAGS=-znow")
494 LDFLAGS = ${LDFLAGS}
495
496 # Flags to enable warnings when using the C compiler
497 WARN_CFLAGS=${WARN_CFLAGS}
498
499 # The prefix to which ${PROJECT} should be installed
500 prefix = ${PREFIX}
501
502 # The directory to which executables should be installed
503 bindir = ${BINDIR:=\$(prefix)/bin}
504
505 # The directory to which libraries should be installed
506 libdir = ${LIBDIR:=\$(prefix)/lib}
507
508 # The directory to which man pages should be installed
509 mandir = ${MANDIR:=\$(prefix)/share/man}
510
511 # The directory to which read-only (configuration) files should be installed
512 sysconfdir = ${SYSCONFDIR:=\$(prefix)/etc}
513
514 # Whether compiler can create 32 or 64-bit binaries
515 COMPILER_SUPPORTS_32 = ${have_m32}
516 COMPILER_SUPPORTS_64 = ${have_m64}
517
518 # Flags needed to compile and link against talloc
519 TALLOC_CFLAGS = ${talloc_cflags}
520 TALLOC_LDFLAGS = ${talloc_ldflags}
521
522 # Flags needed to compile and link against libelf
523 LIBELF_CFLAGS = ${libelf_cflags}
524 LIBELF_LDFLAGS = ${libelf_ldflags}
525
526 # Whether GLX headers are available
527 HAVE_GLX = ${have_glx}
528
529 # Flags needed to find GL and GLX header files (GL/gl.h and GL/glx.h)
530 GL_CFLAGS = ${gl_cflags}
531
532 # Whether EGL headers are available
533 HAVE_EGL = ${have_egl}
534
535 # Flags needed to find EGL header files (EGL/egl.h)
536 EGL_CFLAGS = ${egl_cflags}
537
538 # Flags needed to have linker link only to necessary libraries
539 AS_NEEDED_LDFLAGS = ${as_needed_ldflags}
540
541 # Flags needed to compile the fips binary
542 FIPS_CFLAGS = \$(WARN_CFLAGS) \$(TALLOC_CFLAGS) \$(LIBELF_CFLAGS)
543 FIPS_LDFLAGS = \$(TALLOC_LDFLAGS) \$(LIBELF_LDFLAGS)
544
545 # Flags needed to compile the libfips libraries
546 LIBFIPS_CFLAGS = \$(WARN_CFLAGS) \$(GL_CFLAGS) \$(EGL_CFLAGS)
547 LIBFIPS_LDFLAGS =
548 EOF
549
550 # construct config.h
551 cat > config.h <<EOF
552 /* Generated by configure. */
553
554 /* Relative path from ${bindir} to ${libdir} */
555 #define BINDIR_TO_LIBFIPSDIR "$(relative_path ${BINDIR} ${LIBDIR})/fips"
556 EOF