Merge branch 'v4-0-trivial' into v4-0-gmake3
authorJelmer Vernooij <jelmer@samba.org>
Mon, 18 Feb 2008 21:25:19 +0000 (22:25 +0100)
committerJelmer Vernooij <jelmer@samba.org>
Mon, 18 Feb 2008 21:25:19 +0000 (22:25 +0100)
Conflicts:

source/build/smb_build/input.pm
source/build/smb_build/main.pl
source/build/smb_build/makefile.pm
(This used to be commit bc11e3ef1c34923f5b13571926617a840ad554fe)

1  2 
source4/build/smb_build/config_mk.pm
source4/build/smb_build/input.pm
source4/build/smb_build/main.pl
source4/build/smb_build/makefile.pm
source4/rules.mk

index 027c7ff6d67376f2934bebc5f8e083bdec06ce80,4d8db8a04ea54418a9ed74049d19ffc4174f1693..70520554abdef8cd030e6fb656ec99b5dd726ae0
@@@ -18,7 -18,6 +18,6 @@@ my $section_types = 
                "CFLAGS"                => "list",
                "CPPFLAGS"              => "list",
                "LDFLAGS"               => "list",
-               "PC_NAME" => "string",
                },
        "PYTHON" => {
                SWIG_FILE => "string",
@@@ -90,7 -89,6 +89,6 @@@
                "SO_VERSION"            => "string",
                "LIBRARY_REALNAME" => "string",
  
-               "PC_NAME" => "string",
                "PC_FILE" => "string",
                
                "INIT_FUNCTION_TYPE"    => "string",
@@@ -241,13 -239,12 +239,13 @@@ sub run_config_mk($$$$
                }
  
                # include
-               if ($line =~ /^include (.*)$/) {
+               if ($line =~ /^mkinclude (.*)$/) {
                        my $subfile= $1;
                        my $subdir = dirname($filename);
                        $subdir =~ s/^\.$//g;
                        $subdir =~ s/^\.\///g;
                        $subdir .= "/" if ($subdir ne "");
 +                      $makefile .= "basedir := $subdir\n";
                        $makefile .= run_config_mk($input, $srcdir, $builddir, $subdir.$subfile);
                        next;
                }
                        $infragment = 1;
                        next;
                }
 -
                
                # Assignment
                if ($line =~ /^([a-zA-Z0-9_]+)[\t ]*=(.*)$/) {
index 6be48fcc670bf5b4cf22b51e49eca2866cd51558,da90e9db48e95402f162c5278964f4221c86c79a..9aef1c10021fc0b09b4fe038e40d45c7f926b5f1
@@@ -5,13 -5,10 +5,10 @@@
  #  Copyright (C) Jelmer Vernooij 2004
  #  Released under the GNU GPL
  
- use smb_build::config;
  use strict;
  package smb_build::input;
  use File::Basename;
  
- my $srcdir = $config::config{srcdir};
  sub strtrim($)
  {
        $_ = shift;
@@@ -60,10 -57,7 +57,7 @@@ sub check_subsystem($$$
        my ($INPUT, $subsys, $default_ot) = @_;
        return if ($subsys->{ENABLE} ne "YES");
        
-       unless(defined($subsys->{OUTPUT_TYPE})) {
-               $subsys->{OUTPUT_TYPE} = $default_ot;
-       }
+       unless (defined($subsys->{OUTPUT_TYPE})) { $subsys->{OUTPUT_TYPE} = $default_ot; }
        unless (defined($subsys->{INIT_FUNCTION_TYPE})) { $subsys->{INIT_FUNCTION_TYPE} = "NTSTATUS (*) (void)"; }
        unless (defined($subsys->{INIT_FUNCTION_SENTINEL})) { $subsys->{INIT_FUNCTION_SENTINEL} = "NULL"; }
  }
@@@ -79,11 -73,11 +73,11 @@@ sub check_module($$$
        }
  
        if (!(defined($INPUT->{$mod->{SUBSYSTEM}}))) {
-               $mod->{ENABLE} = "NO";
-               return;
+               die("Unknown subsystem $mod->{SUBSYSTEM} for module $mod->{NAME}");
        }
  
        if ($INPUT->{$mod->{SUBSYSTEM}} eq "NO") {
+               warn("Disabling module $mod->{NAME} because subsystem $mod->{SUBSYSTEM} is disabled");
                $mod->{ENABLE} = "NO";
                return;
        }
@@@ -98,7 -92,7 +92,7 @@@
  
        if (not defined($mod->{OUTPUT_TYPE})) {
                if ($INPUT->{$mod->{SUBSYSTEM}}->{TYPE} eq "EXT_LIB") {
-                       $mod->{OUTPUT_TYPE} = ["SHARED_LIBRARY"];
+                       $mod->{OUTPUT_TYPE} = undef;
                } else {
                        $mod->{OUTPUT_TYPE} = $default_ot;
                }
                push (@{$mod->{PUBLIC_DEPENDENCIES}}, $mod->{SUBSYSTEM});
                add_libreplace($mod);
        } 
-       if (grep(/INTEGRATED/, @{$mod->{OUTPUT_TYPE}})) {
+       if (grep(/MERGED_OBJ/, @{$mod->{OUTPUT_TYPE}})) {
                push (@{$INPUT->{$mod->{SUBSYSTEM}}{INIT_FUNCTIONS}}, $mod->{INIT_FUNCTION}) if defined($mod->{INIT_FUNCTION});
+               unshift (@{$INPUT->{$mod->{SUBSYSTEM}}{PRIVATE_DEPENDENCIES}}, $mod->{NAME});
        }
  }
  
@@@ -159,8 -154,8 +154,8 @@@ sub check_python($$$
                $python->{OBJ_FILES} = ["$dirname$basename\_wrap.o"];
                $python->{LIBRARY_REALNAME} = "_$basename.\$(SHLIBEXT)";
                $python->{PYTHON_FILES} = ["$dirname$basename.py"];
-               push (@{$python->{CFLAGS}}, $config::config{CFLAG_NO_UNUSED_MACROS});
-               push (@{$python->{CFLAGS}}, $config::config{CFLAG_NO_CAST_QUAL});
+               push (@{$python->{CFLAGS}}, "\$(CFLAG_NO_UNUSED_MACROS)");
+               push (@{$python->{CFLAGS}}, "\$(CFLAG_NO_CAST_QUAL)");
                $python->{INIT_FUNCTION} = "{ (char *)\"_$basename\", init_$basename }";
        } else {
                my $basename = $python->{NAME};
                $python->{LIBRARY_REALNAME} = "$basename.\$(SHLIBEXT)";
                $python->{INIT_FUNCTION} = "{ (char *)\"$basename\", init$basename }";
        }
-       push (@{$python->{CFLAGS}}, @{$INPUT->{EXT_LIB_PYTHON}->{CFLAGS}});
+       push (@{$python->{CFLAGS}}, "\$(EXT_LIB_PYTHON_CFLAGS)");
  
        $python->{SUBSYSTEM} = "LIBPYTHON";
  
@@@ -187,26 -182,6 +182,6 @@@ sub check_binary($$
        add_libreplace($bin);
  }
  
- sub import_integrated($$)
- {
-       my ($lib, $depend) = @_;
-       foreach my $mod (values %$depend) {
-               next if(not defined($mod->{OUTPUT_TYPE}));
-               next if(not grep(/INTEGRATED/, @{$mod->{OUTPUT_TYPE}}));
-               next if(not defined($mod->{SUBSYSTEM}));
-               next if($mod->{SUBSYSTEM} ne $lib->{NAME});
-               next if($mod->{ENABLE} ne "YES");
-               push (@{$lib->{LINK_FLAGS}}, "\$($mod->{NAME}_LINK_FLAGS)");
-               push (@{$lib->{CFLAGS}}, @{$mod->{CFLAGS}}) if defined($mod->{CFLAGS});
-               push (@{$lib->{PUBLIC_DEPENDENCIES}}, @{$mod->{PUBLIC_DEPENDENCIES}}) if defined($mod->{PUBLIC_DEPENDENCIES});
-               push (@{$lib->{PRIVATE_DEPENDENCIES}}, @{$mod->{PRIVATE_DEPENDENCIES}}) if defined($mod->{PRIVATE_DEPENDENCIES});
-               $mod->{ENABLE} = "NO";
-       }
- }
  sub add_implicit($$)
  {
        my ($INPUT, $n) = @_;
        $INPUT->{$n} = {
                TYPE => "MAKE_RULE",
                NAME => $n,
-               TARGET => lc($n),
-               LIBS => "\$(".uc($n)."_LIBS)",
-               CFLAGS => "\$(".uc($n)."_CFLAG)"
+               TARGET => "",
+               OUTPUT_TYPE => undef,
+               LIBS => ["\$(".uc($n)."_LIBS)"],
+               LDFLAGS => ["\$(".uc($n)."_LDFLAGS)"],
+               CFLAGS => ["\$(".uc($n)."_CFLAGS)"],
+               CPPFLAGS => ["\$(".uc($n)."_CPPFLAGS)"]
        };
  }
  
@@@ -227,15 -205,17 +205,17 @@@ sub calc_unique_deps($$$$$$$$
  
        foreach my $n (@$deps) {
                add_implicit($INPUT, $n) unless (defined($INPUT->{$n}));
-               die("Recursive dependency: $n, list: " . join(',', @$busy)) if (grep (/^$n$/, @$busy));
-               next if (grep /^$n$/, @$udeps);
                my $dep = $INPUT->{$n};
+               if (grep (/^$n$/, @$busy)) {
+                       next if (@{$dep->{OUTPUT_TYPE}}[0] eq "MERGED_OBJ");
+                       die("Recursive dependency: $n, list: " . join(',', @$busy));
+               }
+               next if (grep /^$n$/, @$udeps);
  
                push (@{$udeps}, $dep->{NAME}) if $forward;
  
                if (defined ($dep->{OUTPUT_TYPE}) && 
                        ($withlibs or 
-                       (@{$dep->{OUTPUT_TYPE}}[0] eq "INTEGRATED") or 
                        (@{$dep->{OUTPUT_TYPE}}[0] eq "MERGED_OBJ") or 
                        (@{$dep->{OUTPUT_TYPE}}[0] eq "STATIC_LIBRARY"))) {
                                push (@$busy, $dep->{NAME});
@@@ -285,6 -265,7 +265,6 @@@ sub check($$$$$
  
        foreach my $part (values %$INPUT) {
                $part->{LINK_FLAGS} = [];
 -              $part->{FULL_OBJ_LIST} = ["\$($part->{NAME}_OBJ_LIST)"];
  
                if ($part->{TYPE} eq "SUBSYSTEM") { 
                        check_subsystem($INPUT, $part, $subsys_ot);
                if (defined($part->{INIT_FUNCTIONS})) {
                        push (@{$part->{LINK_FLAGS}}, "\$(DYNEXP)");
                }
-               import_integrated($part, $INPUT);
        }
  
        foreach my $part (values %$INPUT) {
index 3911a117734b9b7efbdda8b2c0bf3112e30e728c,3ed0327d6d7fef90c7adff22d1abe16dd359cef3..c6031e23e6326fcd51b8b599b4c05f091e29c7a5
@@@ -6,6 -6,7 +6,6 @@@
  #  Released under the GNU GPL                         
  
  use smb_build::makefile;
 -use smb_build::header;
  use smb_build::input;
  use smb_build::config_mk;
  use smb_build::output;
@@@ -18,9 -19,7 +18,7 @@@ use strict
  my $INPUT = {};
  my $mkfile = smb_build::config_mk::run_config_mk($INPUT, $config::config{srcdir}, $config::config{builddir}, "main.mk");
  
- my $subsys_output_type;
- $subsys_output_type = ["MERGED_OBJ"];
- #$subsys_output_type = ["STATIC_LIBRARY"];
+ my $subsys_output_type = ["MERGED_OBJ"];
  
  my $library_output_type;
  if ($config::config{USESHARED} eq "true") {
@@@ -35,7 -34,7 +33,7 @@@ my $module_output_type
  if ($config::config{USESHARED} eq "true") {
        $module_output_type = ["SHARED_LIBRARY"];
  } else {
-       $module_output_type = ["INTEGRATED"];
+       $module_output_type = ["MERGED_OBJ"];
  }
  
  my $DEPEND = smb_build::input::check($INPUT, \%config::enabled,
                                     $library_output_type,
                                     $module_output_type);
  my $OUTPUT = output::create_output($DEPEND, \%config::config);
- $config::config{SUBSYSTEM_OUTPUT_TYPE} = $subsys_output_type;
- $config::config{LIBRARY_OUTPUT_TYPE} = $library_output_type;
- $config::config{MODULE_OUTPUT_TYPE} = $module_output_type;
  my $mkenv = new smb_build::makefile(\%config::config, $mkfile);
  
  my $shared_libs_used = 0;
+ foreach my $key (values %$OUTPUT) {
+       $mkenv->_prepare_list($key, "OBJ_LIST");
+       push(@{$mkenv->{all_objs}}, "\$($key->{NAME}_OBJ_LIST)");
+ }
  
  foreach my $key (values %$OUTPUT) {
        next unless defined $key->{OUTPUT_TYPE};
  
 +      $mkenv->StaticLibraryPrimitives($key) if grep(/STATIC_LIBRARY/, @{$key->{OUTPUT_TYPE}});
        $mkenv->MergedObj($key) if grep(/MERGED_OBJ/, @{$key->{OUTPUT_TYPE}});
 -      $mkenv->StaticLibrary($key) if grep(/STATIC_LIBRARY/, @{$key->{OUTPUT_TYPE}});
        if (defined($key->{PC_FILE})) {
 -              push(@{$mkenv->{pc_files}}, "$key->{BASEDIR}/$key->{PC_FILE}");
 +              $mkenv->output("PC_FILES += $key->{BASEDIR}/$key->{PC_FILE}\n");
        } 
        $mkenv->SharedLibraryPrimitives($key) if ($key->{TYPE} eq "LIBRARY") and
                                        grep(/SHARED_LIBRARY/, @{$key->{OUTPUT_TYPE}});
        $mkenv->PythonFiles($key) if defined($key->{PYTHON_FILES});
        $mkenv->Manpage($key) if defined($key->{MANPAGE});
        $mkenv->Header($key) if defined($key->{PUBLIC_HEADERS});
 -      $mkenv->ProtoHeader($key) if defined($key->{PRIVATE_PROTO_HEADER}) or 
 -                                       defined($key->{PUBLIC_PROTO_HEADER});
  }
  
  foreach my $key (values %$OUTPUT) {
        next unless defined $key->{OUTPUT_TYPE};
  
 +      $mkenv->Integrated($key) if grep(/INTEGRATED/, @{$key->{OUTPUT_TYPE}});
 +}
 +
 +foreach my $key (values %$OUTPUT) {
 +      next unless defined $key->{OUTPUT_TYPE};
 +
 +      $mkenv->StaticLibrary($key) if grep(/STATIC_LIBRARY/, @{$key->{OUTPUT_TYPE}});
        $mkenv->SharedLibrary($key) if ($key->{TYPE} eq "LIBRARY") and
                                        grep(/SHARED_LIBRARY/, @{$key->{OUTPUT_TYPE}});
        $mkenv->SharedModule($key) if ($key->{TYPE} eq "MODULE" or 
                                                                   $key->{TYPE} eq "PYTHON") and
                                        grep(/SHARED_LIBRARY/, @{$key->{OUTPUT_TYPE}});
        $mkenv->Binary($key) if grep(/BINARY/, @{$key->{OUTPUT_TYPE}});
 +      $mkenv->ProtoHeader($key) if defined($key->{PRIVATE_PROTO_HEADER}) or 
 +                                       defined($key->{PUBLIC_PROTO_HEADER});
 +      $mkenv->InitFunctions($key) if defined($key->{INIT_FUNCTIONS});
  }
  
  $mkenv->write("data.mk");
 -header::create_smb_build_h($OUTPUT, "include/build.h");
  
  cflags::create_cflags($OUTPUT, $config::config{srcdir},
                    $config::config{builddir}, "extra_cflags.txt");
index 072e3c0c4bdef22b2fbeda1642d7ae75ebb6a620,d11e761ce14f6094423c3e62677b72796674d545..5fd9f359ee3fbdfdbe96bb32e7f8511fd968e73c
@@@ -21,6 -21,17 +21,6 @@@ sub new($$$
        
        bless($self, $myname);
  
 -      $self->{manpages} = [];
 -      $self->{sbin_progs} = [];
 -      $self->{bin_progs} = [];
 -      $self->{static_libs} = [];
 -      $self->{python_dsos} = [];
 -      $self->{python_pys} = [];
 -      $self->{shared_libs} = [];
 -      $self->{headers} = [];
 -      $self->{plugins} = [];
 -      $self->{pc_files} = [];
 -      $self->{proto_headers} = [];
        $self->{output} = "";
  
        $self->{mkfile} = $mkfile;
@@@ -101,19 -112,6 +101,6 @@@ sub _prepare_list($$$
        $self->output("$ctx->{NAME}_$var =$tmplist\n");
  }
  
- sub Integrated($$)
- {
-       my ($self,$ctx) = @_;
-       $self->_prepare_list($ctx, "OBJ_LIST");
-       $self->output("$ctx->{SUBSYSTEM}_OBJ_LIST += \$($ctx->{NAME}_OBJ_LIST)\n");
-       if(defined($ctx->{INIT_FUNCTION})) {
-               my $init_fn = $ctx->{INIT_FUNCTION};
-               $init_fn =~ s/"/\\\"/g;
-               $self->output("$ctx->{SUBSYSTEM}_INIT_FUNCTIONS += \"$init_fn,\"\n");
-       }
- }
  sub SharedModulePrimitives($$)
  {
        my ($self,$ctx) = @_;
@@@ -125,19 -123,23 +112,19 @@@ sub SharedModule($$
  {
        my ($self,$ctx) = @_;
  
 -      my $init_obj = "";
 -
        my $sane_subsystem = lc($ctx->{SUBSYSTEM});
        $sane_subsystem =~ s/^lib//;
        
        if ($ctx->{TYPE} eq "PYTHON") {
 -              push (@{$self->{python_dsos}}, 
 -                      "$ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}");
 +              $self->output("PYTHON_DSOS += $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}\n");
        } else {
 -              push (@{$self->{plugins}}, "$ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}");
 +              $self->output("PLUGINS += $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}\n");
                $self->output("installplugins:: $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}\n");
                $self->output("\t\@echo Installing $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME} as \$(DESTDIR)\$(modulesdir)/$sane_subsystem/$ctx->{LIBRARY_REALNAME}\n");
                $self->output("\t\@mkdir -p \$(DESTDIR)\$(modulesdir)/$sane_subsystem/\n");
                $self->output("\t\@cp $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME} \$(DESTDIR)\$(modulesdir)/$sane_subsystem/$ctx->{LIBRARY_REALNAME}\n");
                if (defined($ctx->{ALIASES})) {
                        foreach (@{$ctx->{ALIASES}}) {
 -                              $self->output("\t\@rm -f \$(DESTDIR)\$(modulesdir)/$sane_subsystem/$_.\$(SHLIBEXT)\n");
                                $self->output("\t\@ln -fs $ctx->{LIBRARY_REALNAME} \$(DESTDIR)\$(modulesdir)/$sane_subsystem/$_.\$(SHLIBEXT)\n");
                        }
                }
        }
  
        $self->output("$ctx->{NAME}_OUTPUT = $ctx->{OUTPUT}\n");
-       $self->_prepare_list($ctx, "OBJ_LIST");
+       $self->_prepare_list($ctx, "FULL_OBJ_LIST");
        $self->_prepare_list($ctx, "DEPEND_LIST");
        $self->_prepare_list($ctx, "LINK_FLAGS");
  
        if (defined($ctx->{INIT_FUNCTION}) and $ctx->{TYPE} ne "PYTHON") {
 -              my $init_fn = $ctx->{INIT_FUNCTION_TYPE};
 -              $init_fn =~ s/\(\*\)/init_module/;
 -              my $proto_fn = $ctx->{INIT_FUNCTION_TYPE};
 -              $proto_fn =~ s/\(\*\)/$ctx->{INIT_FUNCTION}/;
 -
 -              $self->output(<< "__EOD__"
 -bin/$ctx->{NAME}_init_module.c:
 -      \@echo Creating \$\@
 -      \@echo \"#include \\\"includes.h\\\"\" > \$\@
 -      \@echo \"$proto_fn;\" >> \$\@
 -      \@echo \"_PUBLIC_ $init_fn\" >> \$\@
 -      \@echo \"{\" >> \$\@
 -      \@echo \"       return $ctx->{INIT_FUNCTION}();\" >> \$\@
 -      \@echo \"}\" >> \$\@
 -      \@echo \"\" >> \$\@
 -__EOD__
 -);
 -              $init_obj = "bin/$ctx->{NAME}_init_module.o";
 +              $self->output("\$($ctx->{NAME}_OBJ_LIST): CFLAGS+=-D$ctx->{INIT_FUNCTION}=init_module\n");
        }
  
        $self->output(<< "__EOD__"
 -#
  
 -$ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}: \$($ctx->{NAME}_DEPEND_LIST) \$($ctx->{NAME}_FULL_OBJ_LIST) $init_obj
 +$ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}: \$($ctx->{NAME}_DEPEND_LIST) \$($ctx->{NAME}_OBJ_LIST)
        \@echo Linking \$\@
 -      \@mkdir -p $ctx->{SHAREDDIR}
 +      \@mkdir -p \$(\@D)
        \@\$(MDLD) \$(MDLD_FLAGS) \$(INTERN_LDFLAGS) -o \$\@ \$(INSTALL_LINK_FLAGS) \\
 -              \$($ctx->{NAME}\_FULL_OBJ_LIST) $init_obj \\
 +              \$($ctx->{NAME}\_OBJ_LIST) \\
                \$($ctx->{NAME}_LINK_FLAGS)
  __EOD__
  );
  
        if (defined($ctx->{ALIASES})) {
                foreach (@{$ctx->{ALIASES}}) {
 -                      $self->output("\t\@rm -f $ctx->{SHAREDDIR}/$_.\$(SHLIBEXT)\n");
                        $self->output("\t\@ln -fs $ctx->{LIBRARY_REALNAME} $ctx->{SHAREDDIR}/$_.\$(SHLIBEXT)\n");
                }
        }
@@@ -190,7 -211,7 +177,7 @@@ sub SharedLibraryPrimitives($$
  
        if (not grep(/STATIC_LIBRARY/, @{$ctx->{OUTPUT_TYPE}})) {
                $self->output("$ctx->{NAME}_OUTPUT = $ctx->{OUTPUT}\n");
-               $self->_prepare_list($ctx, "OBJ_LIST");
+               $self->_prepare_list($ctx, "FULL_OBJ_LIST");
        }
  }
  
@@@ -198,109 -219,109 +185,118 @@@ sub SharedLibrary($$
  {
        my ($self,$ctx) = @_;
  
-       $self->output("SHARED_LIBS += $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}\n") if (defined($ctx->{SO_VERSION}));
 -      push (@{$self->{shared_libs}}, $ctx->{RESULT_SHARED_LIBRARY}) if (defined($ctx->{SO_VERSION}));
++      $self->output("SHARED_LIBS += $ctx->{RESULT_SHARED_LIBRARY}\n") if (defined($ctx->{SO_VERSION}));
  
        $self->_prepare_list($ctx, "DEPEND_LIST");
        $self->_prepare_list($ctx, "LINK_FLAGS");
  
 -      my $soarg = "";
 -      my $lns = "";
 -      if ($self->{config}->{SONAMEFLAG} ne "#" and defined($ctx->{LIBRARY_SONAME})) {
 -              $soarg = "$self->{config}->{SONAMEFLAG}$ctx->{LIBRARY_SONAME}";
 -              if ($ctx->{LIBRARY_REALNAME} ne $ctx->{LIBRARY_SONAME}) {
 -                      $lns .= "\n\t\@test \$($ctx->{NAME}_VERSION) = \$($ctx->{NAME}_SOVERSION) || ln -fs $ctx->{LIBRARY_REALNAME} $ctx->{SHAREDDIR}/$ctx->{LIBRARY_SONAME}";
 -              }
 -      }
 -
 -      if (defined($ctx->{LIBRARY_SONAME})) {
 -              $lns .= "\n\t\@ln -fs $ctx->{LIBRARY_REALNAME} $ctx->{SHAREDDIR}/$ctx->{LIBRARY_DEBUGNAME}";
 -      }
 -
        $self->output(<< "__EOD__"
 -#
 +
- $ctx->{SHAREDDIR}/$ctx->{LIBRARY_REALNAME}: \$($ctx->{NAME}_DEPEND_LIST) \$($ctx->{NAME}_OBJ_LIST)
+ $ctx->{RESULT_SHARED_LIBRARY}: \$($ctx->{NAME}_DEPEND_LIST) \$($ctx->{NAME}_FULL_OBJ_LIST)
        \@echo Linking \$\@
        \@mkdir -p $ctx->{SHAREDDIR}
        \@\$(SHLD) \$(SHLD_FLAGS) \$(INTERN_LDFLAGS) -o \$\@ \$(INSTALL_LINK_FLAGS) \\
 -              \$($ctx->{NAME}\_FULL_OBJ_LIST) \\
 +              \$($ctx->{NAME}\_OBJ_LIST) \\
                \$($ctx->{NAME}_LINK_FLAGS) \\
 -              $soarg$lns
 +              \$(if \$(SONAMEFLAG), \$(SONAMEFLAG)$ctx->{LIBRARY_SONAME})
  __EOD__
  );
 -      $self->output("\n");
 +      if ($ctx->{LIBRARY_REALNAME} ne $ctx->{LIBRARY_SONAME}) {
 +              $self->output("\t\@test \$($ctx->{NAME}_VERSION) = \$($ctx->{NAME}_SOVERSION) || ln -fs $ctx->{LIBRARY_REALNAME} $ctx->{SHAREDDIR}/$ctx->{LIBRARY_SONAME}\n");
 +      }
 +      $self->output("ifdef $ctx->{NAME}_SOVERSION\n");
 +      $self->output("\t\@ln -fs $ctx->{LIBRARY_REALNAME} $ctx->{SHAREDDIR}/$ctx->{LIBRARY_DEBUGNAME}\n");
 +      $self->output("endif\n");
  }
  
  sub MergedObj($$)
  {
        my ($self, $ctx) = @_;
  
+       return unless defined($ctx->{OUTPUT});
        $self->output("$ctx->{NAME}_OUTPUT = $ctx->{OUTPUT}\n");
-       $self->_prepare_list($ctx, "OBJ_LIST");
-       $self->_prepare_list($ctx, "FULL_OBJ_LIST");
-       push(@{$self->{all_objs}}, "\$($ctx->{NAME}_FULL_OBJ_LIST)");
        $self->output(<< "__EOD__"
  #
- $ctx->{TARGET_MERGED_OBJ}: \$($ctx->{NAME}_FULL_OBJ_LIST)
+ $ctx->{RESULT_MERGED_OBJ}: \$($ctx->{NAME}_OBJ_LIST)
        \@echo Partially linking \$@
        \@mkdir -p bin/mergedobj
-       \$(PARTLINK) -o \$@ \$($ctx->{NAME}_FULL_OBJ_LIST)
+       \$(PARTLINK) -o \$@ \$($ctx->{NAME}_OBJ_LIST)
  
  __EOD__
  );
  }
  
 -sub StaticLibrary($$)
 +sub StaticLibraryPrimitives($$)
  {
        my ($self,$ctx) = @_;
  
        return unless (defined($ctx->{OBJ_FILES}));
  
-       $self->_prepare_list($ctx, "OBJ_LIST");
+       push (@{$self->{static_libs}}, $ctx->{RESULT_STATIC_LIBRARY}) if ($ctx->{TYPE} eq "LIBRARY");
+       $self->output("$ctx->{NAME}_OUTPUT = $ctx->{OUTPUT}\n");
+       $self->_prepare_list($ctx, "FULL_OBJ_LIST");
 +}
  
 +sub InitFunctions($$)
 +{
 +      my ($self, $ctx) = @_;
 +      $self->output("\$($ctx->{NAME}_OBJ_LIST): CFLAGS+=-DSTATIC_$ctx->{NAME}_MODULES=\"\$($ctx->{NAME}_INIT_FUNCTIONS)$ctx->{INIT_FUNCTION_SENTINEL}\"\n");
 +}
 +
 +sub StaticLibrary($$)
 +{
 +      my ($self,$ctx) = @_;
+       $self->output(<< "__EOD__"
+ #
+ $ctx->{RESULT_STATIC_LIBRARY}: \$($ctx->{NAME}_FULL_OBJ_LIST)
+       \@echo Linking \$@
+       \@rm -f \$@
+       \@mkdir -p $ctx->{STATICDIR}
+       \@\$(STLD) \$(STLD_FLAGS) \$@ \$($ctx->{NAME}_FULL_OBJ_LIST)
  
 -__EOD__
 -);
 +      return unless (defined($ctx->{OBJ_FILES}));
 +
 +      $self->output("STATIC_LIBS += $ctx->{TARGET_STATIC_LIBRARY}\n") if ($ctx->{TYPE} eq "LIBRARY");
 +      $self->output("$ctx->{NAME}_OUTPUT = $ctx->{OUTPUT}\n");
 +      $self->output("$ctx->{TARGET_STATIC_LIBRARY}: \$($ctx->{NAME}_OBJ_LIST)\n");
  }
  
  sub Header($$)
  {
        my ($self,$ctx) = @_;
  
 +      return if ($#{$ctx->{PUBLIC_HEADERS}} == -1);
 +
 +      $self->output("PUBLIC_HEADERS +=");
 +
        foreach (@{$ctx->{PUBLIC_HEADERS}}) {
 -              push (@{$self->{headers}}, output::add_dir_str($ctx->{BASEDIR}, $_));
 +              $self->output(" " . output::add_dir_str($ctx->{BASEDIR}, $_));
        }
 +
 +      $self->output("\n");
  }
  
  sub Binary($$)
  {
        my ($self,$ctx) = @_;
  
 -      my $extradir = "";
 -
        unless (defined($ctx->{INSTALLDIR})) {
        } elsif ($ctx->{INSTALLDIR} eq "SBINDIR") {
-               $self->output("SBIN_PROGS += bin/$ctx->{BINARY}\n");
 -              push (@{$self->{sbin_progs}}, $ctx->{RESULT_BINARY});
++              $self->output("SBIN_PROGS += $ctx->{RESULT_BINARY}\n");
        } elsif ($ctx->{INSTALLDIR} eq "BINDIR") {
-               $self->output("BIN_PROGS += bin/$ctx->{BINARY}\n");
 -              push (@{$self->{bin_progs}}, $ctx->{RESULT_BINARY});
++              $self->output("BIN_PROGS += $ctx->{RESULT_BINARY}\n");
        }
  
-       $self->output("binaries:: bin/$ctx->{BINARY}\n");
+       $self->output("binaries:: $ctx->{TARGET_BINARY}\n");
  
-       $self->_prepare_list($ctx, "OBJ_LIST");
+       $self->_prepare_list($ctx, "FULL_OBJ_LIST");
        $self->_prepare_list($ctx, "DEPEND_LIST");
        $self->_prepare_list($ctx, "LINK_FLAGS");
  
  $self->output(<< "__EOD__"
bin/$ctx->{BINARY}: \$($ctx->{NAME}_DEPEND_LIST) \$($ctx->{NAME}_OBJ_LIST)
$ctx->{RESULT_BINARY}: \$($ctx->{NAME}_DEPEND_LIST) \$($ctx->{NAME}_FULL_OBJ_LIST)
        \@echo Linking \$\@
  __EOD__
        );
@@@ -328,8 -349,10 +324,8 @@@ sub PythonFiles($$
        foreach (@{$ctx->{PYTHON_FILES}}) {
                my $target = "bin/python/".basename($_);
                my $source = output::add_dir_str($ctx->{BASEDIR}, $_);
 -              $self->output("$target: $source\n" .
 -                                        "\tmkdir -p \$(builddir)/bin/python\n" .
 -                            "\tcp $source \$@\n\n");
 -              push (@{$self->{python_pys}}, $target);
 +              $self->output("$target: $source\n\n");
 +              $self->output("PYTHON_PYS += $target\n");
        }
  }
  
@@@ -337,7 -360,8 +333,7 @@@ sub Manpage($$
  {
        my ($self,$ctx) = @_;
  
 -      my $path = output::add_dir_str($ctx->{BASEDIR}, $ctx->{MANPAGE});
 -      push (@{$self->{manpages}}, $path);
 +      $self->output("MANPAGES += " . output::add_dir_str($ctx->{BASEDIR}, $ctx->{MANPAGE}) . "\n");
  }
  
  sub ProtoHeader($$)
                        $comment .= " and ";
                        $target.= " ";
                }
 -              push (@{$self->{proto_headers}}, $priv);
 +              $self->output("PROTO_HEADERS += $priv\n");
        } else {
                $ctx->{PRIVATE_PROTO_HEADER} = $ctx->{PUBLIC_PROTO_HEADER};
                $priv = output::add_dir_str($ctx->{BASEDIR}, $ctx->{PRIVATE_PROTO_HEADER});
                $pub = output::add_dir_str($ctx->{BASEDIR}, $ctx->{PUBLIC_PROTO_HEADER});
                $comment .= $pub;
                $target .= $pub;
 -              push (@{$self->{proto_headers}}, $pub);
 +              $self->output("PROTO_HEADERS += $pub\n");
        } else {
                $ctx->{PUBLIC_PROTO_HEADER} = $ctx->{PRIVATE_PROTO_HEADER};
                $pub = output::add_dir_str($ctx->{BASEDIR}, $ctx->{PUBLIC_PROTO_HEADER});
@@@ -383,6 -407,19 +379,6 @@@ sub write($$
  {
        my ($self, $file) = @_;
  
 -      $self->output("MANPAGES = " . array2oneperline($self->{manpages})."\n");
 -      $self->output("BIN_PROGS = " . array2oneperline($self->{bin_progs}) . "\n");
 -      $self->output("SBIN_PROGS = " . array2oneperline($self->{sbin_progs}) . "\n");
 -      $self->output("STATIC_LIBS = " . array2oneperline($self->{static_libs}) . "\n");
 -      $self->output("SHARED_LIBS = " . array2oneperline($self->{shared_libs}) . "\n");
 -      $self->output("PYTHON_DSOS = " . array2oneperline($self->{python_dsos}) . "\n");
 -      $self->output("PYTHON_PYS = " . array2oneperline($self->{python_pys}) . "\n");
 -      $self->output("PUBLIC_HEADERS = " . array2oneperline($self->{headers}) . "\n");
 -      $self->output("PC_FILES = " . array2oneperline($self->{pc_files}) . "\n");
 -      $self->output("ALL_OBJS = " . array2oneperline($self->{all_objs}) . "\n");
 -      $self->output("PROTO_HEADERS = " . array2oneperline($self->{proto_headers}) .  "\n");
 -      $self->output("PLUGINS = " . array2oneperline($self->{plugins}) . "\n");
 -
        $self->_prepare_mk_files();
  
        $self->output($self->{mkfile});
diff --combined source4/rules.mk
index 506d4c04318133f33f86fe343e87d0fab4c81534,b6a54fae255c3f8b03b91a1568407f67d292e5b7..9791466712368350492dec554b05917706377751
@@@ -66,7 -66,7 +66,7 @@@ clean:: clean_pc
        @-rm -f $(BIN_PROGS) $(SBIN_PROGS) $(BINARIES) $(TORTURE_PROGS)
        @echo Removing libraries
        @-rm -f $(STATIC_LIBRARIES) $(SHARED_LIBRARIES)
-       @-rm -f bin/static/*.a bin/shared/*.$(SHLIBEXT)
+       @-rm -f bin/static/*.a bin/shared/*.$(SHLIBEXT) bin/mergedobj/*.o
        @echo Removing modules
        @-rm -f bin/modules/*/*.$(SHLIBEXT)
        @-rm -f bin/*_init_module.c
@@@ -100,13 -100,6 +100,13 @@@ check:: tes
  unused_macros:
        $(srcdir)/script/find_unused_macros.pl `find . -name "*.[ch]"` | sort
  
 +# Create a static library
 +%.a:
 +      @echo Linking $@
 +      @rm -f $@
 +      @mkdir -p $(@D)
 +      @$(STLD) $(STLD_FLAGS) $@ $^
 +
  ###############################################################################
  # File types
  ###############################################################################