END
}
-sub process_input_mk ($$$$$$$);
-sub process_input_mk ($$$$$$$) {
+sub process_input_mk ($$$$$$$$);
+sub process_input_mk ($$$$$$$$) {
my ($dir_prefix, $dir_suffix, $dir_name,
$var_prefix, $targets,
- $f, $esclitr) = @_;
+ $f, $esclitr, $enoent_ok) = @_;
my $caps_re = qr{[A-Z][0-9_A-Z]*(?=\W)};
my $lc_re = qr{[a-z][-+,0-9_a-z]*(?=\W)};
};
$set_esc->();
- open I, '<', $f or die "open $f: $!\n";
- while (<I>) {
+ my $input = new IO::File $f, '<';
+ if (!$input) {
+ die "open $f: $!\n" unless $!==ENOENT && $enoent_ok;
+ return;
+ }
+ while (<$input>) {
+ if (s#^\s*$esc\:##) {
+ $buffering_output='';
+ }
for (;;) {
unless (s{^(.*?)(\\)?(?=$esc)}{}) { o $_; last; }
o $1;
die "bad escape $$esclitr$_ ";
}
}
+ if (defined $buffering_output) {
+ $_=$buffering_output;
+ $buffering_output=undef;
+ if (m#^(-?)include\s+(\S+)\s+$#) {
+ my $subf = "$srcdir/$2";
+ o "MAKEFILE_TEMPLATES += $subf\n";
+ process_input_mk($dir_prefix, $dir_suffix, $dir_name,
+ $var_prefix, $targets,
+ $subf, $esclitr, $subf);
+ o "\n";
+ } else {
+ die "unknown directive $_ ";
+ }
+ }
}
- I->error and die "read $f: $!\n";
+ $input->error and die "read $f: $!\n";
+ close $input or die "close $f: $!\n";
}
sub filter_subdir_mk ($$$$$) {
#print STDERR "filter @_\n";
my $esclit = '&';
- for my $f ("${srcdir}/${dir_prefix}Subdir.mk.in",
- "${srcdir}/Perdir.mk.in") {
+
+ my $pi = sub {
+ my ($f, $enoentok) = @_;
process_input_mk($dir_prefix, $dir_suffix, $dir_name,
$var_prefix, $targets,
- $f, \$esclit);
- }
+ "${srcdir}/$f", \$esclit, $enoentok);
+ };
+ $pi->("${dir_prefix}Subdir.mk.in", 0);
+ $pi->("Perdir.mk.in", 0);
}
sub process_subtree ($$);