-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathconfigure.ac
295 lines (238 loc) · 11.7 KB
/
configure.ac
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
#!/bin/bash -norc
dnl This file is an input file used by the GNU "autoconf" program to
dnl generate the file "configure", which is run during installation
dnl to configure the system for the local environment.
#-----------------------------------------------------------------------
# Based on sample configure.ac for Tcl Extensions. The only places you
# should need to modify this file are marked by the string __CHANGE__
#-----------------------------------------------------------------------
#-----------------------------------------------------------------------
# __CHANGE__
# Set your package name and version numbers here.
#
# This initializes the environment with PACKAGE_NAME and PACKAGE_VERSION
# set as provided. These will also be added as -D defs in your Makefile
# so you can encode the package version directly into the source files.
# This will also define a special symbol for Windows (BUILD_<PACKAGE_NAME>
# so that we create the export library with the dll.
#-----------------------------------------------------------------------
# Leave a space after the comma for release.cmd to parse
AC_INIT([cffi], [2.0.3])
#--------------------------------------------------------------------
# Call TEA_INIT as the first TEA_ macro to set up initial vars.
# This will define a ${TEA_PLATFORM} variable == "unix" or "windows"
# as well as PKG_LIB_FILE and PKG_STUB_LIB_FILE.
#--------------------------------------------------------------------
TEA_INIT(3.13)
AC_CONFIG_AUX_DIR(tclconfig)
#--------------------------------------------------------------------
# Load the tclConfig.sh file
#--------------------------------------------------------------------
TEA_PATH_TCLCONFIG
TEA_LOAD_TCLCONFIG
#--------------------------------------------------------------------
# Load the tkConfig.sh file if necessary (Tk extension)
#--------------------------------------------------------------------
#TEA_PATH_TKCONFIG
#TEA_LOAD_TKCONFIG
#-----------------------------------------------------------------------
# Handle the --prefix=... option by defaulting to what Tcl gave.
# Must be called after TEA_LOAD_TCLCONFIG and before TEA_SETUP_COMPILER.
#-----------------------------------------------------------------------
TEA_PREFIX
#-----------------------------------------------------------------------
# Standard compiler checks.
# This sets up CC by using the CC env var, or looks for gcc otherwise.
# This also calls AC_PROG_CC and a few others to create the basic setup
# necessary to compile executables.
#-----------------------------------------------------------------------
TEA_SETUP_COMPILER
#-----------------------------------------------------------------------
# __CHANGE__
# Specify the C source files to compile in TEA_ADD_SOURCES,
# public headers that need to be installed in TEA_ADD_HEADERS,
# stub library C source files to compile in TEA_ADD_STUB_SOURCES,
# and runtime Tcl library files in TEA_ADD_TCL_SOURCES.
# This defines PKG(_STUB)_SOURCES, PKG(_STUB)_OBJECTS, PKG_HEADERS
# and PKG_TCL_SOURCES.
#-----------------------------------------------------------------------
TEA_ADD_SOURCES([generic/tclCffi.c \
generic/tclCffiAlias.c \
generic/tclCffiArena.c \
generic/tclCffiCallback.c \
generic/tclCffiEnum.c \
generic/tclCffiFunction.c \
generic/tclCffiHelp.c \
generic/tclCffiInterface.c \
generic/tclCffiLoad.c \
generic/tclCffiMemory.c \
generic/tclCffiNames.c \
generic/tclCffiPointer.c \
generic/tclCffiPrototype.c \
generic/tclCffiStruct.c \
generic/tclCffiTclh.c \
generic/tclCffiTypes.c \
generic/tclCffiWrapper.c])
TEA_ADD_HEADERS([])
TEA_ADD_INCLUDES([-I${srcdir}/generic -I${srcdir}/tclh/include])
TEA_ADD_STUB_SOURCES([])
TEA_ADD_TCL_SOURCES([])
#--------------------------------------------------------------------
# __CHANGE__
#
# You can add more files to clean if your extension creates any extra
# files by extending CLEANFILES.
# Add pkgIndex.tcl if it is generated in the Makefile instead of ./configure
# and change Makefile.in to move it from CONFIG_CLEAN_FILES to BINARIES var.
#
# A few miscellaneous platform-specific items:
# TEA_ADD_* any platform specific compiler/build info here.
#--------------------------------------------------------------------
if test "${TEA_PLATFORM}" = "windows" ; then
# Ensure no empty if clauses
CLEANFILES="$CLEANFILES pkgIndex.tcl *.lib *.dll *.exp *.ilk *.pdb vc*.pch"
#TEA_ADD_SOURCES([win/winFile.c])
#TEA_ADD_INCLUDES([-I\"$(${CYGPATH} ${srcdir}/win)\"])
TEA_ADD_LIBS([rpcrt4.lib])
else
# Ensure no empty else clauses
CLEANFILES="$CLEANFILES pkgIndex.tcl"
if test "`uname -s`" = "Darwin" ; then
TEA_ADD_LIBS([-framework CoreFoundation])
else
TEA_ADD_LIBS([-luuid])
fi
fi
#--------------------------------------------------------------------
# __CHANGE__
# Choose which headers you need. Extension authors should try very
# hard to only rely on the Tcl public header files. Internal headers
# contain private data structures and are subject to change without
# notice.
# This MUST be called after TEA_LOAD_TCLCONFIG / TEA_LOAD_TKCONFIG
#--------------------------------------------------------------------
TEA_PUBLIC_TCL_HEADERS
#TEA_PRIVATE_TCL_HEADERS
#TEA_PUBLIC_TK_HEADERS
#TEA_PRIVATE_TK_HEADERS
#TEA_PATH_X
#--------------------------------------------------------------------
# cffi specific configuration
#--------------------------------------------------------------------
AC_MSG_CHECKING([which library to use for foreign function calls])
AC_ARG_WITH([libffi],
AS_HELP_STRING([--with-libffi],
[use libffi for foreign function calls [--with-libffi=yes]]),
[], [with_libffi=default])
AC_ARG_ENABLE([staticffi],
AS_HELP_STRING([--disable-staticffi],
[statically link ffi library [--enable-staticffi]]),
[], [enable_staticffi=yes])
AC_ARG_WITH([dyncall],
AS_HELP_STRING([--with-dyncall],
[use dyncall for foreign function calls [--with-dyncall=no]]),
[], [with_dyncall=default])
# Either of libffi or dyncall might be used.
AS_CASE([$with_libffi,$with_dyncall],
[no,no],[AC_MSG_ERROR([Please, enable exactly one of --with-libffi or --with-dyncall.])],
[default,default],[AS_VAR_SET([with_libffi], [yes])],
[no,default],[AS_VAR_SET([with_dyncall], [yes])],
[default,no],[AS_VAR_SET([with_libffi], [yes])],
[default,yes],[], dnl continue
[yes,default],[], dnl continue
[no,yes],[], dnl continue
[yes,no],[], dnl continue
[AC_MSG_ERROR([Please, enable exactly one of --with-libffi or --with-dyncall.])])
AS_VAR_IF([with_libffi], [yes], [AC_MSG_RESULT([libffi])], [AC_MSG_RESULT([dyncall])])
#--------------------------------------------------------------------
# Check whether --enable-threads or --disable-threads was given.
# This auto-enables if Tcl was compiled threaded.
#--------------------------------------------------------------------
TEA_ENABLE_THREADS
#--------------------------------------------------------------------
# The statement below defines a collection of symbols related to
# building as a shared library instead of a static library.
#--------------------------------------------------------------------
TEA_ENABLE_SHARED
#--------------------------------------------------------------------
# This macro figures out what flags to use with the compiler/linker
# when building shared/static debug/optimized objects. This information
# can be taken from the tclConfig.sh file, but this figures it all out.
#--------------------------------------------------------------------
TEA_CONFIG_CFLAGS
TEA_ADD_CFLAGS([-DTCL_NO_DEPRECATED -std=gnu99])
AC_CONFIG_COMMANDS_PRE(
[# Must define -DFFI_BUILDING when linking statically, see commentary of FFI_API
# in ffi.h for details.
AS_VAR_IF([with_libffi], [yes],
[AS_VAR_IF([enable_staticffi], [yes],
[AS_VAR_APPEND([DEFS], [" -DFFI_BUILDING=static"])])])])
AS_VAR_IF([with_libffi], [yes],
[AC_DEFINE([CFFI_USE_LIBFFI], 1, [Use libffi for foreign function calls])
dnl Do not try to guess static linking absolute path if LIBFFI_LIBS was
dnl explicitely given.
AS_VAR_SET_IF([LIBFFI_LIBS], [],
[AS_VAR_IF([enable_staticffi], [yes],
[AS_VAR_SET([LIBFFI_LIBS], ["-Wl,-Bstatic -lffi -Wl,-Bdynamic"])],
[AS_VAR_SET([LIBFFI_LIBS], ["-lffi"])]
)
])
TEA_ADD_INCLUDES([$LIBFFI_CFLAGS])
TEA_ADD_SOURCES([generic/tclCffiLibffi.c])
TEA_ADD_LIBS([$LIBFFI_LIBS])])
dnl See with_libffi comments above.
AS_VAR_IF([with_dyncall], [yes],
[AC_DEFINE([CFFI_USE_DYNCALL], 1, [Use dyncalls for foreign function calls])
dnl When DYNCALL_LIBS
TEA_ADD_CFLAGS([-DCFFI_USE_DYNCALL])
TEA_ADD_INCLUDES([$DYNCALL_CFLAGS])
TEA_ADD_SOURCES([generic/tclCffiDyncall.c])
TEA_ADD_LIBS([-ldynload_s -ldyncall_s -ldyncallback_s])])
#--------------------------------------------------------------------
# Set the default compiler switches based on the --enable-symbols option.
#--------------------------------------------------------------------
TEA_ENABLE_SYMBOLS
#--------------------------------------------------------------------
# This macro generates a line to use when building a library. It
# depends on values set by the TEA_ENABLE_SHARED, TEA_ENABLE_SYMBOLS,
# and TEA_LOAD_TCLCONFIG macros above.
#--------------------------------------------------------------------
TEA_MAKE_LIB
#--------------------------------------------------------------------
# Determine the name of the tclsh and/or wish executables in the
# Tcl and Tk build directories or the location they were installed
# into. These paths are used to support running test cases only,
# the Makefile should not be making use of these paths to generate
# a pkgIndex.tcl file or anything else at extension build time.
#--------------------------------------------------------------------
TEA_PROG_TCLSH
#TEA_PROG_WISH
#--------------------------------------------------------------------
# Setup a *Config.sh.in configuration file.
#--------------------------------------------------------------------
#TEA_EXPORT_CONFIG([sample])
#AC_SUBST(SAMPLE_VAR)
#--------------------------------------------------------------------
# Needed for test DLL suffix depending on platform
#--------------------------------------------------------------------
AC_SUBST(SHLIB_SUFFIX)
#--------------------------------------------------------------------
# Needed for linking against tommath on Windows. TCL_TOMMATH_LIB_NAME
# will be set in tclConfig.sh when required (Windows, Tcl 9)
#--------------------------------------------------------------------
# No longer needed
#if test "X${TCL_TOMMATH_LIB_NAME}" != "X" ; then
#TCL_TOMMATH_LIB=\${libdir}/${TCL_TOMMATH_LIB_NAME}
#fi
AC_SUBST(TCL_TOMMATH_LIB)
#--------------------------------------------------------------------
# Specify files to substitute AC variables in. You may alternatively
# have a special pkgIndex.tcl.in or other files which require
# substituting the AC variables in. Include these here.
#--------------------------------------------------------------------
AC_CONFIG_FILES([Makefile pkgIndex.tcl])
#--------------------------------------------------------------------
# Finally, substitute all of the various values into the files
# specified with AC_CONFIG_FILES.
#--------------------------------------------------------------------
AC_OUTPUT