]>
Commit | Line | Data |
---|---|---|
bce1b489 | 1 | # Process this file with autoconf to produce a configure script. |
cbe34bb5 | 2 | # Copyright (C) 1994-2017 Free Software Foundation, Inc. |
9c01f395 | 3 | # Originally contributed by Dave Love (d.love@dl.ac.uk). |
bce1b489 | 4 | # |
9c01f395 | 5 | #This file is part of GCC. |
bce1b489 | 6 | # |
9c01f395 | 7 | #GCC is free software; you can redistribute it and/or modify |
bce1b489 | 8 | #it under the terms of the GNU General Public License as published by |
748086b7 | 9 | #the Free Software Foundation; either version 3, or (at your option) |
bce1b489 BE |
10 | #any later version. |
11 | # | |
9c01f395 | 12 | #GCC is distributed in the hope that it will be useful, |
bce1b489 BE |
13 | #but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 | #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 | #GNU General Public License for more details. | |
16 | # | |
17 | #You should have received a copy of the GNU General Public License | |
748086b7 JJ |
18 | #along with GCC; see the file COPYING3. If not see |
19 | #<http://www.gnu.org/licenses/>. | |
bce1b489 | 20 | |
df58e648 | 21 | AC_PREREQ(2.64) |
684c64bf | 22 | AC_INIT(package-unused, version-unused,, libobjc) |
252dde64 | 23 | AC_CONFIG_SRCDIR([objc/objc.h]) |
215c351a | 24 | GCC_TOPLEV_SUBDIRS |
bce1b489 | 25 | |
252dde64 | 26 | # We need the following definitions because AC_PROG_LIBTOOL relies on them |
1fcfac98 | 27 | PACKAGE=libobjc |
252dde64 | 28 | # Version is pulled out to make it a bit easier to change using sed. |
c7907a55 | 29 | VERSION=4:0:0 |
1fcfac98 NN |
30 | AC_SUBST(VERSION) |
31 | ||
6706f116 AO |
32 | # This works around the fact that libtool configuration may change LD |
33 | # for this particular configuration, but some shells, instead of | |
34 | # keeping the changes in LD private, export them just because LD is | |
35 | # exported. | |
36 | ORIGINAL_LD_FOR_MULTILIBS=$LD | |
37 | ||
252dde64 NN |
38 | # ------- |
39 | # Options | |
40 | # ------- | |
41 | ||
252dde64 NN |
42 | # We use these options to decide which functions to include. |
43 | AC_ARG_WITH(target-subdir, | |
44 | [ --with-target-subdir=SUBDIR | |
45 | configuring in a subdirectory]) | |
46 | AC_ARG_WITH(cross-host, | |
47 | [ --with-cross-host=HOST configuring with a cross compiler]) | |
48 | ||
49 | AC_MSG_CHECKING([for --enable-version-specific-runtime-libs]) | |
50 | AC_ARG_ENABLE(version-specific-runtime-libs, | |
51 | [ --enable-version-specific-runtime-libs Specify that runtime libraries should be installed in a compiler-specific directory ], | |
52 | [case "$enableval" in | |
53 | yes) version_specific_libs=yes ;; | |
54 | no) version_specific_libs=no ;; | |
55 | *) AC_MSG_ERROR([Unknown argument to enable/disable version-specific libs]);; | |
56 | esac], | |
57 | [version_specific_libs=no]) | |
58 | AC_MSG_RESULT($version_specific_libs) | |
59 | ||
252dde64 NN |
60 | # ----------- |
61 | # Directories | |
62 | # ----------- | |
9c01f395 | 63 | |
5b043f08 GK |
64 | # Find the rest of the source tree framework. |
65 | AM_ENABLE_MULTILIB(, ..) | |
aebb8c22 | 66 | |
b150efee | 67 | AC_CANONICAL_SYSTEM |
1506eac1 | 68 | ACX_NONCANONICAL_TARGET |
9c01f395 | 69 | |
af0c82b3 | 70 | # Export source directory. |
9c01f395 NN |
71 | # These need to be absolute paths, yet at the same time need to |
72 | # canonicalize only relative paths, because then amd will not unmount | |
73 | # drives. Thus the use of PWDCMD: set it to 'pawd' or 'amq -w' if using amd. | |
9c01f395 | 74 | case $srcdir in |
252dde64 NN |
75 | [\\/$]* | ?:[\\/]*) glibcpp_srcdir=${srcdir} ;; |
76 | *) glibcpp_srcdir=`cd "$srcdir" && ${PWDCMD-pwd} || echo "$srcdir"` ;; | |
9c01f395 | 77 | esac |
9c01f395 NN |
78 | AC_SUBST(glibcpp_srcdir) |
79 | ||
608e1e0c | 80 | # Calculate toolexeclibdir |
a42a57cb | 81 | # Also toolexecdir, though it's only used in toolexeclibdir |
9c01f395 NN |
82 | case ${version_specific_libs} in |
83 | yes) | |
84 | # Need the gcc compiler version to know where to install libraries | |
85 | # and header files if --enable-version-specific-runtime-libs option | |
86 | # is selected. | |
a42a57cb | 87 | toolexecdir='$(libdir)/gcc/$(target_noncanonical)' |
2b37e3d5 | 88 | toolexeclibdir='$(toolexecdir)/$(gcc_version)$(MULTISUBDIR)' |
9c01f395 NN |
89 | ;; |
90 | no) | |
91 | if test -n "$with_cross_host" && | |
92 | test x"$with_cross_host" != x"no"; then | |
9c01f395 | 93 | # Install a library built with a cross compiler in tooldir, not libdir. |
a42a57cb | 94 | toolexecdir='$(exec_prefix)/$(target_noncanonical)' |
608e1e0c NN |
95 | toolexeclibdir='$(toolexecdir)/lib' |
96 | else | |
a42a57cb | 97 | toolexecdir='$(libdir)/gcc-lib/$(target_noncanonical)' |
608e1e0c | 98 | toolexeclibdir='$(libdir)' |
9c01f395 NN |
99 | fi |
100 | multi_os_directory=`$CC -print-multi-os-directory` | |
101 | case $multi_os_directory in | |
102 | .) ;; # Avoid trailing /. | |
608e1e0c | 103 | *) toolexeclibdir=$toolexeclibdir/$multi_os_directory ;; |
9c01f395 NN |
104 | esac |
105 | ;; | |
106 | esac | |
a42a57cb | 107 | AC_SUBST(toolexecdir) |
608e1e0c | 108 | AC_SUBST(toolexeclibdir) |
9c01f395 | 109 | |
ff65de76 AP |
110 | # Figure out if we want to name the include directory and the |
111 | # library name changes differently. | |
7d34a5a9 | 112 | includedirname=include |
45d5f86c | 113 | libsuffix= |
ff65de76 AP |
114 | case "${host}" in |
115 | *-darwin*) | |
116 | # Darwin is the only target so far that needs a different include directory. | |
7d34a5a9 | 117 | includedirname=include-gnu-runtime |
af333b9a | 118 | libsuffix=-gnu |
ff65de76 AP |
119 | ;; |
120 | esac | |
7d34a5a9 | 121 | AC_SUBST(includedirname) |
4620d81e | 122 | AC_SUBST(libsuffix) |
ff65de76 | 123 | |
049bc404 AP |
124 | AC_CONFIG_HEADERS(config.h) |
125 | ||
252dde64 NN |
126 | # -------- |
127 | # Programs | |
128 | # -------- | |
129 | ||
130 | GCC_NO_EXECUTABLES | |
db7f3c69 NN |
131 | |
132 | # We must force CC to /not/ be a precious variable; otherwise | |
133 | # the wrong, non-multilib-adjusted value will be used in multilibs. | |
134 | # As a side effect, we have to subst CFLAGS ourselves. | |
135 | m4_rename([_AC_ARG_VAR_PRECIOUS],[real_PRECIOUS]) | |
136 | m4_define([_AC_ARG_VAR_PRECIOUS],[]) | |
252dde64 | 137 | AC_PROG_CC |
1b3b24c2 | 138 | m4_rename_force([real_PRECIOUS],[_AC_ARG_VAR_PRECIOUS]) |
db7f3c69 | 139 | |
a5a813f8 | 140 | # extra LD Flags which are required for targets |
7de6ba7a | 141 | ACX_LT_HOST_FLAGS |
a5a813f8 AP |
142 | case "${host}" in |
143 | *-darwin*) | |
144 | # Darwin needs -single_module when linking libobjc | |
7de6ba7a | 145 | extra_ldflags_libobjc='$(lt_host_flags) -Wl,-single_module' |
a5a813f8 | 146 | ;; |
19222959 DK |
147 | *-cygwin*|*-mingw*) |
148 | # Tell libtool to build DLLs on Windows | |
7de6ba7a | 149 | extra_ldflags_libobjc='$(lt_host_flags)' |
19222959 | 150 | ;; |
a5a813f8 AP |
151 | esac |
152 | AC_SUBST(extra_ldflags_libobjc) | |
153 | ||
db7f3c69 | 154 | AC_SUBST(CFLAGS) |
252dde64 NN |
155 | |
156 | AC_CHECK_TOOL(AS, as) | |
157 | AC_CHECK_TOOL(AR, ar) | |
158 | AC_CHECK_TOOL(RANLIB, ranlib, :) | |
159 | AC_PROG_INSTALL | |
7c6b0e92 | 160 | |
dd365157 MS |
161 | AM_MAINTAINER_MODE |
162 | ||
9c01f395 NN |
163 | # Enable Win32 DLL on MS Windows - FIXME |
164 | AC_LIBTOOL_WIN32_DLL | |
7c6b0e92 | 165 | |
b150efee | 166 | AC_PROG_LIBTOOL |
bce1b489 | 167 | |
dd365157 MS |
168 | AM_PROG_CC_C_O |
169 | ||
b150efee | 170 | AC_PROG_MAKE_SET |
bce1b489 | 171 | |
252dde64 NN |
172 | # ------- |
173 | # Headers | |
174 | # ------- | |
175 | ||
bce1b489 BE |
176 | # Sanity check for the cross-compilation case: |
177 | AC_CHECK_HEADER(stdio.h,:, | |
178 | [AC_MSG_ERROR([Can't find stdio.h. | |
179 | You must have a usable C system for the target already installed, at least | |
180 | including headers and, preferably, the library, before you can configure | |
181 | the Objective C runtime system. If necessary, install gcc now with | |
182 | \`LANGUAGES=c', then the target library, then build with \`LANGUAGES=objc'.])]) | |
183 | ||
184 | AC_HEADER_STDC | |
185 | ||
d972a4c2 OP |
186 | AC_CHECK_HEADERS(sched.h) |
187 | ||
252dde64 NN |
188 | # ----------- |
189 | # Miscellanea | |
190 | # ----------- | |
191 | ||
fd312537 NP |
192 | # Check if we have thread-local storage |
193 | GCC_CHECK_TLS | |
bce1b489 | 194 | |
539280a8 TS |
195 | gt_BITFIELD_TYPE_MATTERS |
196 | ||
114bf3f1 MK |
197 | # ----------- |
198 | # boehm-gc | |
199 | # ----------- | |
200 | ||
201 | AC_ARG_ENABLE(objc-gc, | |
202 | [AS_HELP_STRING([--enable-objc-gc], | |
203 | [enable use of Boehm's garbage collector with the | |
ac02e9a8 | 204 | GNU Objective-C runtime])],,enable_objc_gc=no) |
114bf3f1 MK |
205 | AC_ARG_WITH([target-bdw-gc], |
206 | [AS_HELP_STRING([--with-target-bdw-gc=PATHLIST], | |
207 | [specify prefix directory for installed bdw-gc package. | |
208 | Equivalent to --with-target-bdw-gc-include=PATH/include | |
209 | plus --with-target-bdw-gc-lib=PATH/lib])]) | |
210 | AC_ARG_WITH([target-bdw-gc-include], | |
211 | [AS_HELP_STRING([--with-target-bdw-gc-include=PATHLIST], | |
212 | [specify directories for installed bdw-gc include files])]) | |
213 | AC_ARG_WITH([target-bdw-gc-lib], | |
214 | [AS_HELP_STRING([--with-target-bdw-gc-lib=PATHLIST], | |
215 | [specify directories for installed bdw-gc library])]) | |
216 | ||
217 | case "$enable_objc_gc" in | |
218 | no) | |
219 | use_bdw_gc=no | |
220 | ;; | |
221 | *) | |
222 | AC_MSG_CHECKING([for bdw garbage collector]) | |
223 | if test "x$with_target_bdw_gc$with_target_bdw_gc_include$with_target_bdw_gc_lib" = x; then | |
825fba52 MK |
224 | dnl no bdw-gw options, assuming bdw-gc in default locations |
225 | BDW_GC_CFLAGS= | |
226 | BDW_GC_LIBS="-lgc" | |
114bf3f1 MK |
227 | else |
228 | dnl bdw-gw options passed by configure flags | |
229 | if test "x$with_target_bdw_gc_include" = x && test "x$with_target_bdw_gc_lib" != x; then | |
230 | AC_MSG_ERROR([found --with-target-bdw-gc-lib but --with-target-bdw-gc-include missing]) | |
231 | elif test "x$with_target_bdw_gc_include" != x && test "x$with_target_bdw_gc_lib" = x; then | |
232 | AC_MSG_ERROR([found --with-target-bdw-gc-include but --with-target-bdw-gc-lib missing]) | |
233 | else | |
234 | AC_MSG_RESULT([using paths configured with --with-target-bdw-gc options]) | |
235 | fi | |
236 | mldir=`${CC-gcc} --print-multi-directory 2>/dev/null` | |
237 | bdw_val= | |
238 | if test "x$with_target_bdw_gc" != x; then | |
239 | for i in `echo $with_target_bdw_gc | tr ',' ' '`; do | |
240 | case "$i" in | |
241 | *=*) sd=${i%%=*}; d=${i#*=} ;; | |
242 | *) sd=.; d=$i ;; | |
243 | esac | |
244 | if test "$mldir" = "$sd"; then | |
245 | bdw_val=$d | |
246 | fi | |
247 | done | |
248 | if test "x$bdw_val" = x; then | |
249 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc]) | |
250 | fi | |
251 | bdw_inc_dir="$bdw_val/include" | |
252 | bdw_lib_dir="$bdw_val/lib" | |
253 | fi | |
254 | bdw_val= | |
255 | if test "x$with_target_bdw_gc_include" != x; then | |
256 | for i in `echo $with_target_bdw_gc_include | tr ',' ' '`; do | |
257 | case "$i" in | |
258 | *=*) sd=${i%%=*}; d=${i#*=} ;; | |
259 | *) sd=.; d=$i ;; | |
260 | esac | |
261 | if test "$mldir" = "$sd"; then | |
262 | bdw_val=$d | |
263 | fi | |
264 | done | |
265 | if test "x$bdw_val" = x; then | |
266 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-include]) | |
267 | fi | |
268 | bdw_inc_dir="$bdw_val" | |
269 | fi | |
270 | bdw_val= | |
271 | if test "x$with_target_bdw_gc_lib" != x; then | |
272 | for i in `echo $with_target_bdw_gc_lib | tr ',' ' '`; do | |
273 | case "$i" in | |
274 | *=*) sd=${i%%=*}; d=${i#*=} ;; | |
275 | *) sd=.; d=$i ;; | |
276 | esac | |
277 | if test "$mldir" = "$sd"; then | |
278 | bdw_val=$d | |
279 | fi | |
280 | done | |
281 | if test "x$bdw_val" = x; then | |
282 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-lib]) | |
283 | fi | |
284 | bdw_lib_dir="$bdw_val" | |
285 | fi | |
286 | if test "x$bdw_inc_dir" = x; then | |
287 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-include]) | |
288 | fi | |
289 | if test "x$bdw_lib_dir" = x; then | |
290 | AC_MSG_ERROR([no multilib path ($mldir) found in --with-target-bdw-gc-lib]) | |
291 | fi | |
292 | BDW_GC_CFLAGS="-I$bdw_inc_dir" | |
293 | BDW_GC_LIBS="-L$bdw_lib_dir -lgc" | |
294 | AC_MSG_RESULT([found]) | |
295 | fi | |
296 | ||
297 | AC_MSG_CHECKING([for system boehm-gc]) | |
298 | save_CFLAGS=$CFLAGS | |
299 | save_LIBS=$LIBS | |
300 | CFLAGS="$CFLAGS $BDW_GC_CFLAGS" | |
301 | LIBS="$LIBS $BDW_GC_LIBS" | |
302 | dnl the link test is not good enough for ARM32 multilib detection, | |
303 | dnl first check to link, then to run | |
304 | AC_LINK_IFELSE( | |
305 | [AC_LANG_PROGRAM([#include <gc/gc.h>],[GC_init()])], | |
306 | [ | |
307 | AC_RUN_IFELSE([AC_LANG_SOURCE([[ | |
308 | #include <gc/gc.h> | |
309 | int main() { | |
310 | GC_init(); | |
311 | return 0; | |
312 | } | |
313 | ]])], | |
314 | [system_bdw_gc_found=yes], | |
315 | [system_bdw_gc_found=no], | |
316 | dnl assume no system boehm-gc for cross builds ... | |
317 | [system_bdw_gc_found=no] | |
318 | ) | |
319 | ], | |
320 | [system_bdw_gc_found=no]) | |
321 | CFLAGS=$save_CFLAGS | |
322 | LIBS=$save_LIBS | |
323 | if test x$enable_objc_gc = xauto && test x$system_bdw_gc_found = xno; then | |
324 | AC_MSG_WARN([system bdw-gc not found, not building libobjc_gc]) | |
325 | use_bdw_gc=no | |
326 | elif test x$enable_objc_gc = xyes && test x$system_bdw_gc_found = xno; then | |
327 | AC_MSG_ERROR([system bdw-gc required but not found]) | |
328 | else | |
329 | use_bdw_gc=yes | |
330 | AC_MSG_RESULT([found]) | |
331 | fi | |
332 | esac | |
333 | ||
334 | if test "$use_bdw_gc" = no; then | |
335 | OBJC_GCFLAGS='' | |
336 | OBJC_BOEHM_GC='' | |
337 | OBJC_BOEHM_GC_INCLUDES='' | |
338 | OBJC_BOEHM_GC_LIBS='' | |
339 | else | |
340 | OBJC_GCFLAGS='-DOBJC_WITH_GC=1' | |
341 | OBJC_BOEHM_GC='libobjc_gc$(libsuffix).la' | |
342 | OBJC_BOEHM_GC_INCLUDES=$BDW_GC_CFLAGS | |
343 | OBJC_BOEHM_GC_LIBS=$BDW_GC_LIBS | |
344 | fi | |
345 | AC_SUBST(OBJC_GCFLAGS) | |
346 | AC_SUBST(OBJC_BOEHM_GC) | |
347 | AC_SUBST(OBJC_BOEHM_GC_INCLUDES) | |
348 | AC_SUBST(OBJC_BOEHM_GC_LIBS) | |
349 | ||
3c36aa6b JJ |
350 | # Determine what GCC version number to use in filesystem paths. |
351 | GCC_BASE_VER | |
352 | ||
252dde64 NN |
353 | # ------ |
354 | # Output | |
355 | # ------ | |
bce1b489 | 356 | |
2c888488 L |
357 | if test ${multilib} = yes; then |
358 | multilib_arg="--enable-multilib" | |
359 | else | |
360 | multilib_arg= | |
361 | fi | |
252dde64 | 362 | |
2c888488 | 363 | AC_CONFIG_FILES([Makefile]) |
252dde64 | 364 | AC_OUTPUT |