From fb612d54c1df7e45d174060c1cbdf060accceb6d Mon Sep 17 00:00:00 2001 From: Junio C Hamano Date: Mon, 7 Nov 2005 22:21:21 -0800 Subject: [PATCH] Documentation: fix dependency generation. The previous rule misses the case where git.txt or tutorial.txt includes new files. Signed-off-by: Junio C Hamano --- Documentation/Makefile | 3 +-- Documentation/build-docdep.perl | 44 ++++++++++++++++++++++++++------- 2 files changed, 36 insertions(+), 11 deletions(-) diff --git a/Documentation/Makefile b/Documentation/Makefile index f45a06246..be4f3e13c 100644 --- a/Documentation/Makefile +++ b/Documentation/Makefile @@ -53,8 +53,7 @@ install: man # # Determine "include::" file references in asciidoc files. # -TEXTFILES = $(wildcard git-*.txt) -doc.dep : $(TEXTFILES) build-docdep.perl +doc.dep : $(wildcard *.txt) build-docdep.perl rm -f $@+ $@ perl ./build-docdep.perl >$@+ mv $@+ $@ diff --git a/Documentation/build-docdep.perl b/Documentation/build-docdep.perl index dedef765a..6ff35e02f 100755 --- a/Documentation/build-docdep.perl +++ b/Documentation/build-docdep.perl @@ -1,28 +1,54 @@ #!/usr/bin/perl my %include = (); +my %included = (); -for my $text () { +for my $text (<*.txt>) { open I, '<', $text || die "cannot read: $text"; - (my $base = $text) =~ s/\.txt$//; while () { if (/^include::/) { chomp; s/^include::\s*//; s/\[\]//; - $include{$base}{$_} = 1; + $include{$text}{$_} = 1; + $included{$_} = 1; } } close I; } # Do we care about chained includes??? - -while (my ($base, $included) = each %include) { - my ($suffix) = '1'; - if ($base eq 'git') { - $suffix = '7'; # yuck... +my $changed = 1; +while ($changed) { + $changed = 0; + while (my ($text, $included) = each %include) { + print STDERR "Looking at $text...\n"; + for my $i (keys %$included) { + print STDERR "$text includes $i.\n"; + # $text has include::$i; if $i includes $j + # $text indirectly includes $j. + if (exists $include{$i}) { + print STDERR "$i includes something.\n"; + for my $j (keys %{$include{$i}}) { + print STDERR "$text includes $i include $j\n"; + if (!exists $include{$text}{$j}) { + $include{$text}{$j} = 1; + $included{$j} = 1; + $changed = 1; + } + } + } + } } - print "$base.html $base.$suffix : ", join(" ", keys %$included), "\n"; } +while (my ($text, $included) = each %include) { + if (! exists $included{$text} && + (my $base = $text) =~ s/\.txt$//) { + my ($suffix) = '1'; + if ($base eq 'git') { + $suffix = '7'; # yuck... + } + print "$base.html $base.$suffix : ", join(" ", keys %$included), "\n"; + } +} -- 2.30.2