2 # - the input checking functions
4 # Copyright (C) Stefan (metze) Metzmacher 2004
5 # Copyright (C) Jelmer Vernooij 2004
6 # Released under the GNU GPL
9 package smb_build::input;
28 return () if (length($_)==0);
29 return split /[ \t\n]/;
32 sub check_subsystem($$$)
34 my ($INPUT, $subsys, $default_ot) = @_;
35 if ($subsys->{ENABLE} ne "YES") {
36 printf("Subsystem `%s' disabled\n",$subsys->{NAME});
40 unless(defined($subsys->{OUTPUT_TYPE})) {
41 $subsys->{OUTPUT_TYPE} = $default_ot;
47 my ($INPUT, $mod, $default_ot) = @_;
49 die("Module $mod->{NAME} does not have a SUBSYSTEM set") if not defined($mod->{SUBSYSTEM});
53 if (not exists($INPUT->{$mod->{SUBSYSTEM}}{INIT_FUNCTIONS})) {
54 $INPUT->{$mod->{SUBSYSTEM}}{INIT_FUNCTIONS} = [];
57 if (!(defined($INPUT->{$mod->{SUBSYSTEM}}))) {
58 $mod->{ENABLE} = "NO";
62 if ($mod->{ENABLE} ne "YES")
64 printf("Module `%s' disabled\n",$mod->{NAME});
68 if (defined($mod->{CHOSEN_BUILD}) and $mod->{CHOSEN_BUILD} ne "DEFAULT")
70 $mod->{OUTPUT_TYPE} = $mod->{CHOSEN_BUILD};
72 $mod->{OUTPUT_TYPE} = $default_ot;
75 if ($mod->{OUTPUT_TYPE} eq "SHARED_LIBRARY") {
76 $mod->{INSTALLDIR} = "LIBDIR/$mod->{SUBSYSTEM}";
77 push (@{$mod->{REQUIRED_SUBSYSTEMS}}, $mod->{SUBSYSTEM});
79 push (@{$INPUT->{$mod->{SUBSYSTEM}}{REQUIRED_SUBSYSTEMS}}, $mod->{NAME});
80 push (@{$INPUT->{$mod->{SUBSYSTEM}}{INIT_FUNCTIONS}}, $mod->{INIT_FUNCTION}) if defined($mod->{INIT_FUNCTION});
84 sub check_library($$$)
86 my ($INPUT, $lib, $default_ot) = @_;
88 if ($lib->{ENABLE} ne "YES") {
89 printf("Library `%s' disabled\n",$lib->{NAME});
93 $lib->{OUTPUT_TYPE} = $default_ot;
95 unless (defined($lib->{MAJOR_VERSION})) {
96 print "$lib->{NAME}: Please specify MAJOR_VERSION\n";
100 $lib->{INSTALLDIR} = "LIBDIR";
105 my ($INPUT, $bin) = @_;
107 if ($bin->{ENABLE} ne "YES") {
108 printf("Binary `%s' disabled\n",$bin->{NAME});
112 ($bin->{BINARY} = (lc $bin->{NAME})) if not defined($bin->{BINARY});
114 $bin->{OUTPUT_TYPE} = "BINARY";
117 sub calc_unique_deps($$)
119 sub calc_unique_deps($$);
120 my ($deps, $udeps) = @_;
122 foreach my $dep (@{$deps}) {
123 if (not defined($udeps->{$$dep->{NAME}})) {
124 if (defined ($$dep->{OUTPUT_TYPE}) && (($$dep->{OUTPUT_TYPE} eq "OBJ_LIST")
125 or ($$dep->{OUTPUT_TYPE} eq "MERGEDOBJ"))) {
126 $udeps->{$$dep->{NAME}} = "BUSY";
127 calc_unique_deps($$dep->{DEPENDENCIES}, $udeps);
129 $udeps->{$$dep->{NAME}} = $$dep;
136 my ($INPUT, $enabled, $subsys_ot, $lib_ot, $module_ot) = @_;
138 foreach my $part (values %$INPUT) {
139 unless(defined($part->{NOPROTO})) {
140 $part->{NOPROTO} = "NO";
143 if (defined($enabled->{$part->{NAME}})) {
144 $part->{ENABLE} = $enabled->{$part->{NAME}};
148 unless(defined($part->{ENABLE})) {
149 $part->{ENABLE} = "YES";
153 foreach my $k (keys %$INPUT) {
154 my $part = $INPUT->{$k};
156 check_subsystem($INPUT, $part, $subsys_ot) if ($part->{TYPE} eq "SUBSYSTEM");
157 check_module($INPUT, $part, $module_ot) if ($part->{TYPE} eq "MODULE");
158 check_library($INPUT, $part, $lib_ot) if ($part->{TYPE} eq "LIBRARY");
159 check_binary($INPUT, $part) if ($part->{TYPE} eq "BINARY");
162 my %depend = %$INPUT;
164 foreach my $part (values %depend) {
166 # Generate list of dependencies
167 $part->{DEPENDENCIES} = [];
169 foreach my $key (@{$part->{REQUIRED_SUBSYSTEMS}}) {
170 die("$part->{NAME} has undefined dependency $key\n") if not defined($depend{$key});
171 push (@{$part->{DEPENDENCIES}}, \$depend{$key});
174 delete ($part->{REQUIRED_SUBSYSTEMS});
177 foreach my $part (values %depend) {
178 $part->{UNIQUE_DEPENDENCIES} = {};
179 calc_unique_deps($part->{DEPENDENCIES}, $part->{UNIQUE_DEPENDENCIES});