diff options
author | Junio C Hamano <junkio@cox.net> | 2005-11-07 22:21:21 -0800 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2005-11-08 00:23:12 -0800 |
commit | fb612d54c1df7e45d174060c1cbdf060accceb6d (patch) | |
tree | 39f34d76dfc1f8bd2120ac591a33c022a0cc5180 | |
parent | b2d09f063a01b429fe1e8d5179d00f3938ec598b (diff) | |
download | git-fb612d54c1df7e45d174060c1cbdf060accceb6d.tar.gz |
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 <junkio@cox.net>
-rw-r--r-- | Documentation/Makefile | 3 | ||||
-rwxr-xr-x | Documentation/build-docdep.perl | 44 |
2 files changed, 36 insertions, 11 deletions
diff --git a/Documentation/Makefile b/Documentation/Makefile index f45a062469..be4f3e13c6 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 dedef765af..6ff35e02fa 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 (<git-*.txt>) { +for my $text (<*.txt>) { open I, '<', $text || die "cannot read: $text"; - (my $base = $text) =~ s/\.txt$//; while (<I>) { 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"; + } +} |