From: Ian Jackson Date: Sun, 10 Nov 2019 20:39:57 +0000 (+0000) Subject: WIP X-Git-Tag: subdirmk/0.1~122 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ian/git?p=subdirmk.git;a=commitdiff_plain;h=b16a9009730c94eb255445de02f5a0f75cc2d1de;hp=76778fb3d60050136168d3c0bb22effe3228d322 WIP --- diff --git a/build-aux/subdirmk-setup b/build-aux/subdirmk-setup index 59430c7..ea9cb5b 100755 --- a/build-aux/subdirmk-setup +++ b/build-aux/subdirmk-setup @@ -36,17 +36,40 @@ sub build_tree () { sub target_varname ($$) { my ($var_prefix, $target) = @_; - return $vprefix.'TARGETS'.($target eq 'all' ? '' : "_$target"); + return $var_prefix.'TARGETS'.($target eq 'all' ? '' : "_$target"); +} + +our $writing_output; +our %output_files; + +sub close_any_output_file() { + return unless defined $writing_output; + O->error and die "error writing $writing_output.tmp: $! (?)\n"; + close O or die "error closing $writing_output.tmp: $!\n"; + $writing_output = undef; +} + +sub start_output_file ($) { + close_any_output_file(); + ($writing_output) = @_; + die if $output_files{$writing_output}++; + my $tmp = "$writing_output.tmp"; + open O, ">", $tmp or die "create $tmp: $!\n"; +} + +sub o { + die unless defined $writing_output; + print O @_ or die "error writing $writing_output.tmp: $!\n"; } sub write_makefile ($$) { my ($dir_prefix,$depth) = @_; start_output_file("${dir_prefix}Makefile"); my $cd = $depth ? join('/', ('..',) x $depth) : '.'; - o <