r8955: Move a bit more of the build process to the Makefile
[sfrench/samba-autobuild/.git] / source4 / build / smb_build / makefile.pm
index 68d4f23b1e18580044b3f547dd85121639ee8efb..1ccdb3239dbcd183f89e826d03c9dc7c5f82308c 100644 (file)
@@ -7,6 +7,7 @@
 ###########################################################
 
 package makefile;
+use config qw(%config);
 use strict;
 
 sub _prepare_command_interpreters($)
@@ -37,8 +38,9 @@ BINDIR = @bindir@
 SBINDIR = @sbindir@
 LIBDIR = @libdir@
 CONFIGDIR = @configdir@
-VARDIR = @localstatedir@
+localstatedir = @localstatedir@
 SWATDIR = @swatdir@
+VARDIR = @localstatedir@
 
 # The permissions to give the executables
 INSTALLPERMS = 0755
@@ -61,17 +63,15 @@ LOCKDIR = @lockdir@
 # the directory where pid files go
 PIDDIR = @piddir@
 
-PASSWD_FLAGS = -DSMB_PASSWD_FILE=\"$(SMB_PASSWD_FILE)\" -DPRIVATE_DIR=\"$(PRIVATEDIR)\"
-PATH_FLAGS1 = -DCONFIGFILE=\"$(CONFIGFILE)\"  -DSBINDIR=\"$(SBINDIR)\"
-PATH_FLAGS2 = $(PATH_FLAGS1) -DBINDIR=\"$(BINDIR)\" 
-PATH_FLAGS3 = $(PATH_FLAGS2) -DLMHOSTSFILE=\"$(LMHOSTSFILE)\" 
-PATH_FLAGS4 = $(PATH_FLAGS3) -DLOCKDIR=\"$(LOCKDIR)\" -DPIDDIR=\"$(PIDDIR)\"
-PATH_FLAGS5 = $(PATH_FLAGS4) -DLIBDIR=\"$(LIBDIR)\" \
-             -DLOGFILEBASE=\"$(LOGFILEBASE)\" -DSHLIBEXT=\"@SHLIBEXT@\"
-PATH_FLAGS6 = $(PATH_FLAGS5) -DCONFIGDIR=\"$(CONFIGDIR)\" -DNCALRPCDIR=\"$(NCALRPCDIR)\"
-PATH_FLAGS7 = $(PATH_FLAGS6) -DSWATDIR=\"$(SWATDIR)\"
-PATH_FLAGS = $(PATH_FLAGS7) $(PASSWD_FLAGS)
+MANDIR = @mandir@
 
+PATH_FLAGS = -DCONFIGFILE=\"$(CONFIGFILE)\"  -DSBINDIR=\"$(SBINDIR)\" \
+        -DBINDIR=\"$(BINDIR)\" -DLMHOSTSFILE=\"$(LMHOSTSFILE)\" \
+        -DLOCKDIR=\"$(LOCKDIR)\" -DPIDDIR=\"$(PIDDIR)\" -DLIBDIR=\"$(LIBDIR)\" \
+        -DLOGFILEBASE=\"$(LOGFILEBASE)\" -DSHLIBEXT=\"@SHLIBEXT@\" \
+        -DCONFIGDIR=\"$(CONFIGDIR)\" -DNCALRPCDIR=\"$(NCALRPCDIR)\" \
+        -DSWATDIR=\"$(SWATDIR)\" -DSMB_PASSWD_FILE=\"$(SMB_PASSWD_FILE)\" \
+        -DPRIVATE_DIR=\"$(PRIVATEDIR)\"
 __EOD__
 
        return $output;
@@ -85,7 +85,7 @@ sub _prepare_compiler_linker($)
 CC=@CC@
 CFLAGS=-Iinclude -I. -I$(srcdir)/include -I$(srcdir) -D_SAMBA_BUILD_ -DHAVE_CONFIG_H -Ilib @CFLAGS@ @CPPFLAGS@
 
-LD=@CC@
+LD=@LD@
 LD_FLAGS=@LDFLAGS@ @CFLAGS@ -Lbin
 
 STLD=ar
@@ -94,23 +94,14 @@ STLD_FLAGS=-rc
 SHLD=@CC@
 SHLD_FLAGS=@LDSHFLAGS@ @LDFLAGS@ -Lbin
 
-__EOD__
-}
-
+XSLTPROC=@XSLTPROC@
 
-#############################
-# return makefile fragment for 
-# target specific rules
-sub add_target_flags($$)
-{
-       my $ctx = shift;
-       my $name = shift;
+LEX=@LEX@
+YACC=@YACC@
 
-       return "" unless ($ctx->{TARGET_CFLAGS});
-       return "$name: TARGET_CFLAGS = $ctx->{TARGET_CFLAGS}\n";
+__EOD__
 }
 
-
 sub _prepare_default_rule($)
 {
        my $ctx = shift;
@@ -131,7 +122,7 @@ sub _prepare_SUFFIXES($)
 
        $output = << '__EOD__';
 .SUFFIXES:
-.SUFFIXES: .c .o .h .h.gch .a .so
+.SUFFIXES: .c .et .y .l .d .o .h .h.gch .a .so .1 .1.xml .3 .3.xml .5 .5.xml .7 .7.xml
 
 __EOD__
 
@@ -143,29 +134,75 @@ sub _prepare_IDL($)
        my $ctx = shift;
 
        return << '__EOD__';
-idl_full: build/pidl/idl.pm
-       CPP="@CPP@" PERL="$(PERL)" script/build_idl.sh FULL
+idl_full: build/pidl/Parse/Pidl/IDL.pm
+       CPP="@CPP@" PERL="$(PERL)" script/build_idl.sh FULL @PIDL_ARGS@
+
+idl: build/pidl/Parse/Pidl/IDL.pm
+       @CPP="@CPP@" PERL="$(PERL)" script/build_idl.sh PARTIAL @PIDL_ARGS@
 
-idl: build/pidl/idl.pm
-       @CPP="@CPP@" PERL="$(PERL)" script/build_idl.sh PARTIAL
+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 
 
-build/pidl/idl.pm: build/pidl/idl.yp
-       -yapp -s build/pidl/idl.yp
+smb_interfaces: build/pidl/smb_interfaces.pm
+       $(PERL) -Ibuild/pidl script/build_smb_interfaces.pl \
+               include/smb_interfaces.h
+
+build/pidl/smb_interfaces.pm: build/pidl/smb_interfaces.yp
+       -yapp -s -m 'smb_interfaces' -o build/pidl/smb_interfaces.pm build/pidl/smb_interfaces.yp 
 
 pch: proto include/includes.h.gch
 
 pch_clean:
        -rm -f include/includes.h.gch
 
-basics: idl proto_exists
+basics: idl proto_exists HEIMDAL_EXTERNAL
 
 test: @DEFAULT_TEST_TARGET@
 
 test-swrap: all
-       SOCKET_WRAPPER_DIR=. ./script/tests/selftest.sh `pwd`/prefix-test
+       ./script/tests/selftest.sh @selftest_prefix@/st all SOCKET_WRAPPER
 
 test-noswrap: all
-       ./script/tests/selftest.sh `pwd`/prefix-test
+       ./script/tests/selftest.sh @selftest_prefix@/st all
+
+quicktest: all
+       ./script/tests/selftest.sh @selftest_prefix@/st quick SOCKET_WRAPPER
+
+valgrindtest: all
+       SMBD_VALGRIND="xterm -n smbd -e valgrind -q --db-attach=yes --num-callers=30" \
+       ./script/tests/selftest.sh @selftest_prefix@/st quick SOCKET_WRAPPER
+
+__EOD__
+}
+
+sub _prepare_man_rule($)
+{
+       my $suffix = shift;
+
+       return << "__EOD__";
+.$suffix.xml.$suffix:
+       \$(XSLTPROC) -o \$@ http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl \$<
+
+__EOD__
+}
+
+sub _prepare_manpages($)
+{
+       my $ctx = shift;
+
+       my @mp_list = ();
+
+       foreach (values %$ctx) {
+               if (defined($_->{MANPAGE}) and $_->{MANPAGE} ne "") {
+                       push (@mp_list, $_->{MANPAGE});
+               }
+       }
+       
+       my $mp = join(' ', @mp_list);
+       return << "__EOD__";
+MANPAGES = $mp
+
+manpages: \$(MANPAGES)
 
 __EOD__
 }
@@ -186,6 +223,47 @@ dynconfig.o: dynconfig.c Makefile
 __EOD__
 }
 
+sub _prepare_et_rule()
+{
+       return << '__EOD__';
+
+.et.c: 
+       $(MAKE) bin/compile_et
+       ./bin/compile_et $<
+       mv `basename $@` $@
+
+__EOD__
+}
+
+sub _prepare_yacc_rule()
+{
+       return << '__EOD__';
+.y.c:
+       $(YACC) -d -o $@ $<     
+       
+__EOD__
+}
+
+sub _prepare_lex_rule()
+{
+       return << '__EOD__';
+.l.c:
+       $(LEX) -o $@ $<
+
+__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)
 #
@@ -216,7 +294,7 @@ sub _prepare_std_CC_rule($$$$$)
 # $comment
 .$src.$dst:
        \@echo $message \$\*.$src
-       \@\$(CC) \$(TARGET_CFLAGS) \$(CFLAGS) $flags -c \$< -o \$\@
+       \@\$(CC) `script/cflags.sh \$\@` \$(CFLAGS) $flags -c \$< -o \$\@
 \@BROKEN_CC\@  -mv `echo \$\@ | sed 's%^.*/%%g'` \$\@
 
 __EOD__
@@ -227,16 +305,12 @@ __EOD__
 sub array2oneperline($)
 {
        my $array = shift;
-       my $i;
        my $output = "";
 
-       foreach my $str (@{$array}) {
-               if (!defined($str)) {
-                       next;
-               }
+       foreach (@$array) {
+               next unless defined($_);
 
-               $output .= " \\\n\t\t";
-               $output .= $str;
+               $output .= " \\\n\t\t$_";
        }
 
        return $output;
@@ -248,13 +322,10 @@ sub array2oneline($)
        my $i;
        my $output = "";
 
-       foreach my $str (@{$array}) {
-               if (!defined($str)) {
-                       next;
-               }
+       foreach (@{$array}) {
+               next unless defined($_);
 
-               $output .= $str;
-               $output .= " ";
+               $output .= "$_ ";
        }
 
        return $output;
@@ -273,8 +344,7 @@ 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});
 
@@ -287,8 +357,7 @@ __EOD__
 
 sub _prepare_cflags($$)
 {
-       my $var = shift;
-       my $ctx = shift;
+       my ($var,$ctx) = @_;
 
        my $tmplist = array2oneperline($ctx->{CFLAGS});
 
@@ -329,7 +398,6 @@ sub _prepare_shared_library_rule($)
        my $output;
 
        $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-
        $tmpshlink = array2oneperline($ctx->{LINK_LIST});
        $tmpshflag = array2oneperline($ctx->{LINK_FLAGS});
 
@@ -367,7 +435,26 @@ library_$ctx->{NAME}: basics bin/lib$ctx->{LIBRARY_NAME}
 
 __EOD__
 
-$output .= add_target_flags($ctx, "library_" . $ctx->{NAME});
+       return $output;
+}
+
+sub _prepare_mergedobj_rule($)
+{
+       my $ctx = shift;
+
+       return "" unless $ctx->{TARGET};
+
+       my $output = "";
+
+       my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
+
+       $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 .= "\t\@echo \"Linking subsystem $ctx->{NAME}\"\n";
+       $output .= "\t@\$(LD) -r \$($ctx->{TYPE}_$ctx->{NAME}_OBJS) -o $ctx->{TARGET}\n";
+       $output .= "\n";
 
        return $output;
 }
@@ -376,9 +463,16 @@ sub _prepare_objlist_rule($)
 {
        my $ctx = shift;
        my $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-       return "
-$ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST = $tmpdepend\n
-$ctx->{TYPE}_$ctx->{NAME}: \$($ctx->{TYPE}_$ctx->{NAME}_OBJS) \$($ctx->{TYPE}_$ctx->{NAME}_DEPEND_LIST)\n";
+       my $output;
+
+       return "" unless $ctx->{TARGET};
+
+       $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";
+
+       return $output;
 }
 
 ###########################################################
@@ -410,7 +504,6 @@ sub _prepare_static_library_rule($)
        my $output;
 
        $tmpdepend = array2oneperline($ctx->{DEPEND_LIST});
-
        $tmpstlink = array2oneperline($ctx->{LINK_LIST});
        $tmpstflag = array2oneperline($ctx->{LINK_FLAGS});
 
@@ -428,8 +521,6 @@ library_$ctx->{NAME}: basics $ctx->{TARGET}
 
 __EOD__
 
-$output .= add_target_flags($ctx, "library_" . $ctx->{NAME});
-
        return $output;
 }
 
@@ -469,7 +560,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)
@@ -477,11 +568,21 @@ binary_$ctx->{BINARY}: basics bin/$ctx->{BINARY}
 
 __EOD__
 
-$output .= add_target_flags($ctx, "binary_" . $ctx->{BINARY});
-
        return $output;
 }
 
+sub _prepare_custom_rule($)
+{
+       my $ctx = shift;
+       return "
+$ctx->{NAME}: bin/.TARGET_$ctx->{NAME}
+
+bin/.TARGET_$ctx->{NAME}:
+       $ctx->{CMD}
+       touch bin/.TARGET_$ctx->{NAME}
+";
+}
+
 sub _prepare_proto_rules()
 {
        my $output = "";
@@ -491,20 +592,16 @@ sub _prepare_proto_rules()
 # 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 include/build_env.h
+proto_exists: include/proto.h
 
 delheaders: pch_clean
-       -rm -f $(builddir)/include/proto.h $(builddir)/include/build_env.h:
+       -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)
 
-include/build_env.h:
-       @echo Building include/build_env.h
-       @cd $(srcdir) && $(SHELL) script/build_env.sh $(srcdir) $(builddir) $(CC) > $(builddir)/include/build_env.h
-
 # '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.
@@ -516,24 +613,44 @@ proto_test:
        @[ -f $(builddir)/include/proto.h ] || $(MAKE) proto
 
 clean: delheaders
-       -rm -f *.o */*.o */*/*.o */*/*/*.o bin/*
-       -rm -rf librpc/gen_*
+       @echo Removing objects
+       @-find . -name '*.o' -exec rm -f '{}' \;
+       @echo Removing binaries
+       @-rm -f bin/*
+       @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 
+       -rm -f include/config.h include/smb_build.h
        -rm -f Makefile*
        -rm -f config.status
-       -rm -f config.smb_build.*
        -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 */*/*/*~
 
 realdistclean: distclean removebackup
        -rm -f include/config.h.in
-       -rm -f lib/version.h
+       -rm -f include/version.h
        -rm -f configure
+       -rm -f $(MANPAGES)
 __EOD__
 
        return $output;
@@ -586,9 +703,10 @@ showlayout:
        @echo "  libdir:  $(LIBDIR)"
        @echo "  vardir:  $(VARDIR)"
        @echo "  privatedir:  $(PRIVATEDIR)"
-       @echo "  piddir:  $(PIDDIR)"
+       @echo "  piddir:   $(PIDDIR)"
        @echo "  lockdir:  $(LOCKDIR)"
        @echo "  swatdir:  $(SWATDIR)"
+       @echo "  mandir:   $(MANDIR)"
 
 showflags:
        @echo "Samba will be compiled with flags:"
@@ -602,6 +720,7 @@ SBIN_PROGS = bin/smbd
 BIN_PROGS = bin/smbclient \
                bin/net \
                bin/nmblookup \
+               bin/smbscript \
                bin/ntlm_auth
 
 TORTURE_PROGS = bin/smbtorture \
@@ -619,18 +738,21 @@ LDB_PROGS =       bin/ldbadd \
 REG_PROGS =    bin/regpatch \
                bin/regshell \
                bin/regtree \
-               bin/regpatch \
                bin/regdiff
 
-install: showlayout installbin installtorture installldb installreg installdat installswat
+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 privelege
-# of package each samba release for muliple versions of multiple
+# 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
+# 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
@@ -648,13 +770,22 @@ installldb: all installdirs
 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)
+       @$(SHELL) $(srcdir)/script/installswat.sh $(DESTDIR)$(SWATDIR) $(srcdir) $(DESTDIR)$(LIBDIR)
+
+installmisc: installdirs
+       @$(SHELL) $(srcdir)/script/installmisc.sh $(srcdir) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(BINDIR)
+
+installman: installdirs
+       @$(SHELL) $(srcdir)/script/installman.sh $(DESTDIR)$(MANDIR) $(MANPAGES)
 
-uninstall: uninstallbin uninstalltorture uninstallldb uninstallreg
+uninstall: uninstallbin uninstalltorture uninstallldb uninstallreg uninstallgtk
 
 uninstallbin:
        @$(SHELL) $(srcdir)/script/uninstallbin.sh $(INSTALLPERMS) $(DESTDIR)$(BASEDIR) $(DESTDIR)$(SBINDIR) $(DESTDIR)$(LIBDIR) $(DESTDIR)$(VARDIR) $(DESTDIR)$(SBIN_PROGS)
@@ -668,6 +799,12 @@ uninstallldb:
 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
@@ -711,18 +848,19 @@ sub _prepare_rule_lists($)
        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";
                ($output .= _prepare_binary_rule($key)) if $key->{OUTPUT_TYPE} eq "BINARY";
+               ($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);
 
        return $output;
@@ -738,7 +876,7 @@ sub _prepare_rule_lists($)
 # $output -            the resulting output buffer
 sub _prepare_makefile_in($)
 {
-       my $CTX = shift;
+       my ($CTX) = @_;
        my $output;
 
        $output  = "########################################\n";
@@ -762,12 +900,20 @@ sub _prepare_makefile_in($)
        $output .= _prepare_SUFFIXES($suffix_ctx);
 
        $output .= _prepare_dummy_MAKEDIR();
-
        $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_lex_rule();
+       $output .= _prepare_yacc_rule();
+       $output .= _prepare_et_rule();
 
+       $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_target_settings($CTX);
-
        $output .= _prepare_rule_lists($CTX);
 
        my @all = ();
@@ -778,6 +924,16 @@ sub _prepare_makefile_in($)
        
        $output .= _prepare_make_target({ TARGET => "all", DEPEND_LIST => \@all });
 
+       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__
+       }
+
        return $output;
 }
 
@@ -792,8 +948,7 @@ sub _prepare_makefile_in($)
 # $output -            the resulting output buffer
 sub create_makefile_in($$)
 {
-       my $CTX = shift;
-       my $file = shift;
+       my ($CTX, $file) = @_;
 
        open(MAKEFILE_IN,">$file") || die ("Can't open $file\n");
        print MAKEFILE_IN _prepare_makefile_in($CTX);
@@ -804,3 +959,4 @@ sub create_makefile_in($$)
 }
 
 1;
+