From owner-svn-ports-head@freebsd.org Thu Feb 8 13:05:41 2018 Return-Path: Delivered-To: svn-ports-head@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 72D50F02182; Thu, 8 Feb 2018 13:05:41 +0000 (UTC) (envelope-from gahr@FreeBSD.org) Received: from mxrelay.nyi.freebsd.org (mxrelay.nyi.freebsd.org [IPv6:2610:1c1:1:606c::19:3]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client CN "mxrelay.nyi.freebsd.org", Issuer "Let's Encrypt Authority X3" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 25EA1871ED; Thu, 8 Feb 2018 13:05:41 +0000 (UTC) (envelope-from gahr@FreeBSD.org) Received: from repo.freebsd.org (repo.freebsd.org [IPv6:2610:1c1:1:6068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mxrelay.nyi.freebsd.org (Postfix) with ESMTPS id 078B0165C8; Thu, 8 Feb 2018 13:05:41 +0000 (UTC) (envelope-from gahr@FreeBSD.org) Received: from repo.freebsd.org ([127.0.1.37]) by repo.freebsd.org (8.15.2/8.15.2) with ESMTP id w18D5fAK007595; Thu, 8 Feb 2018 13:05:41 GMT (envelope-from gahr@FreeBSD.org) Received: (from gahr@localhost) by repo.freebsd.org (8.15.2/8.15.2/Submit) id w18D5el3007590; Thu, 8 Feb 2018 13:05:40 GMT (envelope-from gahr@FreeBSD.org) Message-Id: <201802081305.w18D5el3007590@repo.freebsd.org> X-Authentication-Warning: repo.freebsd.org: gahr set sender to gahr@FreeBSD.org using -f From: Pietro Cerutti Date: Thu, 8 Feb 2018 13:05:40 +0000 (UTC) To: ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org Subject: svn commit: r461237 - in head/lang/expect: . files X-SVN-Group: ports-head X-SVN-Commit-Author: gahr X-SVN-Commit-Paths: in head/lang/expect: . files X-SVN-Commit-Revision: 461237 X-SVN-Commit-Repository: ports MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-ports-head@freebsd.org X-Mailman-Version: 2.1.25 Precedence: list List-Id: SVN commit messages for the ports tree for head List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 08 Feb 2018 13:05:41 -0000 Author: gahr Date: Thu Feb 8 13:05:40 2018 New Revision: 461237 URL: https://svnweb.freebsd.org/changeset/ports/461237 Log: lang/expect: update to 5.45.4 Announcement: https://sourceforge.net/p/tcl/mailman/message/36215275/ While at it, set LICENSE and import TEA 3.10 (which fixes the shared library generation). Added: head/lang/expect/files/patch-tclconfig_tcl.m4 (contents, props changed) Deleted: head/lang/expect/files/patch-exp__event.c head/lang/expect/files/patch-exp_main_sub.c head/lang/expect/files/patch-expect-5.45.3 Modified: head/lang/expect/Makefile head/lang/expect/distinfo head/lang/expect/pkg-plist Modified: head/lang/expect/Makefile ============================================================================== --- head/lang/expect/Makefile Thu Feb 8 13:01:28 2018 (r461236) +++ head/lang/expect/Makefile Thu Feb 8 13:05:40 2018 (r461237) @@ -2,28 +2,28 @@ # $FreeBSD$ PORTNAME= expect -PORTVERSION= 5.45.3 +PORTVERSION= 5.45.4 PORTEPOCH= 1 CATEGORIES= lang tcl tk -MASTER_SITES= SF/expect/Expect/${PORTVERSION:R} -DISTNAME= ${PORTNAME}${PORTVERSION:R} +MASTER_SITES= SF/expect/Expect/${PORTVERSION} +DISTNAME= ${PORTNAME}${PORTVERSION} MAINTAINER= tcltk@FreeBSD.org COMMENT= Sophisticated scripter based on Tcl/Tk -LIBEXPECT_VER= ${PORTVERSION:S/.//g} +LICENSE= PD +LICENSE_FILE= ${WRKSRC}/license.terms WRKSRC= ${WRKDIR}/${DISTNAME} USES= tcl:tea autoreconf USE_LDCONFIG= yes CONFIGURE_ARGS= --datadir=${DATADIR} -PLIST_SUB+= EXPECT_VER=${PORTVERSION} \ - LIBEXPECT_VER=${LIBEXPECT_VER} +PLIST_SUB+= PORTVERSION=${PORTVERSION} TEST_TARGET= test post-install: - ${LN} -sf expect${PORTVERSION}/libexpect${LIBEXPECT_VER}.so \ + ${LN} -sf expect${PORTVERSION}/libexpect${PORTVERSION}.so \ ${STAGEDIR}${PREFIX}/lib/libexpect.so.1 ${LN} -sf libexpect.so.1 ${STAGEDIR}${PREFIX}/lib/libexpect.so Modified: head/lang/expect/distinfo ============================================================================== --- head/lang/expect/distinfo Thu Feb 8 13:01:28 2018 (r461236) +++ head/lang/expect/distinfo Thu Feb 8 13:05:40 2018 (r461237) @@ -1,3 +1,3 @@ -TIMESTAMP = 1518080080 -SHA256 (expect5.45.tar.gz) = b28dca90428a3b30e650525cdc16255d76bb6ccd65d448be53e620d95d5cc040 -SIZE (expect5.45.tar.gz) = 628808 +TIMESTAMP = 1518093806 +SHA256 (expect5.45.4.tar.gz) = 49a7da83b0bdd9f46d04a04deec19c7767bb9a323e40c4781f89caf760b92c34 +SIZE (expect5.45.4.tar.gz) = 632363 Added: head/lang/expect/files/patch-tclconfig_tcl.m4 ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/lang/expect/files/patch-tclconfig_tcl.m4 Thu Feb 8 13:05:40 2018 (r461237) @@ -0,0 +1,1236 @@ +--- tclconfig/tcl.m4.orig 2018-02-04 13:55:43 UTC ++++ tclconfig/tcl.m4 +@@ -8,14 +8,12 @@ + # + # See the file "license.terms" for information on usage and redistribution + # of this file, and for a DISCLAIMER OF ALL WARRANTIES. +-# +-# RCS: @(#) $Id: tcl.m4,v 1.6 2010/09/16 20:46:47 hobbs Exp $ + + AC_PREREQ(2.57) + + dnl TEA extensions pass us the version of TEA they think they + dnl are compatible with (must be set in TEA_INIT below) +-dnl TEA_VERSION="3.9" ++dnl TEA_VERSION="3.10" + + # Possible values for key variables defined: + # +@@ -140,6 +138,8 @@ AC_DEFUN([TEA_PATH_TCLCONFIG], [ + `ls -d /usr/contrib/lib 2>/dev/null` \ + `ls -d /usr/lib 2>/dev/null` \ + `ls -d /usr/lib64 2>/dev/null` \ ++ `ls -d /usr/lib/tcl8.6 2>/dev/null` \ ++ `ls -d /usr/lib/tcl8.5 2>/dev/null` \ + ; do + if test -f "$i/tclConfig.sh" ; then + ac_cv_c_tclconfig="`(cd $i; pwd)`" +@@ -170,7 +170,7 @@ AC_DEFUN([TEA_PATH_TCLCONFIG], [ + + if test x"${ac_cv_c_tclconfig}" = x ; then + TCL_BIN_DIR="# no Tcl configs found" +- AC_MSG_ERROR([Can't find Tcl configuration definitions]) ++ AC_MSG_ERROR([Can't find Tcl configuration definitions. Use --with-tcl to specify a directory containing tclConfig.sh]) + else + no_tcl= + TCL_BIN_DIR="${ac_cv_c_tclconfig}" +@@ -323,7 +323,7 @@ AC_DEFUN([TEA_PATH_TKCONFIG], [ + + if test x"${ac_cv_c_tkconfig}" = x ; then + TK_BIN_DIR="# no Tk configs found" +- AC_MSG_ERROR([Can't find Tk configuration definitions]) ++ AC_MSG_ERROR([Can't find Tk configuration definitions. Use --with-tk to specify a directory containing tkConfig.sh]) + else + no_tk= + TK_BIN_DIR="${ac_cv_c_tkconfig}" +@@ -344,11 +344,10 @@ AC_DEFUN([TEA_PATH_TKCONFIG], [ + # + # Results: + # +-# Subst the following vars: ++# Substitutes the following vars: + # TCL_BIN_DIR + # TCL_SRC_DIR + # TCL_LIB_FILE +-# + #------------------------------------------------------------------------ + + AC_DEFUN([TEA_LOAD_TCLCONFIG], [ +@@ -417,25 +416,21 @@ AC_DEFUN([TEA_LOAD_TCLCONFIG], [ + AC_SUBST(TCL_STUB_LIB_FLAG) + AC_SUBST(TCL_STUB_LIB_SPEC) + +- case "`uname -s`" in +- *CYGWIN_*) +- AC_MSG_CHECKING([for cygwin variant]) +- case ${TCL_EXTRA_CFLAGS} in +- *-mwin32*|*-mno-cygwin*) +- TEA_PLATFORM="windows" +- CFLAGS="$CFLAGS -mwin32" +- AC_MSG_RESULT([win32]) +- ;; +- *) +- TEA_PLATFORM="unix" +- AC_MSG_RESULT([unix]) +- ;; +- esac +- EXEEXT=".exe" +- ;; +- *) +- ;; +- esac ++ AC_MSG_CHECKING([platform]) ++ hold_cc=$CC; CC="$TCL_CC" ++ AC_TRY_COMPILE(,[ ++ #ifdef _WIN32 ++ #error win32 ++ #endif ++ ], [ ++ TEA_PLATFORM="unix" ++ CYGPATH=echo ++ ], [ ++ TEA_PLATFORM="windows" ++ AC_CHECK_PROG(CYGPATH, cygpath, cygpath -m, echo) ] ++ ) ++ CC=$hold_cc ++ AC_MSG_RESULT($TEA_PLATFORM) + + # The BUILD_$pkg is to define the correct extern storage class + # handling when making this package +@@ -443,6 +438,7 @@ AC_DEFUN([TEA_LOAD_TCLCONFIG], [ + [Building extension source?]) + # Do this here as we have fully defined TEA_PLATFORM now + if test "${TEA_PLATFORM}" = "windows" ; then ++ EXEEXT=".exe" + CLEANFILES="$CLEANFILES *.lib *.dll *.pdb *.exp" + fi + +@@ -567,11 +563,11 @@ AC_DEFUN([TEA_LOAD_TKCONFIG], [ + # only for running extension test cases. It should never be + # or generation of files (like pkgIndex.tcl) at build time. + # +-# Arguments ++# Arguments: + # none + # +-# Results +-# Subst's the following values: ++# Results: ++# Substitutes the following vars: + # TCLSH_PROG + #------------------------------------------------------------------------ + +@@ -580,7 +576,15 @@ AC_DEFUN([TEA_PROG_TCLSH], [ + if test -f "${TCL_BIN_DIR}/Makefile" ; then + # tclConfig.sh is in Tcl build directory + if test "${TEA_PLATFORM}" = "windows"; then ++ if test -f "${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}${EXEEXT}" ; then + TCLSH_PROG="${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}${EXEEXT}" ++ elif test -f "${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}s${EXEEXT}" ; then ++ TCLSH_PROG="${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}s${EXEEXT}" ++ elif test -f "${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}t${EXEEXT}" ; then ++ TCLSH_PROG="${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}t${EXEEXT}" ++ elif test -f "${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}st${EXEEXT}" ; then ++ TCLSH_PROG="${TCL_BIN_DIR}/tclsh${TCL_MAJOR_VERSION}${TCL_MINOR_VERSION}${TCL_DBGX}st${EXEEXT}" ++ fi + else + TCLSH_PROG="${TCL_BIN_DIR}/tclsh" + fi +@@ -617,11 +621,11 @@ AC_DEFUN([TEA_PROG_TCLSH], [ + # only for running extension test cases. It should never be + # or generation of files (like pkgIndex.tcl) at build time. + # +-# Arguments ++# Arguments: + # none + # +-# Results +-# Subst's the following values: ++# Results: ++# Substitutes the following vars: + # WISH_PROG + #------------------------------------------------------------------------ + +@@ -630,9 +634,17 @@ AC_DEFUN([TEA_PROG_WISH], [ + if test -f "${TK_BIN_DIR}/Makefile" ; then + # tkConfig.sh is in Tk build directory + if test "${TEA_PLATFORM}" = "windows"; then ++ if test -f "${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}${EXEEXT}" ; then + WISH_PROG="${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}${EXEEXT}" ++ elif test -f "${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}s${EXEEXT}" ; then ++ WISH_PROG="${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}$s{EXEEXT}" ++ elif test -f "${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}t${EXEEXT}" ; then ++ WISH_PROG="${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}t${EXEEXT}" ++ elif test -f "${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}st${EXEEXT}" ; then ++ WISH_PROG="${TK_BIN_DIR}/wish${TK_MAJOR_VERSION}${TK_MINOR_VERSION}${TK_DBGX}st${EXEEXT}" ++ fi + else +- WISH_PROG="${TK_BIN_DIR}/wish" ++ WISH_PROG="${TK_BIN_DIR}/wish" + fi + else + # tkConfig.sh is in install location +@@ -732,7 +744,6 @@ AC_DEFUN([TEA_ENABLE_SHARED], [ + # TCL_THREADS + # _REENTRANT + # _THREAD_SAFE +-# + #------------------------------------------------------------------------ + + AC_DEFUN([TEA_ENABLE_THREADS], [ +@@ -856,12 +867,11 @@ AC_DEFUN([TEA_ENABLE_THREADS], [ + # + # Defines the following vars: + # CFLAGS_DEFAULT Sets to $(CFLAGS_DEBUG) if true +-# Sets to $(CFLAGS_OPTIMIZE) if false ++# Sets to "$(CFLAGS_OPTIMIZE) -DNDEBUG" if false + # LDFLAGS_DEFAULT Sets to $(LDFLAGS_DEBUG) if true + # Sets to $(LDFLAGS_OPTIMIZE) if false + # DBGX Formerly used as debug library extension; + # always blank now. +-# + #------------------------------------------------------------------------ + + AC_DEFUN([TEA_ENABLE_SYMBOLS], [ +@@ -874,7 +884,7 @@ AC_DEFUN([TEA_ENABLE_SYMBOLS], [ + [tcl_ok=$enableval], [tcl_ok=no]) + DBGX="" + if test "$tcl_ok" = "no"; then +- CFLAGS_DEFAULT="${CFLAGS_OPTIMIZE}" ++ CFLAGS_DEFAULT="${CFLAGS_OPTIMIZE} -DNDEBUG" + LDFLAGS_DEFAULT="${LDFLAGS_OPTIMIZE}" + AC_MSG_RESULT([no]) + else +@@ -921,7 +931,6 @@ AC_DEFUN([TEA_ENABLE_SYMBOLS], [ + # + # Defines the following vars: + # HAVE_LANGINFO Triggers use of nl_langinfo if defined. +-# + #------------------------------------------------------------------------ + + AC_DEFUN([TEA_ENABLE_LANGINFO], [ +@@ -962,7 +971,6 @@ AC_DEFUN([TEA_ENABLE_LANGINFO], [ + # Defines the following var: + # + # system - System/platform/version identification code. +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_CONFIG_SYSTEM], [ +@@ -1031,21 +1039,20 @@ AC_DEFUN([TEA_CONFIG_SYSTEM], [ + # extensions. An empty string means we don't know how + # to use shared libraries on this platform. + # LIB_SUFFIX - Specifies everything that comes after the "libfoo" +-# in a static or shared library name, using the $VERSION variable ++# in a static or shared library name, using the $PACKAGE_VERSION variable + # to put the version in the right place. This is used + # by platforms that need non-standard library names. +-# Examples: ${VERSION}.so.1.1 on NetBSD, since it needs +-# to have a version after the .so, and ${VERSION}.a ++# Examples: ${PACKAGE_VERSION}.so.1.1 on NetBSD, since it needs ++# to have a version after the .so, and ${PACKAGE_VERSION}.a + # on AIX, since a shared library needs to have + # a .a extension whereas shared objects for loadable + # extensions have a .so extension. Defaults to +-# ${VERSION}${SHLIB_SUFFIX}. ++# ${PACKAGE_VERSION}${SHLIB_SUFFIX}. + # CFLAGS_DEBUG - + # Flags used when running the compiler in debug mode + # CFLAGS_OPTIMIZE - + # Flags used when running the compiler in optimize mode + # CFLAGS - Additional CFLAGS added as necessary (usually 64-bit) +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_CONFIG_CFLAGS], [ +@@ -1087,6 +1094,7 @@ AC_DEFUN([TEA_CONFIG_CFLAGS], [ + AC_DEFINE(MODULE_SCOPE, + [extern __attribute__((__visibility__("hidden")))], + [Compiler support for module scope symbols]) ++ AC_DEFINE(HAVE_HIDDEN, [1], [Compiler support for module scope symbols]) + ]) + + # Step 0.d: Disable -rpath support? +@@ -1135,18 +1143,17 @@ AC_DEFUN([TEA_CONFIG_CFLAGS], [ + ECHO_VERSION='`echo ${PACKAGE_VERSION}`' + TCL_LIB_VERSIONS_OK=ok + CFLAGS_DEBUG=-g +- CFLAGS_OPTIMIZE=-O + AS_IF([test "$GCC" = yes], [ +- # TEA specific: + CFLAGS_OPTIMIZE=-O2 + CFLAGS_WARNING="-Wall" +- ], [CFLAGS_WARNING=""]) +-dnl FIXME: Replace AC_CHECK_PROG with AC_CHECK_TOOL once cross compiling is fixed. +-dnl AC_CHECK_TOOL(AR, ar) +- AC_CHECK_PROG(AR, ar, ar) ++ ], [ ++ CFLAGS_OPTIMIZE=-O ++ CFLAGS_WARNING="" ++ ]) ++ AC_CHECK_TOOL(AR, ar) + STLIB_LD='${AR} cr' + LD_LIBRARY_PATH_VAR="LD_LIBRARY_PATH" +- AS_IF([test "x$SHLIB_VERSION" = x],[SHLIB_VERSION="1.0"]) ++ AS_IF([test "x$SHLIB_VERSION" = x],[SHLIB_VERSION=""],[SHLIB_VERSION=".$SHLIB_VERSION"]) + case $system in + # TEA specific: + windows) +@@ -1172,7 +1179,7 @@ dnl AC_CHECK_TOOL(AR, ar) + PATH64="${MSSDK}/Bin/Win64" + ;; + esac +- if test ! -d "${PATH64}" ; then ++ if test "$GCC" != "yes" -a ! -d "${PATH64}" ; then + AC_MSG_WARN([Could not find 64-bit $MACHINE SDK to enable 64bit mode]) + AC_MSG_WARN([Ensure latest Platform SDK is installed]) + do64bit="no" +@@ -1247,13 +1254,21 @@ dnl AC_CHECK_TOOL(AR, ar) + else + runtime=-MD + fi ++ case "x`echo \${VisualStudioVersion}`" in ++ x1[[4-9]]*) ++ lflags="${lflags} -nodefaultlib:libucrt.lib" ++ TEA_ADD_LIBS([ucrt.lib]) ++ ;; ++ *) ++ ;; ++ esac + + if test "$do64bit" != "no" ; then + # All this magic is necessary for the Win64 SDK RC1 - hobbs + CC="\"${PATH64}/cl.exe\"" + CFLAGS="${CFLAGS} -I\"${MSSDK}/Include\" -I\"${MSSDK}/Include/crt\" -I\"${MSSDK}/Include/crt/sys\"" + RC="\"${MSSDK}/bin/rc.exe\"" +- lflags="-nologo -MACHINE:${MACHINE} -LIBPATH:\"${MSSDK}/Lib/${MACHINE}\"" ++ lflags="${lflags} -nologo -MACHINE:${MACHINE} -LIBPATH:\"${MSSDK}/Lib/${MACHINE}\"" + LINKBIN="\"${PATH64}/link.exe\"" + CFLAGS_DEBUG="-nologo -Zi -Od -W3 ${runtime}d" + CFLAGS_OPTIMIZE="-nologo -O2 -W2 ${runtime}" +@@ -1283,13 +1298,13 @@ dnl AC_CHECK_TOOL(AR, ar) + CFLAGS_DEBUG="-nologo -Zi -Od" + CFLAGS_OPTIMIZE="-nologo -Ox" + lversion=`echo ${CEVERSION} | sed -e 's/\(.\)\(..\)/\1\.\2/'` +- lflags="-MACHINE:${ARCH} -LIBPATH:\"${CELIBPATH}\" -subsystem:windowsce,${lversion} -nologo" ++ lflags="${lflags} -MACHINE:${ARCH} -LIBPATH:\"${CELIBPATH}\" -subsystem:windowsce,${lversion} -nologo" + LINKBIN="\"${CEBINROOT}/link.exe\"" + AC_SUBST(CELIB_DIR) + else + RC="rc" +- lflags="-nologo" +- LINKBIN="link" ++ lflags="${lflags} -nologo" ++ LINKBIN="link" + CFLAGS_DEBUG="-nologo -Z7 -Od -W3 -WX ${runtime}d" + CFLAGS_OPTIMIZE="-nologo -O2 -W2 ${runtime}" + fi +@@ -1297,13 +1312,45 @@ dnl AC_CHECK_TOOL(AR, ar) + + if test "$GCC" = "yes"; then + # mingw gcc mode +- RC="windres" ++ AC_CHECK_TOOL(RC, windres) + CFLAGS_DEBUG="-g" + CFLAGS_OPTIMIZE="-O2 -fomit-frame-pointer" +- SHLIB_LD="$CC -shared" ++ SHLIB_LD='${CC} -shared' + UNSHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.a' ++ PRACTCL_UNSHARED_LIB_SUFFIX='.a' ++ + LDFLAGS_CONSOLE="-wl,--subsystem,console ${lflags}" + LDFLAGS_WINDOW="-wl,--subsystem,windows ${lflags}" ++ ++ AC_CACHE_CHECK(for cross-compile version of gcc, ++ ac_cv_cross, ++ AC_TRY_COMPILE([ ++ #ifdef _WIN32 ++ #error cross-compiler ++ #endif ++ ], [], ++ ac_cv_cross=yes, ++ ac_cv_cross=no) ++ ) ++ if test "$ac_cv_cross" = "yes"; then ++ case "$do64bit" in ++ amd64|x64|yes) ++ CC="x86_64-w64-mingw32-gcc" ++ LD="x86_64-w64-mingw32-ld" ++ AR="x86_64-w64-mingw32-ar" ++ RANLIB="x86_64-w64-mingw32-ranlib" ++ RC="x86_64-w64-mingw32-windres" ++ ;; ++ *) ++ CC="i686-w64-mingw32-gcc" ++ LD="i686-w64-mingw32-ld" ++ AR="i686-w64-mingw32-ar" ++ RANLIB="i686-w64-mingw32-ranlib" ++ RC="i686-w64-mingw32-windres" ++ ;; ++ esac ++ fi ++ + else + SHLIB_LD="${LINKBIN} -dll ${lflags}" + # link -lib only works when -lib is the first arg +@@ -1409,8 +1456,10 @@ dnl AC_CHECK_TOOL(AR, ar) + CYGWIN_*) + SHLIB_CFLAGS="" + SHLIB_LD='${CC} -shared' ++ SHLIB_LD_LIBS="${SHLIB_LD_LIBS} -Wl,--out-implib,\$[@].a" + SHLIB_SUFFIX=".dll" +- EXE_SUFFIX=".exe" ++ EXEEXT=".exe" ++ do64bit_ok=yes + CC_SEARCH_FLAGS="" + LD_SEARCH_FLAGS="" + ;; +@@ -1521,7 +1570,7 @@ dnl AC_CHECK_TOOL(AR, ar) + ]) + ]) + ;; +- Linux*) ++ Linux*|GNU*|NetBSD-Debian) + SHLIB_CFLAGS="-fPIC" + SHLIB_SUFFIX=".so" + +@@ -1554,17 +1603,6 @@ dnl AC_CHECK_TOOL(AR, ar) + # files in compat/*.c is being linked in. + + AS_IF([test x"${USE_COMPAT}" != x],[CFLAGS="$CFLAGS -fno-inline"]) +- +- ;; +- GNU*) +- SHLIB_CFLAGS="-fPIC" +- SHLIB_SUFFIX=".so" +- +- SHLIB_LD='${CC} -shared' +- LDFLAGS="$LDFLAGS -Wl,--export-dynamic" +- CC_SEARCH_FLAGS="" +- LD_SEARCH_FLAGS="" +- AS_IF([test "`uname -m`" = "alpha"], [CFLAGS="$CFLAGS -mieee"]) + ;; + Lynx*) + SHLIB_CFLAGS="-fPIC" +@@ -1577,35 +1615,51 @@ dnl AC_CHECK_TOOL(AR, ar) + LD_SEARCH_FLAGS='-Wl,-rpath,${LIB_RUNTIME_DIR}']) + ;; + OpenBSD-*) +- SHLIB_CFLAGS="-fPIC" +- SHLIB_LD='${CC} -shared ${SHLIB_CFLAGS}' +- SHLIB_SUFFIX=".so" +- AS_IF([test $doRpath = yes], [ +- CC_SEARCH_FLAGS='-Wl,-rpath,${LIB_RUNTIME_DIR}']) +- LD_SEARCH_FLAGS=${CC_SEARCH_FLAGS} +- SHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.so.${SHLIB_VERSION}' +- AC_CACHE_CHECK([for ELF], tcl_cv_ld_elf, [ +- AC_EGREP_CPP(yes, [ +-#ifdef __ELF__ +- yes +-#endif +- ], tcl_cv_ld_elf=yes, tcl_cv_ld_elf=no)]) +- AS_IF([test $tcl_cv_ld_elf = yes], [ +- LDFLAGS=-Wl,-export-dynamic +- ], [LDFLAGS=""]) ++ arch=`arch -s` ++ case "$arch" in ++ vax) ++ SHLIB_SUFFIX="" ++ SHARED_LIB_SUFFIX="" ++ LDFLAGS="" ++ ;; ++ *) ++ case "$arch" in ++ alpha|sparc64) ++ SHLIB_CFLAGS="-fPIC" ++ ;; ++ *) ++ SHLIB_CFLAGS="-fpic" ++ ;; ++ esac ++ SHLIB_LD='${CC} -shared ${SHLIB_CFLAGS}' ++ SHLIB_SUFFIX=".so" ++ AS_IF([test $doRpath = yes], [ ++ CC_SEARCH_FLAGS='-Wl,-rpath,${LIB_RUNTIME_DIR}']) ++ LD_SEARCH_FLAGS=${CC_SEARCH_FLAGS} ++ SHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.so${SHLIB_VERSION}' ++ LDFLAGS="-Wl,-export-dynamic" ++ ;; ++ esac ++ case "$arch" in ++ vax) ++ CFLAGS_OPTIMIZE="-O1" ++ ;; ++ *) ++ CFLAGS_OPTIMIZE="-O2" ++ ;; ++ esac + AS_IF([test "${TCL_THREADS}" = "1"], [ +- # OpenBSD builds and links with -pthread, never -lpthread. ++ # On OpenBSD: Compile with -pthread ++ # Don't link with -lpthread + LIBS=`echo $LIBS | sed s/-lpthread//` + CFLAGS="$CFLAGS -pthread" +- SHLIB_CFLAGS="$SHLIB_CFLAGS -pthread" + ]) + # OpenBSD doesn't do version numbers with dots. + UNSHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.a' + TCL_LIB_VERSIONS_OK=nodots + ;; +- NetBSD-*|FreeBSD-[[3-4]].*) +- # FreeBSD 3.* and greater have ELF. +- # NetBSD 2.* has ELF and can use 'cc -shared' to build shared libs ++ NetBSD-*) ++ # NetBSD has ELF and can use 'cc -shared' to build shared libs + SHLIB_CFLAGS="-fPIC" + SHLIB_LD='${CC} -shared ${SHLIB_CFLAGS}' + SHLIB_SUFFIX=".so" +@@ -1619,35 +1673,31 @@ dnl AC_CHECK_TOOL(AR, ar) + CFLAGS="$CFLAGS -pthread" + LDFLAGS="$LDFLAGS -pthread" + ]) +- case $system in +- FreeBSD-3.*) +- # FreeBSD-3 doesn't handle version numbers with dots. +- UNSHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.a' +- SHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.so' +- TCL_LIB_VERSIONS_OK=nodots +- ;; +- esac + ;; + FreeBSD-*) + # This configuration from FreeBSD Ports. + SHLIB_CFLAGS="-fPIC" + SHLIB_LD="${CC} -shared" +- TCL_SHLIB_LD_EXTRAS="-soname \$[@]" ++ SHLIB_LD_LIBS="${SHLIB_LD_LIBS} -Wl,-soname,\$[@]" + SHLIB_SUFFIX=".so" + LDFLAGS="" + AS_IF([test $doRpath = yes], [ + CC_SEARCH_FLAGS='-Wl,-rpath,${LIB_RUNTIME_DIR}' +- LD_SEARCH_FLAGS='-rpath ${LIB_RUNTIME_DIR}']) ++ LD_SEARCH_FLAGS='-Wl,-rpath,${LIB_RUNTIME_DIR}']) + AS_IF([test "${TCL_THREADS}" = "1"], [ + # The -pthread needs to go in the LDFLAGS, not LIBS + LIBS=`echo $LIBS | sed s/-pthread//` + CFLAGS="$CFLAGS $PTHREAD_CFLAGS" + LDFLAGS="$LDFLAGS $PTHREAD_LIBS"]) +- # Version numbers are dot-stripped by system policy. +- TCL_TRIM_DOTS=`echo ${VERSION} | tr -d .` +- UNSHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.a' +- SHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}\$\{DBGX\}.so.1' +- TCL_LIB_VERSIONS_OK=nodots ++ case $system in ++ FreeBSD-3.*) ++ # Version numbers are dot-stripped by system policy. ++ TCL_TRIM_DOTS=`echo ${PACKAGE_VERSION} | tr -d .` ++ UNSHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}.a' ++ SHARED_LIB_SUFFIX='${TCL_TRIM_DOTS}\$\{DBGX\}.so.1' ++ TCL_LIB_VERSIONS_OK=nodots ++ ;; ++ esac + ;; + Darwin-*) + CFLAGS_OPTIMIZE="-Os" +@@ -1706,7 +1756,7 @@ dnl AC_CHECK_TOOL(AR, ar) + AS_IF([test $tcl_cv_ld_single_module = yes], [ + SHLIB_LD="${SHLIB_LD} -Wl,-single_module" + ]) +- # TEA specific: link shlib with current and compatiblity version flags ++ # TEA specific: link shlib with current and compatibility version flags + vers=`echo ${PACKAGE_VERSION} | sed -e 's/^\([[0-9]]\{1,5\}\)\(\(\.[[0-9]]\{1,3\}\)\{0,2\}\).*$/\1\2/p' -e d` + SHLIB_LD="${SHLIB_LD} -current_version ${vers:-0} -compatibility_version ${vers:-0}" + SHLIB_SUFFIX=".dylib" +@@ -1818,8 +1868,8 @@ dnl AC_CHECK_TOOL(AR, ar) + SHLIB_CFLAGS="-fPIC -melf" + LDFLAGS="$LDFLAGS -melf -Wl,-Bexport" + ], [ +- SHLIB_CFLAGS="-Kpic -belf" +- LDFLAGS="$LDFLAGS -belf -Wl,-Bexport" ++ SHLIB_CFLAGS="-Kpic -belf" ++ LDFLAGS="$LDFLAGS -belf -Wl,-Bexport" + ]) + SHLIB_LD="ld -G" + SHLIB_LD_LIBS="" +@@ -1942,6 +1992,24 @@ dnl AC_CHECK_TOOL(AR, ar) + LD_SEARCH_FLAGS='-R ${LIB_RUNTIME_DIR}' + ]) + ;; ++ UNIX_SV* | UnixWare-5*) ++ SHLIB_CFLAGS="-KPIC" ++ SHLIB_LD='${CC} -G' ++ SHLIB_LD_LIBS="" ++ SHLIB_SUFFIX=".so" ++ # Some UNIX_SV* systems (unixware 1.1.2 for example) have linkers ++ # that don't grok the -Bexport option. Test that it does. ++ AC_CACHE_CHECK([for ld accepts -Bexport flag], tcl_cv_ld_Bexport, [ ++ hold_ldflags=$LDFLAGS ++ LDFLAGS="$LDFLAGS -Wl,-Bexport" ++ AC_TRY_LINK(, [int i;], tcl_cv_ld_Bexport=yes, tcl_cv_ld_Bexport=no) ++ LDFLAGS=$hold_ldflags]) ++ AS_IF([test $tcl_cv_ld_Bexport = yes], [ ++ LDFLAGS="$LDFLAGS -Wl,-Bexport" ++ ]) ++ CC_SEARCH_FLAGS="" ++ LD_SEARCH_FLAGS="" ++ ;; + esac + + AS_IF([test "$do64bit" = yes -a "$do64bit_ok" = no], [ +@@ -1966,7 +2034,7 @@ dnl # preprocessing tests use only CPPFL + case $system in + AIX-*) ;; + BSD/OS*) ;; +- CYGWIN_*) ;; ++ CYGWIN_*|MINGW32_*) ;; + IRIX*) ;; + NetBSD-*|FreeBSD-*|OpenBSD-*) ;; + Darwin-*) ;; +@@ -1978,15 +2046,111 @@ dnl # preprocessing tests use only CPPFL + AS_IF([test "$tcl_cv_cc_visibility_hidden" != yes], [ + AC_DEFINE(MODULE_SCOPE, [extern], + [No Compiler support for module scope symbols]) +- AC_DEFINE(NO_VIZ, [], [No visibility hidden passed to zlib?]) + ]) + + AS_IF([test "$SHARED_LIB_SUFFIX" = ""], [ +- # TEA specific: use PACKAGE_VERSION instead of VERSION +- SHARED_LIB_SUFFIX='${PACKAGE_VERSION}${SHLIB_SUFFIX}']) ++ # TEA specific: use PACKAGE_VERSION instead of VERSION ++ SHARED_LIB_SUFFIX='${PACKAGE_VERSION}${SHLIB_SUFFIX}' ++ ]) + AS_IF([test "$UNSHARED_LIB_SUFFIX" = ""], [ +- # TEA specific: use PACKAGE_VERSION instead of VERSION +- UNSHARED_LIB_SUFFIX='${PACKAGE_VERSION}.a']) ++ # TEA specific: use PACKAGE_VERSION instead of VERSION ++ UNSHARED_LIB_SUFFIX='${PACKAGE_VERSION}.a' ++ ]) ++ ++ if test "${GCC}" = "yes" -a ${SHLIB_SUFFIX} = ".dll"; then ++ AC_CACHE_CHECK(for SEH support in compiler, ++ tcl_cv_seh, ++ AC_TRY_RUN([ ++#define WIN32_LEAN_AND_MEAN ++#include ++#undef WIN32_LEAN_AND_MEAN ++ ++ int main(int argc, char** argv) { ++ int a, b = 0; ++ __try { ++ a = 666 / b; ++ } ++ __except (EXCEPTION_EXECUTE_HANDLER) { ++ return 0; ++ } ++ return 1; ++ } ++ ], ++ tcl_cv_seh=yes, ++ tcl_cv_seh=no, ++ tcl_cv_seh=no) ++ ) ++ if test "$tcl_cv_seh" = "no" ; then ++ AC_DEFINE(HAVE_NO_SEH, 1, ++ [Defined when mingw does not support SEH]) ++ fi ++ ++ # ++ # Check to see if the excpt.h include file provided contains the ++ # definition for EXCEPTION_DISPOSITION; if not, which is the case ++ # with Cygwin's version as of 2002-04-10, define it to be int, ++ # sufficient for getting the current code to work. ++ # ++ AC_CACHE_CHECK(for EXCEPTION_DISPOSITION support in include files, ++ tcl_cv_eh_disposition, ++ AC_TRY_COMPILE([ ++# define WIN32_LEAN_AND_MEAN ++# include ++# undef WIN32_LEAN_AND_MEAN ++ ],[ ++ EXCEPTION_DISPOSITION x; ++ ], ++ tcl_cv_eh_disposition=yes, ++ tcl_cv_eh_disposition=no) ++ ) ++ if test "$tcl_cv_eh_disposition" = "no" ; then ++ AC_DEFINE(EXCEPTION_DISPOSITION, int, ++ [Defined when cygwin/mingw does not support EXCEPTION DISPOSITION]) ++ fi ++ ++ # Check to see if winnt.h defines CHAR, SHORT, and LONG ++ # even if VOID has already been #defined. The win32api ++ # used by mingw and cygwin is known to do this. ++ ++ AC_CACHE_CHECK(for winnt.h that ignores VOID define, ++ tcl_cv_winnt_ignore_void, ++ AC_TRY_COMPILE([ ++#define VOID void ++#define WIN32_LEAN_AND_MEAN ++#include ++#undef WIN32_LEAN_AND_MEAN ++ ], [ ++ CHAR c; ++ SHORT s; ++ LONG l; ++ ], ++ tcl_cv_winnt_ignore_void=yes, ++ tcl_cv_winnt_ignore_void=no) ++ ) ++ if test "$tcl_cv_winnt_ignore_void" = "yes" ; then ++ AC_DEFINE(HAVE_WINNT_IGNORE_VOID, 1, ++ [Defined when cygwin/mingw ignores VOID define in winnt.h]) ++ fi ++ fi ++ ++ # See if the compiler supports casting to a union type. ++ # This is used to stop gcc from printing a compiler ++ # warning when initializing a union member. ++ ++ AC_CACHE_CHECK(for cast to union support, ++ tcl_cv_cast_to_union, ++ AC_TRY_COMPILE([], ++ [ ++ union foo { int i; double d; }; ++ union foo f = (union foo) (int) 0; ++ ], ++ tcl_cv_cast_to_union=yes, ++ tcl_cv_cast_to_union=no) ++ ) ++ if test "$tcl_cv_cast_to_union" = "yes"; then ++ AC_DEFINE(HAVE_CAST_TO_UNION, 1, ++ [Defined when compiler supports casting to union type.]) ++ fi + + AC_SUBST(CFLAGS_DEBUG) + AC_SUBST(CFLAGS_OPTIMIZE) +@@ -1994,6 +2158,7 @@ dnl # preprocessing tests use only CPPFL + + AC_SUBST(STLIB_LD) + AC_SUBST(SHLIB_LD) ++ AC_SUBST(SHLIB_SUFFIX) + + AC_SUBST(SHLIB_LD_LIBS) + AC_SUBST(SHLIB_CFLAGS) +@@ -2025,7 +2190,6 @@ dnl # preprocessing tests use only CPPFL + # USE_TERMIOS + # USE_TERMIO + # USE_SGTTY +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_SERIAL_PORT], [ +@@ -2237,7 +2401,6 @@ closedir(d); + # XINCLUDES + # XLIBSW + # PKG_LIBS (appends to) +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_PATH_X], [ +@@ -2251,9 +2414,9 @@ AC_DEFUN([TEA_PATH_UNIX_X], [ + not_really_there="" + if test "$no_x" = ""; then + if test "$x_includes" = ""; then +- AC_TRY_CPP([#include ], , not_really_there="yes") ++ AC_TRY_CPP([#include ], , not_really_there="yes") + else +- if test ! -r $x_includes/X11/Intrinsic.h; then ++ if test ! -r $x_includes/X11/Xlib.h; then + not_really_there="yes" + fi + fi +@@ -2261,11 +2424,11 @@ AC_DEFUN([TEA_PATH_UNIX_X], [ + if test "$no_x" = "yes" -o "$not_really_there" = "yes"; then + AC_MSG_CHECKING([for X11 header files]) + found_xincludes="no" +- AC_TRY_CPP([#include ], found_xincludes="yes", found_xincludes="no") ++ AC_TRY_CPP([#include ], found_xincludes="yes", found_xincludes="no") + if test "$found_xincludes" = "no"; then + dirs="/usr/unsupported/include /usr/local/include /usr/X386/include /usr/X11R6/include /usr/X11R5/include /usr/include/X11R5 /usr/include/X11R4 /usr/openwin/include /usr/X11/include /usr/sww/include" + for i in $dirs ; do +- if test -r $i/X11/Intrinsic.h; then ++ if test -r $i/X11/Xlib.h; then + AC_MSG_RESULT([$i]) + XINCLUDES=" -I$i" + found_xincludes="yes" +@@ -2333,7 +2496,6 @@ AC_DEFUN([TEA_PATH_UNIX_X], [ + # HAVE_SYS_FILIO_H + # USE_FIONBIO + # O_NONBLOCK +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_BLOCKING_STYLE], [ +@@ -2368,7 +2530,6 @@ AC_DEFUN([TEA_BLOCKING_STYLE], [ + # HAVE_TM_GMTOFF + # HAVE_TM_TZADJ + # HAVE_TIMEZONE_VAR +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_TIME_HANDLER], [ +@@ -2437,7 +2598,6 @@ AC_DEFUN([TEA_TIME_HANDLER], [ + # + # Might defines some of the following vars: + # strtod (=fixstrtod) +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_BUGGY_STRTOD], [ +@@ -2488,7 +2648,7 @@ AC_DEFUN([TEA_BUGGY_STRTOD], [ + # + # Results: + # +-# Subst's the following var: ++# Substitutes the following vars: + # TCL_LIBS + # MATH_LIBS + # +@@ -2497,7 +2657,6 @@ AC_DEFUN([TEA_BUGGY_STRTOD], [ + # + # Might define the following vars: + # HAVE_NET_ERRNO_H +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_TCL_LINK_LIBS], [ +@@ -2575,7 +2734,6 @@ AC_DEFUN([TEA_TCL_LINK_LIBS], [ + # _ISOC99_SOURCE + # _LARGEFILE64_SOURCE + # _LARGEFILE_SOURCE64 +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_TCL_EARLY_FLAG],[ +@@ -2623,7 +2781,6 @@ AC_DEFUN([TEA_TCL_EARLY_FLAGS],[ + # HAVE_STRUCT_DIRENT64 + # HAVE_STRUCT_STAT64 + # HAVE_TYPE_OFF64_T +-# + #-------------------------------------------------------------------- + + AC_DEFUN([TEA_TCL_64BIT_FLAGS], [ +@@ -2655,7 +2812,7 @@ AC_DEFUN([TEA_TCL_64BIT_FLAGS], [ + # Now check for auxiliary declarations + AC_CACHE_CHECK([for struct dirent64], tcl_cv_struct_dirent64,[ + AC_TRY_COMPILE([#include +-#include ],[struct dirent64 p;], ++#include ],[struct dirent64 p;], + tcl_cv_struct_dirent64=yes,tcl_cv_struct_dirent64=no)]) + if test "x${tcl_cv_struct_dirent64}" = "xyes" ; then + AC_DEFINE(HAVE_STRUCT_DIRENT64, 1, [Is 'struct dirent64' in ?]) +@@ -2725,12 +2882,12 @@ AC_DEFUN([TEA_TCL_64BIT_FLAGS], [ + AC_DEFUN([TEA_INIT], [ + # TEA extensions pass this us the version of TEA they think they + # are compatible with. +- TEA_VERSION="3.9" ++ TEA_VERSION="3.10" + + AC_MSG_CHECKING([for correct TEA configuration]) + if test x"${PACKAGE_NAME}" = x ; then + AC_MSG_ERROR([ +-The PACKAGE_NAME variable must be defined by your TEA configure.in]) ++The PACKAGE_NAME variable must be defined by your TEA configure.ac]) + fi + if test x"$1" = x ; then + AC_MSG_ERROR([ +@@ -2740,21 +2897,36 @@ TEA version not specified.]) + else + AC_MSG_RESULT([ok (TEA ${TEA_VERSION})]) + fi ++ ++ # If the user did not set CFLAGS, set it now to keep macros ++ # like AC_PROG_CC and AC_TRY_COMPILE from adding "-g -O2". ++ if test "${CFLAGS+set}" != "set" ; then ++ CFLAGS="" ++ fi ++ + case "`uname -s`" in + *win32*|*WIN32*|*MINGW32_*) +- AC_CHECK_PROG(CYGPATH, cygpath, cygpath -w, echo) ++ AC_CHECK_PROG(CYGPATH, cygpath, cygpath -m, echo) + EXEEXT=".exe" + TEA_PLATFORM="windows" + ;; + *CYGWIN_*) +- CYGPATH=echo + EXEEXT=".exe" +- # TEA_PLATFORM is determined later in LOAD_TCLCONFIG ++ # CYGPATH and TEA_PLATFORM are determined later in LOAD_TCLCONFIG + ;; + *) + CYGPATH=echo +- EXEEXT="" +- TEA_PLATFORM="unix" ++ # Maybe we are cross-compiling.... ++ case ${host_alias} in ++ *mingw32*) ++ EXEEXT=".exe" ++ TEA_PLATFORM="windows" ++ ;; ++ *) ++ EXEEXT="" ++ TEA_PLATFORM="unix" ++ ;; ++ esac + ;; + esac + +@@ -3061,7 +3233,7 @@ AC_DEFUN([TEA_PREFIX], [ + # TEA_SETUP_COMPILER_CC -- + # + # Do compiler checks the way we want. This is just a replacement +-# for AC_PROG_CC in TEA configure.in files to make them cleaner. ++# for AC_PROG_CC in TEA configure.ac files to make them cleaner. + # + # Arguments: + # none +@@ -3074,16 +3246,22 @@ AC_DEFUN([TEA_SETUP_COMPILER_CC], [ + # Don't put any macros that use the compiler (e.g. AC_TRY_COMPILE) + # in this macro, they need to go into TEA_SETUP_COMPILER instead. + +- # If the user did not set CFLAGS, set it now to keep +- # the AC_PROG_CC macro from adding "-g -O2". +- if test "${CFLAGS+set}" != "set" ; then +- CFLAGS="" +- fi +- + AC_PROG_CC + AC_PROG_CPP + +- AC_PROG_INSTALL ++ INSTALL='$(SHELL) $(srcdir)/tclconfig/install-sh -c' ++ INSTALL_DATA_DIR='${INSTALL} -d -m 755' ++ INSTALL_DATA='${INSTALL} -m 644' ++ INSTALL_PROGRAM='${INSTALL}' ++ INSTALL_SCRIPT='${INSTALL}' ++ INSTALL_LIBRARY='${INSTALL_DATA}' ++ ++ AC_SUBST(INSTALL) ++ AC_SUBST(INSTALL_DATA_DIR) ++ AC_SUBST(INSTALL_DATA) ++ AC_SUBST(INSTALL_PROGRAM) ++ AC_SUBST(INSTALL_SCRIPT) ++ AC_SUBST(INSTALL_LIBRARY) + + #-------------------------------------------------------------------- + # Checks to see if the make program sets the $MAKE variable. +@@ -3095,7 +3273,7 @@ AC_DEFUN([TEA_SETUP_COMPILER_CC], [ + # Find ranlib + #-------------------------------------------------------------------- + +- AC_PROG_RANLIB ++ AC_CHECK_TOOL(RANLIB, ranlib) + + #-------------------------------------------------------------------- + # Determines the correct binary file extension (.o, .obj, .exe etc.) +@@ -3176,92 +3354,128 @@ AC_DEFUN([TEA_SETUP_COMPILER], [ + # MAKE_STUB_LIB Makefile rule for building a stub library + # VC_MANIFEST_EMBED_DLL Makefile rule for embedded VC manifest in DLL + # VC_MANIFEST_EMBED_EXE Makefile rule for embedded VC manifest in EXE ++# ++# PRACTCL_TOOLSET What toolset is in use (gcc or msvc) ++# PRACTCL_SHARED_LIB Template rule for building a shared library ++# PRACTCL_STATIC_LIB Template rule for building a static library ++# PRACTCL_STUB_LIB Template rule for building a stub library ++# PRACTCL_VC_MANIFEST_EMBED_DLL Template rule for embedded VC manifest in DLL ++# PRACTCL_VC_MANIFEST_EMBED_EXE Template rule for embedded VC manifest in EXE ++# PRACTCL_NAME_LIBRARY Template rule for naming libraries ++# + #------------------------------------------------------------------------ + + AC_DEFUN([TEA_MAKE_LIB], [ +- if test "${TEA_PLATFORM}" = "windows" -a "$GCC" != "yes"; then +- MAKE_STATIC_LIB="\${STLIB_LD} -out:\[$]@ \$(PKG_OBJECTS)" +- MAKE_SHARED_LIB="\${SHLIB_LD} \${SHLIB_LD_LIBS} \${LDFLAGS_DEFAULT} -out:\[$]@ \$(PKG_OBJECTS)" +- AC_EGREP_CPP([manifest needed], [ ++ PRACTCL_TOOLSET="gcc" ++ PRACTCL_VC_MANIFEST_EMBED_DLL=: ++ PRACTCL_VC_MANIFEST_EMBED_EXE=: ++ if test "${TEA_PLATFORM}" = "windows" -a "$GCC" != "yes"; then *** DIFF OUTPUT TRUNCATED AT 1000 LINES ***