# -*- 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 . # # 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) $contents AC_OUTPUT(confdummy)" close $hand if [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 $hand return 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_output set 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_output set 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 $testname return 0 } if ![autoconf_load_plus $testname] { autoconf_remove $testname return 0 } if ![autoconf_remove $testname] { return 0 } pass "$testname" return 1 }