# -*- TCL -*-# Auxiliary procedures for autoconf tests.# Copyright (C) 1994 Free Software Foundation, Inc.# This program is free software; you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation; either version 2 of the License, or# (at your option) any later version.## This program is distributed in the hope that it will be useful,# but WITHOUT ANY WARRANTY; without even the implied warranty of# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the# GNU General Public License for more details.## You should have received a copy of the GNU General Public License# along with this program; if not, write to the Free Software# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.# Written by David MacKenzie <djm@gnu.ai.mit.edu>.## Create a configure.in from a string.# CONFIG.in is the file to create containing CONTENTS plus boilerplate.# Return 1 if successful, 0 if an error occurs.proc autoconf_create {config contents} {if [catch {open "$config.in" "w"} hand] {error "$config, cannot create $config.in"return 0}puts $hand "AC_INIT(confdummy.in)$contentsAC_OUTPUT(confdummy)"close $handif [catch {open "confdummy.in" "w"} hand] {error "$config, cannot create confdummy.in"return 0}puts $hand "# This is a dummy file for testing.srcdir = @srcdir@# Please ignore this file."close $handreturn 1}# Compile a configure.in into a configure# and call error if there's any output (undefined macros, can't# find library files, etc.).proc autoconf_start_plus {configout} {global comp_outputset status [autoconf_start $configout]if {$status==0} {return 0}# Examine $comp_output.if [string match "*is obsolete*" "$comp_output"] then {return 1}if [string match "*allow cross*" "$comp_output"] then {return 1}if ![string match "" "$comp_output"] then {fail "$configout, problem with running autoconf"return 0}return 1}# Execute a configure script and check the output# against what it's supposed to be.# Return 1 if successful so far, 0 if failure already.proc autoconf_load_plus {args} {global exec_outputset status [autoconf_load $args]if {$status==0} {return 0}if [string match "*:*" "$exec_output"] then {fail "$args, problem with executing"return 0}return 1}# Remove generated configuration files for test CONFIG.# Return 1 if successful, 0 if not.proc autoconf_remove {config} {if [catch "exec rm -f $config $config.in [glob -nocomplain conftest* confdummy*] config.status config.cache config.log"] {warning "$config output files, cannot remove"return 0}return 1}# The standard autoconf test: create, compile, run, and remove# a simple configure script to test a single macro.# TESTNAME is the name of the macro being tested.# CONTENTS is the body of the configure script to create and test.proc autoconf_test {testname contents} {if ![autoconf_remove $testname] {return 0}if ![autoconf_create $testname "$contents"] {return 0}if ![autoconf_start_plus $testname] {autoconf_remove $testnamereturn 0}if ![autoconf_load_plus $testname] {autoconf_remove $testnamereturn 0}if ![autoconf_remove $testname] {return 0}pass "$testname"return 1}