X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ian/git?p=subdirmk.git;a=blobdiff_plain;f=build-aux%2Fsubdirmk-setup;h=ea9cb5b8b36230fd2b9e3d536416b8a44708a5bf;hp=59430c7cc987977d9f866ae5f0b491903782f4de;hb=b16a9009730c94eb255445de02f5a0f75cc2d1de;hpb=76778fb3d60050136168d3c0bb22effe3228d322 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 <