1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Add a mechanism for using autoconf to detect the quirks of Unix systems

rather than relying on the user to edit the Makefile.  Makefile.gtk
still works as well as it ever did, but now we get a Makefile.in alongside
it.  mkunxarc.sh now relies on autoconf and friends to build the configure
script for the Unix source distribution.

[originally from svn r5673]
This commit is contained in:
Ben Harris 2005-04-25 15:55:06 +00:00
parent 38b266727a
commit 0227bfdbc7
6 changed files with 118 additions and 5 deletions

11
README
View File

@ -42,11 +42,14 @@ For building on Windows:
For building on Unix: For building on Unix:
- unix/Makefile.gtk is for Unix and GTK. If you don't have GTK, you - unix/configure is for Unix and GTK. If you don't have GTK, you
should still be able to build the command-line utilities (PSCP, should still be able to build the command-line utilities (PSCP,
PSFTP, Plink, PuTTYgen) using this makefile. The makefile expects PSFTP, Plink, PuTTYgen) using this script. To use it, change
you to change into the `unix' subdirectory, then run `make -f into the `unix' subdirectory, run `./configure' and then `make'.
Makefile.gtk'. Note that Unix PuTTY has mostly only been tested
- unix/Makefile.gtk is for non-autoconfigured builds. This makefile
expects you to change into the `unix' subdirectory, then run `make
-f Makefile.gtk'. Note that Unix PuTTY has mostly only been tested
on Linux so far; portability problems such as BSD-style ptys or on Linux so far; portability problems such as BSD-style ptys or
different header file requirements are expected. different header file requirements are expected.

1
Recipe
View File

@ -18,6 +18,7 @@
!makefile borland windows/Makefile.bor !makefile borland windows/Makefile.bor
!makefile lcc windows/Makefile.lcc !makefile lcc windows/Makefile.lcc
!makefile gtk unix/Makefile.gtk !makefile gtk unix/Makefile.gtk
!makefile ac unix/Makefile.in
!makefile mpw mac/Makefile.mpw !makefile mpw mac/Makefile.mpw
!makefile osx macosx/Makefile !makefile osx macosx/Makefile
# Source directories. # Source directories.

View File

@ -212,7 +212,7 @@ sub mfval($) {
# Returns true if the argument is a known makefile type. Otherwise, # Returns true if the argument is a known makefile type. Otherwise,
# prints a warning and returns false; # prints a warning and returns false;
if (grep { $type eq $_ } if (grep { $type eq $_ }
("vc","vcproj","cygwin","borland","lcc","gtk","mpw","osx")) { ("vc","vcproj","cygwin","borland","lcc","gtk","ac","mpw","osx")) {
return 1; return 1;
} }
warn "$.:unknown makefile type '$type'\n"; warn "$.:unknown makefile type '$type'\n";
@ -945,6 +945,64 @@ if (defined $makefiles{'gtk'}) {
select STDOUT; close OUT; select STDOUT; close OUT;
} }
if (defined $makefiles{'ac'}) {
$dirpfx = &dirpfx($makefiles{'ac'}, "/");
##-- Unix/autoconf makefile
open OUT, ">$makefiles{'ac'}"; select OUT;
print
"# Makefile.in for $project_name under Unix with Autoconf.\n".
"#\n# This file was created by `mkfiles.pl' from the `Recipe' file.\n".
"# DO NOT EDIT THIS FILE DIRECTLY; edit Recipe or mkfiles.pl instead.\n";
# gcc command line option is -D not /D
($_ = $help) =~ s/=\/D/=-D/gs;
print $_;
print
"\n".
"CC = \@CC\@\n".
"\n".
&splitline("CFLAGS = \@CFLAGS\@ \@CPPFLAGS\@ \@DEFS\@ \@GTK_CFLAGS\@ " .
(join " ", map {"-I$dirpfx$_"} @srcdirs))."\n".
"XLDFLAGS = \@LDFLAGS\@ \@LIBS\@ \@GTK_LIBS\@\n".
"ULDFLAGS = \@LDFLAGS\@ \@LIBS\@\n".
"INSTALL=\@INSTALL\@\n",
"INSTALL_PROGRAM=\$(INSTALL)\n",
"INSTALL_DATA=\$(INSTALL)\n",
"prefix=\@prefix\@\n",
"exec_prefix=\@exec_prefix\@\n",
"bindir=\@bindir\@\n",
"mandir=\@mandir\@\n",
"man1dir=\$(mandir)/man1\n",
"\n".
$makefile_extra{'gtk'}->{'vars'} .
"\n".
".SUFFIXES:\n".
"\n".
"\n".
"all: \@all_targets\@\n".
&splitline("all-cli:" . join "", map { " $_" } &progrealnames("U"))."\n".
&splitline("all-gtk:" . join "", map { " $_" } &progrealnames("X"))."\n";
print "\n";
foreach $p (&prognames("X:U")) {
($prog, $type) = split ",", $p;
$objstr = &objects($p, "X.o", undef, undef);
print &splitline($prog . ": " . $objstr), "\n";
$libstr = &objects($p, undef, undef, "-lX");
print &splitline("\t\$(CC)" . $mw . " \$(${type}LDFLAGS) -o \$@ " .
$objstr . " $libstr", 69), "\n\n";
}
foreach $d (&deps("X.o", undef, $dirpfx, "/", "gtk")) {
print &splitline(sprintf("%s: %s", $d->{obj}, join " ", @{$d->{deps}})),
"\n";
print &splitline("\t\$(CC) \$(COMPAT) \$(XFLAGS) \$(CFLAGS) -c $d->{deps}->[0]\n");
}
print "\n";
print $makefile_extra{'gtk'}->{'end'};
print "\nclean:\n".
"\trm -f *.o". (join "", map { " $_" } &progrealnames("X:U")) . "\n";
select STDOUT; close OUT;
}
if (defined $makefiles{'mpw'}) { if (defined $makefiles{'mpw'}) {
##-- MPW Makefile ##-- MPW Makefile
open OUT, ">$makefiles{'mpw'}"; select OUT; open OUT, ">$makefiles{'mpw'}"; select OUT;

View File

@ -28,6 +28,9 @@ esac
perl mkfiles.pl perl mkfiles.pl
(cd doc && make -s ${docver:+"$docver"}) (cd doc && make -s ${docver:+"$docver"})
# Track down automake's copy of install-sh
cp `aclocal --print-ac-dir | sed 's/aclocal$/automake/'`/install-sh unix/.
(cd unix && autoreconf && rm -rf aclocal.m4 autom4te.cache)
relver=`cat LATEST.VER` relver=`cat LATEST.VER`
arcname="putty$arcsuffix" arcname="putty$arcsuffix"

44
unix/configure.ac Normal file
View File

@ -0,0 +1,44 @@
# To compile this into a configure script, you need:
# * Autoconf 2.50 or newer
# * Gtk (for $prefix/share/aclocal/gtk.m4)
# * Automake (for aclocal)
# If you've got them, running "autoreconf" should work.
AC_INIT
AC_CONFIG_FILES([Makefile])
AC_CONFIG_HEADERS([uxconfig.h:uxconfig.in])
AC_PROG_INSTALL
AC_PROG_CC
if test "X$GCC" = Xyes; then
CFLAGS="$CFLAGS -Wall -Werror"
fi
AM_PATH_GTK([1.2.0], [all_targets="all-cli all-gtk"], [all_targets="all-cli"])
AC_SUBST([all_targets])
AC_SEARCH_LIBS([socket], [xnet])
AC_CHECK_FUNCS([getaddrinfo ptsname pututline setresuid strsignal])
AC_OUTPUT
AH_BOTTOM([
/* Convert autoconf definitions to ones that PuTTY wants. */
#ifndef HAVE_GETADDRINFO
# define NO_IPV6
#endif
#ifndef HAVE_SETRESUID
# define HAVE_NO_SETRESUID
#endif
#ifndef HAVE_STRSIGNAL
# define HAVE_NO_STRSIGNAL
#endif
#ifndef HAVE_PUTUTLINE
# define OMIT_UTMP
#endif
#ifndef HAVE_PTSNAME
# define BSD_PTYS
#endif
])

View File

@ -1,6 +1,10 @@
#ifndef PUTTY_UNIX_H #ifndef PUTTY_UNIX_H
#define PUTTY_UNIX_H #define PUTTY_UNIX_H
#ifdef HAVE_CONFIG_H
# include "uxconfig.h" /* Space to hide it from mkfiles.pl */
#endif
#include <stdio.h> /* for FILENAME_MAX */ #include <stdio.h> /* for FILENAME_MAX */
#include "charset.h" #include "charset.h"