[FFmpeg-cvslog] doc: add script to compute texi files dependencies

Stefano Sabatini git at videolan.org
Wed Jul 3 11:28:27 CEST 2013


ffmpeg | branch: master | Stefano Sabatini <stefasab at gmail.com> | Tue May 28 21:52:33 2013 +0200| [628ceac6526724d35cb390cc1f88344f4ea22eb4] | committer: Stefano Sabatini

doc: add script to compute texi files dependencies

Replace the inline awk script with a Perl script which tracks the
dependencies recursively.

This allows to correctly track dependencies for files including files
with a second level include (for example: ffmpeg-devices.texi ->
devices.texi -> outdevs.texi).

This also adds a dependency on perl for computing the dependencies, which
should not be a problem since perl is already required all the way for
building documentation.

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=628ceac6526724d35cb390cc1f88344f4ea22eb4
---

 configure      |    4 ++--
 doc/Makefile   |    2 +-
 doc/texidep.pl |   22 ++++++++++++++++++++++
 3 files changed, 25 insertions(+), 3 deletions(-)

diff --git a/configure b/configure
index dd6e951..97f6913 100755
--- a/configure
+++ b/configure
@@ -2214,8 +2214,8 @@ ffserver_extralibs='$ldl'
 # documentation
 podpages_deps="perl"
 manpages_deps="perl pod2man"
-htmlpages_deps="texi2html"
-txtpages_deps="makeinfo"
+htmlpages_deps="perl texi2html"
+txtpages_deps="perl makeinfo"
 doc_deps_any="manpages htmlpages podpages txtpages"
 
 # default parameters
diff --git a/doc/Makefile b/doc/Makefile
index cd24b8c..ab18146 100644
--- a/doc/Makefile
+++ b/doc/Makefile
@@ -43,7 +43,7 @@ doc: documentation
 apidoc: doc/doxy/html
 documentation: $(DOCS)
 
-TEXIDEP = awk '/^@(verbatim)?include/ { printf "$@: $(@D)/%s\n", $$2 }' <$< >$(@:%=%.d)
+TEXIDEP = perl $(SRC_PATH)/doc/texidep.pl $< $@ >$(@:%=%.d)
 
 doc/%.txt: TAG = TXT
 doc/%.txt: doc/%.texi
diff --git a/doc/texidep.pl b/doc/texidep.pl
new file mode 100644
index 0000000..0275e74
--- /dev/null
+++ b/doc/texidep.pl
@@ -0,0 +1,22 @@
+#! /usr/bin/perl
+
+use warnings;
+use strict;
+
+my ($root, $target) = @ARGV;
+
+sub print_deps {
+    my ($file, $deps) = @_;
+    $deps->{$file} = 1;
+
+    open(my $fh, "$file") or die "Cannot open file '$file': $!";
+    while (<$fh>) {
+        /^@(?:verbatim)?include\s+(\S+)/ and do {
+            die "Circular dependency found in file $root\n" if exists $deps->{"doc/$1"};
+            print "$target: doc/$1\n";
+            print_deps("doc/$1", {%$deps});
+        }
+    }
+}
+
+print_deps($root, {});



More information about the ffmpeg-cvslog mailing list