r9587: Fix SWAT data dir for --with-fhs
[sfrench/samba-autobuild/.git] / source / build / smb_build / makefile.pm
index 820ccfaf6c13e559f4a1add019cf847733d3bd77..e2ab304adcf1fc0a4d5dce80d8862a545916dfd1 100644 (file)
@@ -3,42 +3,35 @@
 ### - create output for Makefile                       ###
 ###                                                    ###
 ###  Copyright (C) Stefan (metze) Metzmacher 2004      ###
+###  Copyright (C) Jelmer Vernooij 2005                        ###
 ###  Released under the GNU GPL                                ###
 ###########################################################
 
 package makefile;
+use config qw(%config);
 use strict;
 
-sub _prepare_command_interpreters($)
+sub _prepare_path_vars()
 {
-       my $ctx = shift;
-
-       return << '__EOD__';
-SHELL=/bin/sh
-PERL=@PERL@
-
-__EOD__
-}
-
-sub _prepare_path_vars($)
-{
-       my $ctx = shift;
        my $output;
 
        $output = << '__EOD__';
-prefix=@prefix@
-exec_prefix=@exec_prefix@
-VPATH=@srcdir@
-srcdir=@srcdir@
-builddir=@builddir@
-
-BASEDIR= @prefix@
+prefix = @prefix@
+exec_prefix = @exec_prefix@
+selftest_prefix = @selftest_prefix@
+VPATH = @srcdir@
+srcdir = @srcdir@
+builddir = @builddir@
+
+BASEDIR = @prefix@
 BINDIR = @bindir@
 SBINDIR = @sbindir@
+datadir = @datadir@
 LIBDIR = @libdir@
 CONFIGDIR = @configdir@
-VARDIR = @localstatedir@
+localstatedir = @localstatedir@
 SWATDIR = @swatdir@
+VARDIR = @localstatedir@
 
 # The permissions to give the executables
 INSTALLPERMS = 0755
@@ -75,102 +68,100 @@ __EOD__
        return $output;
 }
 
-sub _prepare_compiler_linker($)
+sub _prepare_compiler_linker()
 {
-       my $ctx = shift;
-
-       return << '__EOD__';
-CC=@CC@
-CFLAGS=-Iinclude -I. -I$(srcdir)/include -I$(srcdir) -D_SAMBA_BUILD_ -DHAVE_CONFIG_H -Ilib @CFLAGS@ @CPPFLAGS@
+       return << "__EOD__";
+SHELL=$config{SHELL}
+PERL=$config{PERL}
+CC=$config{CC}
+CFLAGS=-I\$(srcdir)/include -I\$(srcdir) -D_SAMBA_BUILD_ -DHAVE_CONFIG_H -I\$(srcdir)/lib $config{CFLAGS} $config{CPPFLAGS}
 
-LD=@CC@
-LD_FLAGS=@LDFLAGS@ @CFLAGS@ -Lbin
+LD=$config{LD}
+LD_FLAGS=$config{LDFLAGS} -Lbin
 
-STLD=ar
+STLD=$config{AR}
 STLD_FLAGS=-rc
 
-SHLD=@CC@
-SHLD_FLAGS=@LDSHFLAGS@ @LDFLAGS@ -Lbin
+SHLD=$config{CC}
+SHLD_FLAGS=$config{LDSHFLAGS} -Lbin
 
-XSLTPROC=@XSLTPROC@
+XSLTPROC=$config{XSLTPROC}
 
-__EOD__
-}
+LEX=$config{LEX}
+YACC=$config{YACC}
 
-sub _prepare_default_rule($)
-{
-       my $ctx = shift;
-       my $output;
+CPP=$config{CPP}
 
-       $output = << '__EOD__';
-default: all
+DEFAULT_TEST_TARGET=$config{DEFAULT_TEST_TARGET}
 
 __EOD__
-
-       return $output;
 }
 
-sub _prepare_SUFFIXES($)
+sub _prepare_default_rule()
 {
-       my $ctx = shift;
-       my $output;
-
-       $output = << '__EOD__';
-.SUFFIXES:
-.SUFFIXES: .c .o .h .h.gch .a .so .1 .1.xml .3 .3.xml .5 .5.xml .7 .7.xml
+       return << '__EOD__';
+default: all
 
 __EOD__
-
-       return $output;
 }
 
-sub _prepare_IDL($)
+sub _prepare_SUFFIXES()
 {
-       my $ctx = shift;
-
        return << '__EOD__';
-idl_full: build/pidl/Parse/Pidl/IDL.pm
-       CPP="@CPP@" PERL="$(PERL)" script/build_idl.sh FULL @PIDL_ARGS@
+.SUFFIXES: .x .c .et .y .l .d .o .h .h.gch .a .so .1 .1.xml .3 .3.xml .5 .5.xml .7 .7.xml
 
-idl: build/pidl/Parse/Pidl/IDL.pm
-       @CPP="@CPP@" PERL="$(PERL)" script/build_idl.sh PARTIAL @PIDL_ARGS@
+__EOD__
+}
 
-build/pidl/Parse/Pidl/IDL.pm: build/pidl/idl.yp
-       -yapp -s -m 'Parse::Pidl::IDL' -o build/pidl/Parse/Pidl/IDL.pm build/pidl/idl.yp 
+sub _prepare_man_rule($)
+{
+       my $suffix = shift;
 
-pch: proto include/includes.h.gch
+       return << "__EOD__";
+.$suffix.xml.$suffix:
+       \$(XSLTPROC) -o \$@ http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl \$<
 
-pch_clean:
-       -rm -f include/includes.h.gch
+__EOD__
+}
 
-basics: idl proto_exists HEIMDAL_EXTERNAL
+sub _prepare_config_status()
+{
+       my @parsed_files = @smb_build::config_mk::parsed_files;
+       my $deps = "";
+       
+       foreach (@parsed_files) {
+               /^([^ |]+)/;
+               $deps.= " $1";
+       }
 
-test: @DEFAULT_TEST_TARGET@
+       return "
 
-test-swrap: all
-       ./script/tests/selftest.sh @selftest_prefix@/prefix-test all SOCKET_WRAPPER
+Makefile: config.status $deps
+       ./config.status
 
-test-noswrap: all
-       ./script/tests/selftest.sh @selftest_prefix@/prefix-test all
+";
+}
 
-quicktest: all
-       ./script/tests/selftest.sh @selftest_prefix@/prefix-test quick SOCKET_WRAPPER
+sub _prepare_binaries($)
+{
+       my $ctx = shift;
 
-valgrindtest: all
-       SMBD_VALGRIND="xterm -n smbd -e valgrind -q --db-attach=yes --num-callers=30" \
-       ./script/tests/selftest.sh @selftest_prefix@/prefix-test quick SOCKET_WRAPPER
+       my @bbn_list = ();
+       my @sbn_list = ();
 
-__EOD__
-}
+       foreach (values %$ctx) {
+               next unless defined $_->{OUTPUT_TYPE};
+               next unless ($_->{OUTPUT_TYPE} eq "BINARY");
 
-sub _prepare_man_rule($)
-{
-       my $suffix = shift;
+               push(@sbn_list, $_->{OUTPUT}) if ($_->{INSTALLDIR} eq "SBINDIR");
+               push(@bbn_list, $_->{OUTPUT}) if ($_->{INSTALLDIR} eq "BINDIR");
+       }
 
+       my $bbn = array2oneperline(\@bbn_list);
+       my $sbn = array2oneperline(\@sbn_list);
        return << "__EOD__";
-.$suffix.xml.$suffix:
-       \$(XSLTPROC) -o \$@ http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl \$<
-
+BIN_PROGS = $bbn
+SBIN_PROGS = $sbn
 __EOD__
 }
 
@@ -181,17 +172,13 @@ sub _prepare_manpages($)
        my @mp_list = ();
 
        foreach (values %$ctx) {
-               if (defined($_->{MANPAGE}) and $_->{MANPAGE} ne "") {
-                       push (@mp_list, $_->{MANPAGE});
-               }
+               push (@mp_list, $_->{MANPAGE}) if (defined($_->{MANPAGE}) and $_->{MANPAGE} ne "");
        }
        
-       my $mp = join(' ', @mp_list);
+       my $mp = array2oneperline(\@mp_list);
        return << "__EOD__";
 MANPAGES = $mp
 
-manpages: \$(MANPAGES)
-
 __EOD__
 }
 
@@ -211,6 +198,17 @@ dynconfig.o: dynconfig.c Makefile
 __EOD__
 }
 
+sub _prepare_depend_CC_rule()
+{
+       return << '__EOD__';
+
+.c.d:
+       @echo "Generating dependencies for $<"
+       @$(CC) -MM -MG -MT $(<:.c=.o) -MF $@ $(CFLAGS) $<
+
+__EOD__
+}
+
 ###########################################################
 # This function creates a standard make rule which is using $(CC)
 #
@@ -229,15 +227,9 @@ __EOD__
 # $output -            the resulting output buffer
 sub _prepare_std_CC_rule($$$$$)
 {
-       my $src = shift;
-       my $dst = shift;
-       my $flags = shift;
-       my $message = shift;
-       my $comment = shift;
-       my $flagsstr = "";
-       my $output;
+       my ($src,$dst,$flags,$message,$comment) = @_;
 
-       $output = << "__EOD__";
+       return << "__EOD__";
 # $comment
 .$src.$dst:
        \@echo $message \$\*.$src
@@ -245,41 +237,17 @@ sub _prepare_std_CC_rule($$$$$)
 \@BROKEN_CC\@  -mv `echo \$\@ | sed 's%^.*/%%g'` \$\@
 
 __EOD__
-
-       return $output;
 }
 
 sub array2oneperline($)
 {
        my $array = shift;
-       my $i;
-       my $output = "";
-
-       foreach my $str (@{$array}) {
-               if (!defined($str)) {
-                       next;
-               }
-
-               $output .= " \\\n\t\t";
-               $output .= $str;
-       }
-
-       return $output;
-}
-
-sub array2oneline($)
-{
-       my $array = shift;
-       my $i;
        my $output = "";
 
-       foreach my $str (@{$array}) {
-               if (!defined($str)) {
-                       next;
-               }
+       foreach (@$array) {
+               next unless defined($_);
 
-               $output .= $str;
-               $output .= " ";
+               $output .= " \\\n\t\t$_";
        }
 
        return $output;
@@ -298,24 +266,22 @@ sub array2oneline($)
 # $output -            the resulting output buffer
 sub _prepare_obj_list($$)
 {
-       my $var = shift;
-       my $ctx = shift;
+       my ($var,$ctx) = @_;
 
        my $tmplist = array2oneperline($ctx->{OBJ_LIST});
+       return "" if ($tmplist eq "");
 
        return << "__EOD__";
-# $var $ctx->{NAME} OBJ LIST
 $var\_$ctx->{NAME}_OBJS =$tmplist
-
 __EOD__
 }
 
 sub _prepare_cflags($$)
 {
-       my $var = shift;
-       my $ctx = shift;
+       my ($var,$ctx) = @_;
 
        my $tmplist = array2oneperline($ctx->{CFLAGS});
+       return "" if ($tmplist eq "");
 
        return << "__EOD__";
 $var\_$ctx->{NAME}_CFLAGS =$tmplist
@@ -345,22 +311,14 @@ __EOD__
 sub _prepare_shared_library_rule($)
 {
        my $ctx = shift;
-       my $tmpdepend;
-       my $tmpstlink;
-       my $tmpstflag;
-       my $tmpshlink;
-       my $tmpshflag;
-       my $tmprules;
        my $output;
 
-       $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-
-       $tmpshlink = array2oneperline($ctx->{LINK_LIST});
-       $tmpshflag = array2oneperline($ctx->{LINK_FLAGS});
+       my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
+       my $tmpshlink = array2oneperline($ctx->{LINK_LIST});
+       my $tmpshflag = array2oneperline($ctx->{LINK_FLAGS});
 
        $output = << "__EOD__";
 LIBRARY_$ctx->{NAME}_DEPEND_LIST =$tmpdepend
-#
 LIBRARY_$ctx->{NAME}_SHARED_LINK_LIST =$tmpshlink
 LIBRARY_$ctx->{NAME}_SHARED_LINK_FLAGS =$tmpshflag
 #
@@ -395,20 +353,34 @@ __EOD__
        return $output;
 }
 
-sub _prepare_objlist_rule($)
+sub _prepare_mergedobj_rule($)
 {
        my $ctx = shift;
+
+       return "" unless $ctx->{TARGET};
+
        my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-       my $output;
 
-       if (! $ctx->{TARGET}) {
-               return "";
-       }
+       my $output = "$ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST = $tmpdepend\n";
 
-       $output = "$ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST = $tmpdepend\n";
+       $output .= "$ctx->{TARGET}: \$($ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST) \$($ctx->{TYPE}_$ctx->{NAME}_OBJS)\n";
 
-       $output .= "$ctx->{TARGET}: ";
+       $output .= "\t\@echo \"Pre-Linking $ctx->{TYPE} $ctx->{NAME}\"\n";
+       $output .= "\t@\$(LD) -r \$($ctx->{TYPE}_$ctx->{NAME}_OBJS) -o $ctx->{TARGET}\n";
+       $output .= "\n";
 
+       return $output;
+}
+
+sub _prepare_objlist_rule($)
+{
+       my $ctx = shift;
+       my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
+
+       return "" unless $ctx->{TARGET};
+
+       my $output = "$ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST = $tmpdepend\n";
+       $output .= "$ctx->{TARGET}: ";
        $output .= "\$($ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST) \$($ctx->{TYPE}_$ctx->{NAME}_OBJS)\n";
        $output .= "\t\@touch $ctx->{TARGET}\n";
 
@@ -435,18 +407,11 @@ sub _prepare_objlist_rule($)
 sub _prepare_static_library_rule($)
 {
        my $ctx = shift;
-       my $tmpdepend;
-       my $tmpstlink;
-       my $tmpstflag;
-       my $tmpshlink;
-       my $tmpshflag;
-       my $tmprules;
        my $output;
 
-       $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-
-       $tmpstlink = array2oneperline($ctx->{LINK_LIST});
-       $tmpstflag = array2oneperline($ctx->{LINK_FLAGS});
+       my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
+       my $tmpstlink = array2oneperline($ctx->{LINK_LIST});
+       my $tmpstflag = array2oneperline($ctx->{LINK_FLAGS});
 
        $output = << "__EOD__";
 LIBRARY_$ctx->{NAME}_DEPEND_LIST =$tmpdepend
@@ -484,16 +449,12 @@ __EOD__
 sub _prepare_binary_rule($)
 {
        my $ctx = shift;
-       my $tmpdepend;
-       my $tmplink;
-       my $tmpflag;
-       my $output;
 
-       $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-       $tmplink = array2oneperline($ctx->{LINK_LIST});
-       $tmpflag = array2oneperline($ctx->{LINK_FLAGS});
+       my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
+       my $tmplink = array2oneperline($ctx->{LINK_LIST});
+       my $tmpflag = array2oneperline($ctx->{LINK_FLAGS});
 
-       $output = << "__EOD__";
+       my $output = << "__EOD__";
 #
 BINARY_$ctx->{NAME}_DEPEND_LIST =$tmpdepend
 BINARY_$ctx->{NAME}_LINK_LIST =$tmplink
@@ -501,7 +462,7 @@ BINARY_$ctx->{NAME}_LINK_FLAGS =$tmpflag
 #
 bin/$ctx->{BINARY}: bin/.dummy \$(BINARY_$ctx->{NAME}_DEPEND_LIST) \$(BINARY_$ctx->{NAME}_OBJS)
        \@echo Linking \$\@
-       \@\$(LD) \$(LD_FLAGS) -o \$\@ \\
+       \@\$(CC) \$(LD_FLAGS) -o \$\@ \\
                \$\(BINARY_$ctx->{NAME}_LINK_FLAGS) \\
                \$\(BINARY_$ctx->{NAME}_LINK_LIST) \\
                \$\(BINARY_$ctx->{NAME}_LINK_FLAGS)
@@ -524,57 +485,37 @@ bin/.TARGET_$ctx->{NAME}:
 ";
 }
 
-sub _prepare_proto_rules()
+sub _prepare_clean_rules()
 {
-       my $output = "";
-
-       $output .= << '__EOD__';
-# Making this target will just make sure that the prototype files
-# exist, not necessarily that they are up to date.  Since they're
-# removed by 'make clean' this will always be run when you do anything
-# afterwards.
-proto_exists: include/proto.h
-
-delheaders: pch_clean
-       -rm -f $(builddir)/include/proto.h
-
-include/proto.h:
-       @cd $(srcdir) && $(SHELL) script/mkproto.sh "$(PERL)" \
-         -h _PROTO_H_ $(builddir)/include/proto.h \
-         $(PROTO_PROTO_OBJS)
-
-# 'make headers' or 'make proto' calls a subshell because we need to
-# make sure these commands are executed in sequence even for a
-# parallel make.
-headers: delheaders proto_exists
-
-proto: idl headers
-
-proto_test:
-       @[ -f $(builddir)/include/proto.h ] || $(MAKE) proto
-
-clean: delheaders
+       my $output = << '__EOD__';
+clean: heimdal_clean
+       @echo Removing headers
+       @-rm -f include/proto.h
        @echo Removing objects
        @-find . -name '*.o' -exec rm -f '{}' \;
        @echo Removing binaries
-       @-rm -f bin/*
+       @-rm -f $(BIN_PROGS) $(SBIN_PROGS)
        @echo Removing dummy targets
        @-rm -f bin/.*_*
        @echo Removing generated files
        @-rm -rf librpc/gen_*
-       @echo Removing generated ASN1 files
-       @-find heimdal/lib/asn1 -name 'asn1_*.[xc]' -exec rm -f '{}' \;
-       @-find heimdal/lib/gssapi -name 'asn1_*.[xc]' -exec rm -f '{}' \;
-       @-find heimdal/lib/hdb -name 'asn1_*.[xc]' -exec rm -f '{}' \;
 
 distclean: clean
        -rm -f bin/.dummy
        -rm -f include/config.h include/smb_build.h
-       -rm -f Makefile*
+       -rm -f Makefile Makefile.in
        -rm -f config.status
        -rm -f config.log config.cache
        -rm -f samba4-deps.dot
+       -rm -f config.pm config.mk
        -rm -f lib/registry/winregistry.pc
+__EOD__
+
+       if ($config{developer} eq "yes") {
+               $output .= "\t\@-rm -f \$(_ALL_OBJS_OBJS:.o=.d)\n";
+       }
+
+       $output .= << '__EOD__';
 
 removebackup:
        -rm -f *.bak *~ */*.bak */*~ */*/*.bak */*/*~ */*/*/*.bak */*/*/*~
@@ -593,7 +534,6 @@ sub _prepare_make_target($)
 {
        my $ctx = shift;
        my $tmpdepend;
-       my $output;
 
        $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
 
@@ -611,9 +551,6 @@ sub _prepare_target_settings($)
        foreach my $key (values %$CTX) {
                if (defined($key->{OBJ_LIST})) {
                        $output .= _prepare_obj_list($key->{TYPE}, $key);
-               }
-
-               if (defined($key->{OBJ_LIST})) {
                        $output .= _prepare_cflags($key->{TYPE}, $key);
                }
        }
@@ -621,167 +558,15 @@ sub _prepare_target_settings($)
        return $output;
 }
 
-sub _prepare_install_rules($)
-{
-       my $CTX = shift;
-       my $output = "";
-
-       $output .= << '__EOD__';
-
-showlayout: 
-       @echo "Samba will be installed into:"
-       @echo "  basedir: $(BASEDIR)"
-       @echo "  bindir:  $(BINDIR)"
-       @echo "  sbindir: $(SBINDIR)"
-       @echo "  libdir:  $(LIBDIR)"
-       @echo "  vardir:  $(VARDIR)"
-       @echo "  privatedir:  $(PRIVATEDIR)"
-       @echo "  piddir:   $(PIDDIR)"
-       @echo "  lockdir:  $(LOCKDIR)"
-       @echo "  swatdir:  $(SWATDIR)"
-       @echo "  mandir:   $(MANDIR)"
-
-showflags:
-       @echo "Samba will be compiled with flags:"
-       @echo "  CFLAGS = $(CFLAGS)"
-       @echo "  LD_FLAGS = $(LD_FLAGS)"
-       @echo "  STLD_FLAGS = $(STLD_FLAGS)"
-       @echo "  SHLD_FLAGS = $(SHLD_FLAGS)"
-
-SBIN_PROGS = bin/smbd
-
-BIN_PROGS = bin/smbclient \
-               bin/net \
-               bin/nmblookup \
-               bin/ntlm_auth
-
-TORTURE_PROGS = bin/smbtorture \
-               bin/gentest \
-               bin/locktest \
-               bin/masktest \
-               bin/ndrdump
-
-LDB_PROGS =    bin/ldbadd \
-               bin/ldbdel \
-               bin/ldbmodify \
-               bin/ldbedit \
-               bin/ldbsearch
-
-REG_PROGS =    bin/regpatch \
-               bin/regshell \
-               bin/regtree \
-               bin/regdiff
-
-GTK_PROGS = bin/gregedit \
-               bin/gwsam \
-               bin/gepdump
-
-install: showlayout installbin installtorture installldb installreg installdat installswat installmisc installgtk
-
-# DESTDIR is used here to prevent packagers wasting their time
-# duplicating the Makefile. Remove it and you will have the privilege
-# of package each samba release for multiple versions of multiple
-# distributions and operating systems, or at least supplying patches
-# to all the packaging files required for this, prior to committing
-# the removal of DESTDIR. Do not remove it even though you think it
-# is not used.
-
-installdirs:
-       @$(SHELL) $(srcdir)/script/installdirs.sh $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(SBINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(PRIVATEDIR) $(DESTDIR)$(PIDDIR) $(DESTDIR)$(LOCKDIR) $(DESTDIR)$(PRIVATEDIR)/tls
-
-installbin: all installdirs
-       @$(SHELL) $(srcdir)/script/installbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(SBINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(SBIN_PROGS)
-       @$(SHELL) $(srcdir)/script/installbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(BIN_PROGS)
-
-installtorture: all installdirs
-       @$(SHELL) $(srcdir)/script/installbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(TORTURE_PROGS)
-
-installldb: all installdirs
-       @$(SHELL) $(srcdir)/script/installbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(LDB_PROGS)
-
-installreg: all installdirs
-       @$(SHELL) $(srcdir)/script/installbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(REG_PROGS)
-
-installgtk: all installdirs
-       @$(SHELL) $(srcdir)/script/installbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(GTK_PROGS)
-
-installdat: installdirs
-       @$(SHELL) $(srcdir)/script/installdat.sh $(DESTDIR)$(LIBDIR) $(srcdir)
-
-installswat: installdirs
-       @$(SHELL) $(srcdir)/script/installswat.sh $(DESTDIR)$(SWATDIR) $(srcdir) $(DESTDIR)$(LIBDIR)
-
-installmisc: installdirs
-       @$(SHELL) $(srcdir)/script/installmisc.sh $(srcdir) $(DESTDIR)$(LIBDIR)
-
-installman: installdirs
-       @$(SHELL) $(srcdir)/script/installman.sh $(DESTDIR)$(MANDIR) $(MANPAGES)
-
-uninstall: uninstallbin uninstalltorture uninstallldb uninstallreg uninstallgtk
-
-uninstallbin:
-       @$(SHELL) $(srcdir)/script/uninstallbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(SBINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(SBIN_PROGS)
-
-uninstalltorture:
-       @$(SHELL) $(srcdir)/script/uninstallbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(TORTURE_PROGS)
-
-uninstallldb:
-       @$(SHELL) $(srcdir)/script/uninstallbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(LDB_PROGS)
-
-uninstallreg:
-       @$(SHELL) $(srcdir)/script/uninstallbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(REG_PROGS)
-
-uninstallgtk:
-       @$(SHELL) $(srcdir)/script/uninstallbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(BINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(GTK_PROGS)
-
-uninstallman:
-       @$(SHELL) $(srcdir)/script/uninstallman.sh $(DESTDIR)$(MANDIR) $(MANPAGES)
-
-# Swig extensions
-
-swig: scripting/swig/_tdb.so scripting/swig/_dcerpc.so
-
-scripting/swig/tdb_wrap.c: scripting/swig/tdb.i
-       swig -python scripting/swig/tdb.i
-
-scripting/swig/_tdb.so: scripting/swig/tdb_wrap.o $(LIBRARY_swig_tdb_DEPEND_LIST)
-       $(SHLD) $(SHLD_FLAGS) -o scripting/swig/_tdb.so scripting/swig/tdb_wrap.o \
-               $(LIBRARY_swig_tdb_SHARED_LINK_LIST) $(LIBRARY_swig_tdb_SHARED_LINK_FLAGS)
-
-SWIG_INCLUDES = librpc/gen_ndr/samr.i librpc/gen_ndr/lsa.i librpc/gen_ndr/spoolss.i
-
-scripting/swig/dcerpc_wrap.c: scripting/swig/dcerpc.i scripting/swig/samba.i scripting/swig/status_codes.i $(SWIG_INCLUDES)
-       swig -python scripting/swig/dcerpc.i
-
-scripting/swig/_dcerpc.so: scripting/swig/dcerpc_wrap.o $(LIBRARY_swig_dcerpc_DEPEND_LIST)
-       $(SHLD) $(SHLD_FLAGS) -o scripting/swig/_dcerpc.so scripting/swig/dcerpc_wrap.o $(LIBRARY_swig_dcerpc_SHARED_LINK_LIST) $(LIBRARY_swig_dcerpc_SHARED_LINK_FLAGS)
-
-swig_clean:
-       -rm -f scripting/swig/_tdb.so scripting/swig/tdb.pyc \
-               scripting/swig/tdb.py scripting/swig/tdb_wrap.c \
-               scripting/swig/tdb_wrap.o
-
-everything: all
-
-etags:
-       etags `find $(srcdir) -name "*.[ch]"`
-
-ctags:
-       ctags `find $(srcdir) -name "*.[ch]"`
-
-__EOD__
-
-       return $output;
-}
-
 sub _prepare_rule_lists($)
 {
        my $depend = shift;
        my $output = "";
 
        foreach my $key (values %{$depend}) {
-               next if not defined $key->{OUTPUT_TYPE};
+               next unless defined $key->{OUTPUT_TYPE};
 
+               ($output .= _prepare_mergedobj_rule($key)) if $key->{OUTPUT_TYPE} eq "MERGEDOBJ";
                ($output .= _prepare_objlist_rule($key)) if $key->{OUTPUT_TYPE} eq "OBJLIST";
                ($output .= _prepare_static_library_rule($key)) if $key->{OUTPUT_TYPE} eq "STATIC_LIBRARY";
                ($output .= _prepare_shared_library_rule($key)) if $key->{OUTPUT_TYPE} eq "SHARED_LIBRARY";
@@ -789,12 +574,7 @@ sub _prepare_rule_lists($)
                ($output .= _prepare_custom_rule($key) ) if $key->{TYPE} eq "TARGET";
        }
 
-       my $idl_ctx;
-       $output .= _prepare_IDL($idl_ctx);
-
-       $output .= _prepare_proto_rules();
-
-       $output .= _prepare_install_rules($depend);
+       $output .= _prepare_clean_rules();
 
        return $output;
 }
@@ -807,55 +587,45 @@ sub _prepare_rule_lists($)
 # $OUTPUT -    the global OUTPUT context
 #
 # $output -            the resulting output buffer
-sub _prepare_makefile_in($$)
+sub _prepare_makefile_in($)
 {
-       my $CTX = shift;
-       my $settings = shift;
+       my ($CTX) = @_;
        my $output;
 
-       $output  = "########################################\n";
-       $output .= "# Autogenerated by config.smb_build.pl #\n";
-       $output .= "########################################\n";
+       $output  = "############################################\n";
+       $output .= "# Autogenerated by build/smb_build/main.pl #\n";
+       $output .= "############################################\n";
        $output .= "\n";
 
-       my $cmd_ctx;
-       $output .= _prepare_command_interpreters($cmd_ctx);
-
-       my $path_ctx;
-       $output .= _prepare_path_vars($path_ctx);
-
-       my $compiler_ctx;
-       $output .= _prepare_compiler_linker($compiler_ctx);
-
-       my $rules_ctx;
-       $output .= _prepare_default_rule($rules_ctx);
-
-       my $suffix_ctx;
-       $output .= _prepare_SUFFIXES($suffix_ctx);
-
+       $output .= _prepare_path_vars();
+       $output .= _prepare_compiler_linker();
+       $output .= _prepare_default_rule();
+       $output .= _prepare_SUFFIXES();
        $output .= _prepare_dummy_MAKEDIR();
+       $output .= _prepare_std_CC_rule("c","o",$config{PICFLAG},"Compiling","Rule for std objectfiles");
+       $output .= _prepare_std_CC_rule("h","h.gch",$config{PICFLAG},"Precompiling","Rule for precompiled headerfiles");
 
-       $output .= _prepare_std_CC_rule("c","o",'@PICFLAG@',"Compiling","Rule for std objectfiles");
-       $output .= _prepare_std_CC_rule("h","h.gch",'@PICFLAG@',"Precompiling","Rule for precompiled headerfiles");
-
+       $output .= _prepare_depend_CC_rule();
+       
        $output .= _prepare_man_rule("1");
        $output .= _prepare_man_rule("3");
        $output .= _prepare_man_rule("5");
        $output .= _prepare_man_rule("7");
-
        $output .= _prepare_manpages($CTX);
-
+       $output .= _prepare_binaries($CTX);
        $output .= _prepare_target_settings($CTX);
-
        $output .= _prepare_rule_lists($CTX);
-
-       my @all = ();
-       
-       foreach my $part (values %{$CTX}) {
-               push (@all, $part->{TARGET}) if defined ($part->{OUTPUT_TYPE}) and $part->{OUTPUT_TYPE} eq "BINARY";    
+       $output .= _prepare_config_status();
+
+       if ($config{developer} eq "yes") {
+               $output .= <<__EOD__
+#-include \$(_ALL_OBJS_OBJS:.o=.d)
+IDL_FILES = \$(wildcard librpc/idl/*.idl)
+\$(patsubst librpc/idl/%.idl,librpc/gen_ndr/ndr_%.c,\$(IDL_FILES)) \\
+\$(patsubst librpc/idl/%.idl,librpc/gen_ndr/ndr_\%_c.c,\$(IDL_FILES)) \\
+\$(patsubst librpc/idl/%.idl,librpc/gen_ndr/ndr_%.h,\$(IDL_FILES)): idl
+__EOD__
        }
-       
-       $output .= _prepare_make_target({ TARGET => "all", DEPEND_LIST => \@all });
 
        return $output;
 }
@@ -871,15 +641,13 @@ sub _prepare_makefile_in($$)
 # $output -            the resulting output buffer
 sub create_makefile_in($$$)
 {
-       my $CTX = shift;
-       my $settings = shift;
-       my $file = shift;
+       my ($CTX, $mk, $file) = @_;
 
        open(MAKEFILE_IN,">$file") || die ("Can't open $file\n");
-       print MAKEFILE_IN _prepare_makefile_in($CTX, $settings);
+       print MAKEFILE_IN _prepare_makefile_in($CTX) . $mk;
        close(MAKEFILE_IN);
 
-       print "config.smb_build.pl: creating $file\n";
+       print "build/smb_build/main.pl: creating $file\n";
        return; 
 }