2 # - config.mk parsing functions
4 # Copyright (C) Stefan (metze) Metzmacher 2004
5 # Copyright (C) Jelmer Vernooij 2005
6 # Released under the GNU GPL
9 package smb_build::config_mk;
23 "OBJ_FILES" => "list",
25 "REQUIRED_SUBSYSTEMS" => "list",
30 "MANPAGE" => "string",
32 "PUBLIC_PROTO_HEADER" => "string",
33 "PRIVATE_PROTO_HEADER" => "string"
36 "SUBSYSTEM" => "string",
38 "INIT_FUNCTION" => "string",
39 "OBJ_FILES" => "list",
41 "REQUIRED_SUBSYSTEMS" => "list",
46 "OUTPUT_TYPE" => "string",
48 "MANPAGE" => "string",
49 "PRIVATE_PROTO_HEADER" => "string"
52 "OBJ_FILES" => "list",
54 "REQUIRED_SUBSYSTEMS" => "list",
59 "MANPAGE" => "string",
60 "INSTALLDIR" => "string",
61 "PRIVATE_PROTO_HEADER" => "string"
64 "MAJOR_VERSION" => "string",
65 "MINOR_VERSION" => "string",
66 "RELEASE_VERSION" => "string",
68 "OBJ_FILES" => "list",
70 "DESCRIPTION" => "string",
72 "REQUIRED_SUBSYSTEMS" => "list",
77 "MANPAGE" => "string",
79 "PUBLIC_HEADERS" => "list",
81 "PUBLIC_PROTO_HEADER" => "string",
82 "PRIVATE_PROTO_HEADER" => "string"
86 use vars qw(@parsed_files);
90 ###########################################################
91 # The parsing function which parses the file
93 # $result = _parse_config_mk($filename)
95 # $filename - the path of the config.mk file
96 # which should be parsed
97 sub run_config_mk($$$)
99 sub run_config_mk($$$);
100 my ($input, $srcdir, $filename) = @_;
104 my $section = "GLOBAL";
107 push (@parsed_files, $srcdir."/".$filename);
109 open(CONFIG_MK, $srcdir."/".$filename) or die("Can't open `$srcdir/$filename'\n");
110 my @lines = <CONFIG_MK>;
119 # lines beginning with '#' are ignored
130 if ($line =~ /^\[([a-zA-Z0-9_:]+)\][\t ]*$/)
138 if ($line =~ /^include (.*)$/) {
139 $makefile .= run_config_mk($input, $srcdir, dirname($filename)."/$1");
144 if ($line =~ /^[ \t]*$/) {
146 if ($infragment) { $makefile.="\n"; }
150 # global stuff is considered part of the makefile
151 if ($section eq "GLOBAL") {
159 if ($line =~ /^([a-zA-Z0-9_]+)[\t ]*=(.*)$/) {
160 $result->{$section}{$1}{VAL} = $2;
161 $result->{$section}{$1}{KEY} = $1;
166 die("$srcdir."/".$filename:$linenum: Bad line while parsing $srcdir."/".$filename");
169 foreach my $section (keys %{$result}) {
170 my ($type, $name) = split(/::/, $section, 2);
172 my $sectype = $section_types->{$type};
173 if (not defined($sectype)) {
174 die($srcdir."/".$filename.":[".$section."] unknown section type \"".$type."\"!");
177 $input->{$name}{NAME} = $name;
178 $input->{$name}{TYPE} = $type;
179 $input->{$name}{BASEDIR} = dirname($filename);
181 foreach my $key (values %{$result->{$section}}) {
182 $key->{VAL} = smb_build::input::strtrim($key->{VAL});
183 my $vartype = $sectype->{$key->{KEY}};
184 if (not defined($vartype)) {
185 die($srcdir."/".$filename.":[".$section."]: unknown attribute type \"$key->{KEY}\"!");
187 if ($vartype eq "string") {
188 $input->{$name}{$key->{KEY}} = $key->{VAL};
189 } elsif ($vartype eq "list") {
190 $input->{$name}{$key->{KEY}} = [smb_build::input::str2array($key->{VAL})];
191 } elsif ($vartype eq "bool") {
192 if (($key->{VAL} ne "YES") and ($key->{VAL} ne "NO")) {
193 die("Invalid value for bool attribute $key->{KEY}: $key->{VAL} in section $section");
195 $input->{$name}{$key->{KEY}} = $key->{VAL};