1 ###########################################################
2 ### SMB Build System ###
3 ### - config.mk parsing functions ###
5 ### Copyright (C) Stefan (metze) Metzmacher 2004 ###
6 ### Released under the GNU GPL ###
7 ###########################################################
9 package smb_build::config_mk;
23 "INIT_FUNCTION" => "string",
24 "INIT_OBJ_FILES" => "list",
25 "ADD_OBJ_FILES" => "list",
26 "OBJ_FILES" => "list",
28 "REQUIRED_SUBSYSTEMS" => "list",
29 "TARGET_DEPS" => "list",
34 "MANPAGE" => "string",
37 "SUBSYSTEM" => "string",
39 "INIT_FUNCTION" => "string",
40 "INIT_OBJ_FILES" => "list",
41 "ADD_OBJ_FILES" => "list",
42 "OBJ_FILES" => "list",
44 "REQUIRED_SUBSYSTEMS" => "list",
45 "TARGET_DEPS" => "list",
50 "MANPAGE" => "string",
53 "OBJ_FILES" => "list",
55 "REQUIRED_SUBSYSTEMS" => "list",
56 "TARGET_DEPS" => "list",
61 "MANPAGE" => "string",
62 "INSTALLDIR" => "string",
65 "MAJOR_VERSION" => "string",
66 "MINOR_VERSION" => "string",
67 "RELEASE_VERSION" => "string",
68 "INIT_OBJ_FILES" => "list",
69 "ADD_OBJ_FILES" => "list",
70 "OBJ_FILES" => "list",
72 "REQUIRED_SUBSYSTEMS" => "list",
73 "TARGET_DEPS" => "list",
78 "MANPAGE" => "string",
80 "PUBLIC_HEADERS" => "list"
84 use vars qw(@parsed_files);
88 ###########################################################
89 # The parsing function which parses the file
91 # $result = _parse_config_mk($filename)
93 # $filename - the path of the config.mk file
94 # which should be parsed
97 sub run_config_mk($$);
98 my ($input, $filename) = @_;
102 my $section = "GLOBAL";
105 push (@parsed_files, $filename);
107 open(CONFIG_MK, $filename) or die("Can't open `$filename'\n");
108 my @lines = <CONFIG_MK>;
117 # lines beginning with '#' are ignored
128 if ($line =~ /^\[([a-zA-Z0-9_:]+)\][\t ]*$/)
136 if ($line =~ /^include (.*)$/) {
137 $makefile .= run_config_mk($input, dirname($filename)."/$1");
142 if ($line =~ /^[ \t]*$/) {
144 if ($infragment) { $makefile.="\n"; }
148 # global stuff is considered part of the makefile
149 if ($section eq "GLOBAL") {
157 if ($line =~ /^([a-zA-Z0-9_]+)[\t ]*=(.*)$/) {
158 $result->{$section}{$1}{VAL} = $2;
159 $result->{$section}{$1}{KEY} = $1;
164 die("$filename:$linenum: Bad line while parsing $filename");
167 foreach my $section (keys %{$result}) {
168 my ($type, $name) = split(/::/, $section, 2);
170 my $sectype = $section_types->{$type};
171 if (not defined($sectype)) {
172 die($filename.":[".$section."] unknown section type \"".$type."\"!");
175 $input->{$name}{NAME} = $name;
176 $input->{$name}{TYPE} = $type;
177 $input->{$name}{BASEDIR} = dirname($filename);
179 foreach my $key (values %{$result->{$section}}) {
180 $key->{VAL} = smb_build::input::strtrim($key->{VAL});
181 my $vartype = $sectype->{$key->{KEY}};
182 if (not defined($vartype)) {
183 die($filename.":[".$section."]: unknown attribute type \"$key->{KEY}\"!");
185 if ($vartype eq "string") {
186 $input->{$name}{$key->{KEY}} = $key->{VAL};
187 } elsif ($vartype eq "list") {
188 $input->{$name}{$key->{KEY}} = [smb_build::input::str2array($key->{VAL})];
189 } elsif ($vartype eq "bool") {
190 if (($key->{VAL} ne "YES") and ($key->{VAL} ne "NO")) {
191 die("Invalid value for bool attribute $key->{KEY}: $key->{VAL} in section $section");
193 $input->{$name}{$key->{KEY}} = $key->{VAL};