summaryrefslogtreecommitdiff
path: root/buildtools/mktowscript
diff options
context:
space:
mode:
Diffstat (limited to 'buildtools/mktowscript')
-rw-r--r--buildtools/mktowscript/mklist.txt86
-rwxr-xr-xbuildtools/mktowscript/mktowscript.pl451
-rwxr-xr-xbuildtools/mktowscript/rebuild_all.sh37
3 files changed, 0 insertions, 574 deletions
diff --git a/buildtools/mktowscript/mklist.txt b/buildtools/mktowscript/mklist.txt
deleted file mode 100644
index ee77bb99df..0000000000
--- a/buildtools/mktowscript/mklist.txt
+++ /dev/null
@@ -1,86 +0,0 @@
-source4/main.mk
-source4/lib/basic.mk
-pidl/config.mk
-nsswitch/config.mk
-nsswitch/libwbclient/config.mk
-source4/heimdal_build/internal.mk
-source4/lib/ldb-samba/config.mk
-source4/librpc/config.mk
-source4/utils/config.mk
-source4/utils/net/config.mk
-source4/scripting/python/config.mk
-source4/auth/config.mk
-source4/auth/gensec/config.mk
-source4/auth/kerberos/config.mk
-source4/auth/ntlm/config.mk
-source4/auth/credentials/config.mk
-source4/auth/ntlmssp/config.mk
-source4/libnet/config.mk
-source4/nbt_server/config.mk
-source4/wrepl_server/config.mk
-source4/ntvfs/config.mk
-source4/ntvfs/unixuid/config.mk
-source4/ntvfs/sysdep/config.mk
-source4/ntvfs/common/config.mk
-source4/ntvfs/posix/config.mk
-source4/selftest/config.mk
-source4/cldap_server/config.mk
-source4/smb_server/config.mk
-source4/smb_server/smb2/config.mk
-source4/smb_server/smb/config.mk
-source4/smbd/config.mk source4/smbd/process_model.mk
-source4/kdc/config.mk
-source4/dsdb/config.mk
-source4/dsdb/samdb/ldb_modules/config.mk
-source4/web_server/config.mk
-source4/param/config.mk
-source4/winbind/config.mk
-source4/cluster/config.mk
-source4/client/config.mk
-source4/ntptr/config.mk
-source4/rpc_server/config.mk
-source4/libcli/config.mk
-source4/libcli/smb2/config.mk
-source4/libcli/wbclient/config.mk
-source4/libcli/security/config.mk
-source4/libcli/ldap/config.mk
-source4/ntp_signd/config.mk
-source4/torture/config.mk
-source4/torture/smb2/config.mk
-source4/torture/local/config.mk
-source4/torture/drs/config.mk
-source4/torture/winbind/config.mk
-source4/torture/libsmbclient/config.mk
-source4/torture/libnetapi/config.mk
-source4/lib/messaging/config.mk
-source4/lib/events/config.mk
-source4/lib/stream/config.mk
-source4/lib/cmdline/config.mk
-source4/lib/com/config.mk
-source4/lib/registry/config.mk
-source4/lib/wmi/config.mk
-source4/lib/socket/config.mk
-source4/lib/samba3/config.mk
-source4/ldap_server/config.mk
-libgpo/config.mk
-libcli/cldap/config.mk
-libcli/samsync/config.mk
-libcli/nbt/config.mk
-libcli/auth/config.mk
-libcli/drsuapi/config.mk
-libcli/security/config.mk
-libcli/smb/config.mk
-libcli/named_pipe_auth/config.mk
-libcli/ldap/config.mk
-lib/uid_wrapper/config.mk
-lib/crypto/config.mk
-lib/socket_wrapper/config.mk
-lib/util/config.mk
-lib/util/charset/config.mk
-lib/nss_wrapper/config.mk
-lib/tsocket/config.mk
-lib/popt/config.mk
-lib/async_req/config.mk
-lib/tdr/config.mk
-lib/torture/config.mk
-lib/smbconf/config.mk
diff --git a/buildtools/mktowscript/mktowscript.pl b/buildtools/mktowscript/mktowscript.pl
deleted file mode 100755
index a05506bcbd..0000000000
--- a/buildtools/mktowscript/mktowscript.pl
+++ /dev/null
@@ -1,451 +0,0 @@
-#!/usr/bin/perl -w
-
-use strict;
-use Data::Dumper;
-use File::Basename;
-use List::MoreUtils qw(uniq);
-
-my $globals;
-my $dname;
-
-sub read_file($)
-{
- my $filename = shift;
- open(CONFIG_MK, "$filename");
- my @lines = <CONFIG_MK>;
- close(CONFIG_MK);
- return @lines;
-}
-
-sub trim($)
-{
- my $string = shift;
- $string =~ s/^\s+//;
- $string =~ s/\s+$//;
- return $string;
-}
-
-sub strlist($)
-{
- my $s = shift;
- $s =~ s/\$\(SHLIBEXT\)/so/g;
- $s =~ s/\$\(heimdalsrcdir\)/..\/heimdal/g;
- $s =~ s/\$\(heimdalbuildsrcdir\)/..\/heimdal_build/g;
- $s =~ s/\$\(nsswitchsrcdir\)/..\/nsswitch/g;
- $s =~ s/\$\(param_OBJ_FILES\)/..\/pyparam.c/g;
- $s =~ s/\$\(libclisrcdir\)\///g;
- $s =~ s/\$\(socketwrappersrcdir\)\///g;
- $s =~ s/\$\(libcompressionsrcdir\)\///g;
- $s =~ s/\$\(\w*srcdir\)\///g;
- $s =~ s/\$\(libgpodir\)\///g;
- $s =~ s/\:\.o=\.ho//g;
- $s =~ s/\:\.o=\.d//g;
-
- # this one doesn't exist?
- $s =~ s/\bLDAP_ENCODE\b//g;
-
- # these need to use the library names
- $s =~ s/\bLIBLDB\b/ldb/g;
- $s =~ s/\bLDB\b/ldb/g;
- $s =~ s/\bLIBTALLOC\b/talloc/g;
- $s =~ s/\bTALLOC\b/talloc/g;
- $s =~ s/\bLIBTEVENT\b/tevent/g;
- $s =~ s/\bTEVENT\b/tevent/g;
- $s =~ s/\bTSOCKET\b/LIBTSOCKET/g;
- $s =~ s/\bGENSEC\b/gensec/g;
- $s =~ s/\bLIBTDB\b/tdb/g;
- $s =~ s/\bRESOLV\b/resolv/g;
-
- return trim(join(' ', split(/\s+/, $s)));
-}
-
-sub expand_vars($$)
-{
- my $vars = shift;
- my $s = shift;
- foreach my $v (keys %{$vars}) {
- if ($s =~ /\$\($v\)/) {
- $s =~ s/\$\($v\)/$vars->{$v}/g;
- delete($vars->{$v});
- }
- }
- foreach my $v (keys %{$globals}) {
- if ($s =~ /\$\($v\)/) {
- $s =~ s/\$\($v\)/$globals->{$v}/g;
- }
- }
- return $s;
-}
-
-sub find_file($)
-{
- my $f = shift;
- my $orig = $f;
-
- if ($f =~ /\$/) {
- printf(STDERR "bad variable expansion for file $orig in $dname\n");
- exit(1);
- }
-
- my $b = basename($f);
- return $b if (-e $b);
-
- return $f if (-e $f);
-
- while ($f =~ /\//) {
- $f =~ s/^[^\/]+\///g;
- return $f if (-e $f);
- }
- my $f2;
- $f2 = `find . -name "$f" -type f`;
- return $f2 unless ($f2 eq "");
- $f2 = `find .. -name "$f" -type f`;
- return $f2 unless ($f2 eq "");
- $f2 = `find ../.. -name "$f" -type f`;
- return $f2 unless ($f2 eq "");
- $f2 = `find ../../.. -name "$f" -type f`;
- return $f2 unless ($f2 eq "");
- printf(STDERR "Failed to find $orig in $dname\n");
- exit(1);
- return '';
-}
-
-sub find_files($)
-{
- my $list = shift;
- my $ret = '';
- foreach my $f (split(/\s+/, $list)) {
- if ($f =~ /\.[0-9]$/) {
- # a man page
- my $m = find_file($f . ".xml");
- die("Unable to find man page $f\n") if ($m eq "");
- $m =~ s/\.xml$//;
- return $m;
- }
- $f = find_file($f);
- $f =~ s/^[.]\///;
- $ret .= ' ' . $f;
- }
- $ret = strlist($ret);
- my @list = split(/\s+/, $ret);
- @list = uniq(@list);
- $ret = trim(join(' ', @list));
- return $ret;
-}
-
-sub read_config_mk($)
-{
- my $filename = shift;
- my @lines = read_file($filename);
- my $prev = "";
- my $linenum = 1;
- my $section = "GLOBAL";
- my $infragment;
- my $result;
- my $line = "";
- my $secnumber = 1;
-
- $result->{"GLOBAL"}->{SECNUMBER} = $secnumber++;
-
- foreach (@lines) {
- $linenum++;
-
- # lines beginning with '#' are ignored
- next if (/^\#.*$/);
-
- if (/^(.*)\\$/) {
- $prev .= $1;
- next;
- } else {
- $line = "$prev$_";
- $prev = "";
- }
-
- if ($line =~ /^mkinclude.*asn1_deps.pl\s+([^\s]+)\s+([^\s]+)\s+\\\$\\\(\w+\\\)\/([^\s|]+)\s*([^|]*)\|$/) {
- my $src = $1;
- $section = $2;
- my $dir = $3;
- my $options = $4;
- $section = "HEIMDAL_" . uc($section);
- $result->{$section}->{TYPE} = 'ASN1';
- $result->{$section}->{SECNUMBER} = $secnumber++;
- if ($options ne '') {
- $result->{$section}->{OPTIONS} = $options;
- }
- $result->{$section}->{DIRECTORY} = $dir;
- $result->{$section}->{$section . '_OBJ_FILES'} = $src;
- next;
- }
-
- if ($line =~ /^mkinclude.*et_deps.pl\s+([^\s]+)\s+\\\$\\\(\w+\\\)\/([^\s|]+)\|$/) {
- my $src = $1;
- my $dir = $2;
- $section = basename($src);
- $section =~ s/\./_/g;
- $section = "HEIMDAL_" . uc($section);
- $result->{$section}->{TYPE} = 'ERRTABLE';
- $result->{$section}->{SECNUMBER} = $secnumber++;
- $result->{$section}->{DIRECTORY} = "$dir";
- $result->{$section}->{$section . '_OBJ_FILES'} = $src;
- next;
- }
-
- if ($line =~ /^\[(\w+)::([\w-]+)\]/)
- {
- my $type = $1;
- $section = $2;
- $infragment = 0;
-
- $result->{$section}->{TYPE} = $type;
- $result->{$section}->{SECNUMBER} = $secnumber++;
- next;
- }
-
- # include
- if ($line =~ /^mkinclude (.*)$/) {
- my $subfile = $1;
- $result->{$subfile}->{TYPE} = 'SUBCONFIG';
- $result->{$subfile}->{SECNUMBER} = $secnumber++;
- next;
- }
-
- # empty line
- if ($line =~ /^[ \t]*$/) {
- next;
- }
-
- # global stuff is considered part of the makefile
- if ($section eq "GLOBAL") {
- $infragment = 1;
- next;
- }
-
- # Assignment
- if ($line =~ /^([a-zA-Z0-9_-]+)[\t ]*=(.*)$/) {
- $result->{$section}->{$1} = expand_vars($result->{$section}, strlist($2));
- $globals->{$1} = $result->{$section}->{$1};
- next;
- }
-
- # +=
- if ($line =~ /^([a-zA-Z0-9_-]+)[\t ]*\+=(.*)$/) {
- if (!$result->{$section}->{$1}) {
- $result->{$section}->{$1}="";
- }
- $result->{$section}->{$1} .= " " . expand_vars($result->{$section}, strlist($2));
- $globals->{$1} = $result->{$section}->{$1};
- next;
- }
-
- if ($line =~ /\$\(eval.\$\(call.proto_header_template.*,(.*),.*/) {
- $result->{$section}->{AUTOPROTO} = $1;
- }
- if ($line =~ /^\$\(eval/) {
- # skip eval lines for now
- next;
- }
-
- printf(STDERR "$linenum: Bad line: $line");
- }
-
- return $result;
-}
-
-
-sub process_results($)
-{
- my $result = shift;
-
- foreach my $s (sort {$result->{$a}->{SECNUMBER} <=> $result->{$b}->{SECNUMBER}} keys %{$result}) {
- next if ($s eq "GLOBAL");
- my $sec = $result->{$s};
- if ($sec->{TYPE} eq "SUBCONFIG") {
- my $d = dirname($s);
- next if ($d eq ".");
- printf "bld.BUILD_SUBDIR('%s')\n", dirname($s);
- } else {
- printf "\nbld.SAMBA_%s('%s'", $sec->{TYPE}, $s;
- my $trailer="";
- my $got_src = 0;
- my $got_private_deps = 0;
-
- foreach my $k (keys %{$sec}) {
- #print "key=$k\n";
-
- next if ($k eq "SECNUMBER");
- next if ($k eq "TYPE");
- if ($k eq "INIT_FUNCTION") {
- $trailer .= sprintf(",\n\tinit_function='%s'", trim($sec->{$k}));
- next;
- }
- if ($k eq "INIT_FUNCTION_SENTINEL") {
- $trailer .= sprintf(",\n\tinit_function_sentinal='%s'", trim($sec->{$k}));
- next;
- }
- if ($k eq "_PY_FILES" ||
- $k eq "EPYDOC_OPTIONS" ||
- $k eq "COV_TARGET" ||
- $k eq "GCOV" ||
- $k eq "PC_FILES" ||
- $k eq "CONFIG4FILE" ||
- $k eq "LMHOSTSFILE4") {
- $trailer .= sprintf(",\n\t# %s='%s'", $k, trim($sec->{$k}));
- next;
- }
- if ($k eq "SUBSYSTEM") {
- $trailer .= sprintf(",\n\tsubsystem='%s'", trim($sec->{$k}));
- next;
- }
- if ($k eq "PRIVATE_DEPENDENCIES") {
- $trailer .= sprintf(",\n\tdeps='%s'", strlist($sec->{$k}));
- $got_private_deps = 1;
- next;
- }
- if ($k eq "PUBLIC_DEPENDENCIES") {
- $trailer .= sprintf(",\n\tpublic_deps='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "ALIASES") {
- $trailer .= sprintf(",\n\taliases='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "CFLAGS") {
- $trailer .= sprintf(",\n\tcflags='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "OPTIONS") {
- $trailer .= sprintf(",\n\toptions='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "DIRECTORY") {
- $trailer .= sprintf(",\n\tdirectory='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "LDFLAGS") {
- $trailer .= sprintf(",\n\tldflags='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "INSTALLDIR") {
- $trailer .= sprintf(",\n\tinstalldir='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "ASN1C") {
- $trailer .= sprintf(",\n\tcompiler='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "ET_COMPILER") {
- $trailer .= sprintf(",\n\tcompiler='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "ENABLE") {
- my $v = strlist($sec->{$k});
- if ($v eq "NO") {
- $trailer .= sprintf(",\n\tenabled=False");
- next;
- }
- next if ($v eq "YES");
- die("Unknown ENABLE value $v in $s\n");
- }
- if ($k eq "USE_HOSTCC") {
- my $v = strlist($sec->{$k});
- if ($v eq "YES") {
- $trailer .= sprintf(",\n\tuse_hostcc=True");
- next;
- }
- next if ($v eq "NO");
- die("Unknown HOST_CC value $v in $s\n");
- }
- if ($k eq "$s" . "_VERSION") {
- $trailer .= sprintf(",\n\tvnum='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "$s" . "_SOVERSION") {
- next;
- }
- if ($k eq "LIBRARY_REALNAME") {
- $trailer .= sprintf(",\n\trealname='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "OUTPUT_TYPE") {
- $trailer .= sprintf(",\n\toutput_type='%s'", strlist($sec->{$k}));
- next;
- }
- if ($k eq "AUTOPROTO") {
- my $list = trim(find_files(strlist($sec->{$k})));
- $trailer .= sprintf(",\n\tautoproto='%s'", $list);
- next;
- }
- if ($k eq "PUBLIC_HEADERS") {
- my $list = trim(strlist($sec->{$k}));
- if ($list =~ /\$\(addprefix .*,(.*)\)(.*)$/) {
- $list = trim("$1 $2");
- $list = find_files($list);
- } else {
- $list = trim(find_files(strlist($sec->{$k})));
- }
- $trailer .= sprintf(",\n\tpublic_headers='%s'", $list);
- next;
- }
- if ($k eq "MANPAGES") {
- my $list = trim(find_files(strlist($sec->{$k})));
- $trailer .= sprintf(",\n\tmanpages='%s'", $list);
- next;
- }
- if ($k eq "$s" . "_OBJ_FILES") {
- my $list = trim(strlist($sec->{$k}));
- $list =~ s/\.o/.c/g;
- $list =~ s/\.ho/.c/g;
- if ($list =~ /\$\(addprefix .*,(.*)\)(.*)$/) {
- $list = trim("$1 $2");
- $list = find_files($list);
- $list = "'$list'";
- } elsif ($list =~ /\$\(addprefix \$\((\w+)\)(.*),(.*)\)(.*)$/) {
- my $src = trim($3);
- my $dir = "$1$2";
- $dir =~ s/\/$//;
- my $res = "bld.SUBDIR('$dir', '$src')";
- if ($4) {
- $res = "$res + '$4'";
- }
- $list = $res;
- } else {
- $list = find_files($list);
- $list="'$list'";
- }
- $list =~ s/\$\(\w+srcdir\)\///g;
- printf(",\n\tsource=%s", $list);
- $got_src = 1;
- next;
- }
- if ($k eq "HEIMDAL_GSSAPI_KRB5_OBJ_FILES" ||
- $k eq "HEIMDAL_GSSAPI_SPNEGO_OBJ_FILES" ||
- $k eq "HEIMDAL_HEIM_ASN1_DER_OBJ_FILES" ||
- $k eq "HEIMDAL_HX509_OBJH_FILES" ||
- $k eq "HEIMDAL_HX509_OBJG_FILES" ||
- $k eq "HEIMDAL_ROKEN_OBJ_FILES"
- ) {
- next;
- }
- die("Unknown keyword $k in $s\n");
- }
- die("No source list in $s\n") unless $got_src or $got_private_deps;
- if (! $got_src) {
- printf(",source=''\n\t");
- }
- printf("%s\n\t)\n\n", $trailer);
- }
- }
-}
-
-for (my $i=0; $i <= $#ARGV; $i++) {
- my $filename=$ARGV[$i];
- $dname=dirname($filename);
- my $result = read_config_mk($filename);
- if ($i != 0) {
- print "\n\n\n";
- }
- print "# AUTOGENERATED by mktowscript.pl from $filename\n# Please remove this notice if hand editing\n\n";
- die("Unable to chdir to $dname\n") unless chdir($dname);
- process_results($result);
-}
-
diff --git a/buildtools/mktowscript/rebuild_all.sh b/buildtools/mktowscript/rebuild_all.sh
deleted file mode 100755
index e3ed7cfd24..0000000000
--- a/buildtools/mktowscript/rebuild_all.sh
+++ /dev/null
@@ -1,37 +0,0 @@
-#!/bin/sh
-
-cat mklist.txt |
-while read line; do
- ws=""
- list=""
- for f in $line; do
- echo "Processing $f"
- f="../../$f"
- test -f $f || {
- echo "$f doesn't exist"
- exit 1
- }
- ws="$(dirname $f)/wscript_build"
- if [ -f $ws ]; then
- if test -s $ws && ! grep "AUTOGENERATED.by.mktowscript" $ws > /dev/null; then
- echo "Skipping manually edited file $ws"
- continue
- fi
- fi
- list="$list $f"
- done
- if [ "$list" = "" ]; then
- continue
- fi
- ./mktowscript.pl $list > wscript_build.$$ || {
- echo "Failed on $f"
- rm -f wscript_build.$$
- exit 1
- }
- if cmp wscript_build.$$ $ws > /dev/null 2>&1; then
- rm -f wscript_build.$$
- else
- mv wscript_build.$$ $ws || exit 1
- fi
- #exit 1
-done