1999-04-21 01:11:55 +00:00
|
|
|
#! /usr/bin/env perl
|
|
|
|
#
|
2004-04-18 14:21:17 +00:00
|
|
|
# ***** BEGIN LICENSE BLOCK *****
|
|
|
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
1999-04-21 01:11:55 +00:00
|
|
|
#
|
2004-04-18 14:21:17 +00:00
|
|
|
# The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
# 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
# the License. You may obtain a copy of the License at
|
|
|
|
# http://www.mozilla.org/MPL/
|
1999-04-21 01:11:55 +00:00
|
|
|
#
|
2004-04-18 14:21:17 +00:00
|
|
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
# for the specific language governing rights and limitations under the
|
|
|
|
# License.
|
1999-11-06 03:40:37 +00:00
|
|
|
#
|
2004-04-18 14:21:17 +00:00
|
|
|
# The Original Code is mozilla.org code.
|
1999-04-21 01:11:55 +00:00
|
|
|
#
|
2004-04-18 14:21:17 +00:00
|
|
|
# The Initial Developer of the Original Code is
|
|
|
|
# Netscape Communications Corporation.
|
|
|
|
# Portions created by the Initial Developer are Copyright (C) 1999
|
|
|
|
# the Initial Developer. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Contributor(s):
|
|
|
|
#
|
|
|
|
# Alternatively, the contents of this file may be used under the terms of
|
|
|
|
# either of the GNU General Public License Version 2 or later (the "GPL"),
|
|
|
|
# or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
# of those above. If you wish to allow use of your version of this file only
|
|
|
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
# use your version of this file under the terms of the MPL, indicate your
|
|
|
|
# decision by deleting the provisions above and replace them with the notice
|
|
|
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
# the provisions above, a recipient may use your version of this file under
|
|
|
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
#
|
|
|
|
# ***** END LICENSE BLOCK *****
|
1999-04-21 01:11:55 +00:00
|
|
|
|
|
|
|
# acoutput-fast.pl - Quickly create makefiles that are in a common format.
|
|
|
|
#
|
|
|
|
# Most of the makefiles in mozilla only refer to two configure variables:
|
|
|
|
# @srcdir@
|
|
|
|
# @top_srcdir@
|
|
|
|
# However, configure does not know any better and it runs sed on each file
|
|
|
|
# with over 150 replacement rules (slow as molasses).
|
|
|
|
#
|
|
|
|
# This script takes a list of makefiles as input. For example,
|
|
|
|
#
|
|
|
|
# echo $MAKEFILES | acoutput-fast.pl
|
|
|
|
#
|
|
|
|
# The script creates each Makefile that only references @srcdir@ and
|
|
|
|
# @top_srcdir@. For other files, it lists them in a shell command that is
|
|
|
|
# printed to stdout:
|
|
|
|
#
|
|
|
|
# CONFIG_FILES="unhandled_files..."; export CONFIG_FILES
|
|
|
|
#
|
|
|
|
# This command can be used to have config.status create the unhandled
|
|
|
|
# files. For example,
|
|
|
|
#
|
|
|
|
# eval "echo $MAKEFILES | acoutput-fast.pl"
|
|
|
|
# AC_OUTPUT($MAKEFILES)
|
|
|
|
#
|
|
|
|
# Send comments, improvements, bugs to Steve Lamm (slamm@netscape.com).
|
|
|
|
|
|
|
|
#use File::Basename;
|
|
|
|
sub dirname {
|
|
|
|
my $dir = $_[0];
|
|
|
|
return '.' if not $dir =~ m%/%;
|
|
|
|
$dir =~ s%/[^/][^/]*$%%;
|
|
|
|
return $dir;
|
|
|
|
}
|
|
|
|
|
1999-09-10 23:08:07 +00:00
|
|
|
# Create one directory. Assumes it doesn't already exist.
|
|
|
|
# Will create parent(s) if needed.
|
|
|
|
sub create_directory {
|
|
|
|
my $dir = $_[0];
|
|
|
|
my $parent = dirname($dir);
|
|
|
|
create_directory($parent) if not -d $parent;
|
|
|
|
mkdir "$dir",0777;
|
|
|
|
}
|
|
|
|
|
1999-09-01 23:37:05 +00:00
|
|
|
# Create all the directories at once.
|
|
|
|
# This can be much faster than calling mkdir() for each one.
|
|
|
|
sub create_directories {
|
|
|
|
my @makefiles = @_;
|
|
|
|
my @dirs = ();
|
|
|
|
my $ac_file;
|
|
|
|
foreach $ac_file (@makefiles) {
|
1999-09-09 19:26:19 +00:00
|
|
|
push @dirs, dirname($ac_file);
|
1999-09-01 23:37:05 +00:00
|
|
|
}
|
|
|
|
# Call mkdir with the directories sorted by subdir count (how many /'s)
|
1999-09-10 23:08:07 +00:00
|
|
|
if (@dirs) {
|
2007-06-04 17:33:21 -07:00
|
|
|
foreach $dir (@dirs) {
|
|
|
|
if (not -d $dir) {
|
|
|
|
print STDERR "Creating directory $dir\n";
|
|
|
|
create_directory($dir);
|
1999-09-10 23:08:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
1999-09-01 23:37:05 +00:00
|
|
|
}
|
|
|
|
|
2003-10-30 21:05:56 +00:00
|
|
|
while($arg = shift) {
|
|
|
|
if ($arg =~ /^--srcdir=/) {
|
|
|
|
$ac_given_srcdir = (split /=/, $arg)[1];
|
|
|
|
}
|
|
|
|
if ($arg =~ /^--cygwin-srcdir/) {
|
|
|
|
$ac_cygwin_srcdir = (split /=/, $arg)[1];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$ac_given_srcdir) {
|
1999-09-27 17:28:33 +00:00
|
|
|
$ac_given_srcdir = $0;
|
|
|
|
$ac_given_srcdir =~ s|/?build/autoconf/.*$||;
|
|
|
|
$ac_given_srcdir = '.' if $ac_given_srcdir eq '';
|
|
|
|
}
|
1999-04-21 01:11:55 +00:00
|
|
|
|
2003-10-30 21:05:56 +00:00
|
|
|
if (!$ac_cygwin_srcdir) {
|
|
|
|
$ac_cygwin_srcdir = $ac_given_srcdir;
|
|
|
|
}
|
|
|
|
|
1999-04-21 01:11:55 +00:00
|
|
|
# Read list of makefiles from the stdin or,
|
|
|
|
# from files listed on the command-line.
|
|
|
|
#
|
|
|
|
@makefiles=();
|
2002-02-17 21:08:44 +00:00
|
|
|
push @makefiles, split while (<STDIN>);
|
1999-04-21 01:11:55 +00:00
|
|
|
|
|
|
|
# Create all the directories at once.
|
|
|
|
# This can be much faster than calling mkdir() for each one.
|
1999-09-01 23:37:05 +00:00
|
|
|
create_directories(@makefiles);
|
1999-04-21 01:11:55 +00:00
|
|
|
|
|
|
|
# Output the makefiles.
|
|
|
|
#
|
|
|
|
@unhandled=();
|
|
|
|
foreach $ac_file (@makefiles) {
|
|
|
|
if (not $ac_file =~ /Makefile$/ or $ac_file =~ /:/) {
|
|
|
|
push @unhandled, $ac_file;
|
|
|
|
next;
|
|
|
|
}
|
|
|
|
$ac_file_in = "$ac_given_srcdir/$ac_file.in";
|
|
|
|
$ac_dir = dirname($ac_file);
|
|
|
|
if ($ac_dir eq '.') {
|
|
|
|
$ac_dir_suffix = '';
|
|
|
|
$ac_dots = '';
|
|
|
|
} else {
|
|
|
|
$ac_dir_suffix = "/$ac_dir";
|
|
|
|
$ac_dir_suffix =~ s%^/\./%/%;
|
|
|
|
$ac_dots = $ac_dir_suffix;
|
|
|
|
$ac_dots =~ s%/[^/]*%../%g;
|
|
|
|
}
|
|
|
|
if ($ac_given_srcdir eq '.') {
|
|
|
|
$srcdir = '.';
|
|
|
|
if ($ac_dots eq '') {
|
|
|
|
$top_srcdir = '.'
|
|
|
|
} else {
|
|
|
|
$top_srcdir = $ac_dots;
|
|
|
|
$top_srcdir =~ s%/$%%;
|
|
|
|
}
|
2003-10-30 21:05:56 +00:00
|
|
|
} elsif ($ac_cygwin_srcdir =~ m%^/% or $ac_cygwin_srcdir =~ m%^.:/%) {
|
|
|
|
$srcdir = "$ac_cygwin_srcdir$ac_dir_suffix";
|
|
|
|
$top_srcdir = "$ac_cygwin_srcdir";
|
1999-04-21 01:11:55 +00:00
|
|
|
} else {
|
2003-10-30 21:05:56 +00:00
|
|
|
$srcdir = "$ac_dots$ac_cygwin_srcdir$ac_dir_suffix";
|
|
|
|
$top_srcdir = "$ac_dots$ac_cygwin_srcdir";
|
1999-04-21 01:11:55 +00:00
|
|
|
}
|
|
|
|
|
1999-08-19 19:56:26 +00:00
|
|
|
if (-e $ac_file) {
|
|
|
|
next if -M _ < -M $ac_file_in;
|
|
|
|
print STDERR "updating $ac_file\n";
|
|
|
|
} else {
|
|
|
|
print STDERR "creating $ac_file\n";
|
|
|
|
}
|
1999-04-26 18:08:50 +00:00
|
|
|
|
1999-04-21 01:11:55 +00:00
|
|
|
open (INFILE, "<$ac_file_in")
|
1999-04-26 18:08:50 +00:00
|
|
|
or ( warn "can't read $ac_file_in: No such file or directory\n" and next);
|
1999-04-21 01:11:55 +00:00
|
|
|
open (OUTFILE, ">$ac_file")
|
1999-04-26 18:08:50 +00:00
|
|
|
or ( warn "Unable to create $ac_file\n" and next);
|
1999-04-21 01:11:55 +00:00
|
|
|
|
|
|
|
while (<INFILE>) {
|
2000-06-28 10:21:53 +00:00
|
|
|
#if (/\@[_a-zA-Z]*\@.*\@[_a-zA-Z]*\@/) {
|
|
|
|
# warn "Two defines on a line:$ac_file:$.:$_";
|
|
|
|
# push @unhandled, $ac_file;
|
|
|
|
# last;
|
|
|
|
#}
|
1999-04-21 01:11:55 +00:00
|
|
|
|
2000-06-28 10:21:53 +00:00
|
|
|
s/\@srcdir\@/$srcdir/g;
|
|
|
|
s/\@top_srcdir\@/$top_srcdir/g;
|
1999-04-21 01:11:55 +00:00
|
|
|
|
|
|
|
if (/\@[_a-zA-Z]*\@/) {
|
2000-06-28 10:21:53 +00:00
|
|
|
warn "Unknown variable:$ac_file:$.:$_";
|
1999-04-21 01:11:55 +00:00
|
|
|
push @unhandled, $ac_file;
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
print OUTFILE;
|
|
|
|
}
|
|
|
|
close INFILE;
|
|
|
|
close OUTFILE;
|
|
|
|
}
|
|
|
|
|
|
|
|
# Print the shell command to be evaluated by configure.
|
|
|
|
#
|
|
|
|
print "CONFIG_FILES=\"".join(' ', @unhandled)."\"; export CONFIG_FILES\n";
|
|
|
|
|