| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- #! /usr/bin/perl
- # Intended to generate an index of classnames to references in the manual (using the interfacename and classname elements).
- #
- # Builds an index of classnames to Javadoc (or src xref) links, from the allclasses-frame.html file.
- # Processes the ref manual docbook files, building an index of classname to section ids where the class is referenced
- #
- #
- use strict;
- # Get list of links to class src packages from Javadoc
- #system("curl http://static.springsource.org/spring-security/site/docs/3.0.x/apidocs/allclasses-frame.html > allclasses-frame.html");
- # Manual front page gives us section numbers
- #system("curl http://static.springsource.org/spring-security/site/docs/3.0.x/reference/springsecurity.html > springsecurity.html");
- my $index_page = `cat springsecurity.html`;
- my @all_classes = `cat allclasses-frame.html`;
- $#all_classes > 0 || die "No lines in Javadoc";
- # Src XREF format
- #<a href="org/springframework/security/vote/AbstractAccessDecisionManager.html" target="classFrame">AbstractAccessDecisionManager</a>
- # Javadoc format
- #<A HREF="org/springframework/security/acls/afterinvocation/AbstractAclProvider.html" title="class in org.springframework.security.acls.afterinvocation" target="classFrame">AbstractAclProvider</A>
- my %classnames_to_src;
- print "Extracting classnames to links map from Javadoc...\n";
- while ($_ = pop @all_classes) {
- chomp;
- # Get rid of the italic tags round interface names
- $_ =~ s/<I>//;
- $_ =~ s/<\/I>//;
- next unless $_ =~ /<A HREF="(.*)" title=.*>(([a-zA-Z0-9_]+?))<\/A>.*/;
- # print "Adding class $1, $2\n";
- $classnames_to_src{$2} = $1;
- }
- #my @docbook = glob("*.xml");
- # The list of docbook files xincluded in the manual
- my @docbook;
- print "Building list of docbook source files...\n";
- # Read the includes rather than using globbing to get the ordering right for the index.
- open MAINDOC, "<springsecurity.xml";
- while(<MAINDOC>) {
- if (/href="(.*\.xml)"/) {
- push @docbook, $1;
- }
- }
- # Hash of xml:id (i.e. anchor) to filename.html#anchor
- my %id_to_html;
- # Build map of html pages links
- print "Building map of section xml:ids to reference manual links...\n";
- while (my $file = pop @docbook) {
- open FILE, $file or die "$!";
- # print "\nProcessing: $file\n\n";
- my $file_id;
- while(<FILE>) {
- if (/.* xml:id="([a-z0-9-]+?)"/) {
- $file_id = $1;
- last;
- }
- }
- $id_to_html{$file_id} = "$file_id.html";
-
- while (<FILE>) {
- next unless /.* xml:id="([a-z0-9-]+?)"/;
- # print "$1\n";
- $id_to_html{$1} = "$file_id.html#$1";
- }
- close FILE;
- }
- # Get the list of class/interface names and their section ids/titles
- print "Obtaining class and interface references from manual...\n";
- my @class_references = split /;/,`xsltproc --xinclude index-classes.xsl springsecurity.xml`;
- # Get unique values
- my %seen = ();
- @class_references = grep { !$seen{$_}++} @class_references;
- print "There are $#class_references references to classes and interfaces.\n";
- my %id_to_title;
- my %classnames_to_ids = ();
- foreach my $class_id_title (@class_references) {
- (my $class, my $id, my $title) = split /:/, $class_id_title;
- $title =~ s/</</;
- $title =~ s/>/>/;
- $id_to_title{$id} = $title;
- push( @{$classnames_to_ids{$class}}, $id );
- }
- print "Writing index file...\n";
- open INDEX, ">classindex.xml" || die "Couldn't open output file\n";
- print INDEX "<index>\n";
- foreach my $class (sort keys %classnames_to_ids) {
- print INDEX "<class name='$class'";
- if (exists $classnames_to_src{$class}) {
- print INDEX " src-xref='$classnames_to_src{$class}'";
- }
- print INDEX ">\n";
- foreach my $id (@{$classnames_to_ids{$class}}) {
- my $href = $id_to_html{$id};
- $index_page =~ /$href">([AB0-9\.]* )/;
- my $section = $1 ? "$1" : "";
- # print "$id $href $section\n";
- my $title = $id_to_title{$id};
- # print "$section$title\n";
- print INDEX " <link href='$href' title='$section$title'/>\n";
- }
- print INDEX "</class>\n"
-
- }
- print INDEX "</index>\n";
- close INDEX;
- print "Generating HTML file...\n";
- system("xsltproc class-index-html.xsl classindex.xml > class-index.html");
|