# This Source Code Form is subject to the terms of the Mozilla Public # License, v. 2.0. If a copy of the MPL was not distributed with this # file, You can obtain one at http://mozilla.org/MPL/2.0/. # # This Source Code Form is "Incompatible With Secondary Licenses", as # defined by the Mozilla Public License, v. 2.0. package Pod::Simple::HTMLBatch::Bugzilla; use 5.14.0; use strict; use warnings; use parent qw(Pod::Simple::HTMLBatch); # This is the same hack that HTMLBatch does to "import" this subroutine. BEGIN { *esc = \&Pod::Simple::HTML::esc } # Describes how top-level modules should be sorted and named. This # is a translation from HTMLBatch's names to our categories. # Note that if you leave out a category here, it will not be indexed # in the contents file, even though its HTML POD will still exist. use constant FILE_TRANSLATION => { Files => ['importxml', 'contrib', 'checksetup', 'email_in', 'install-module', 'sanitycheck', 'jobqueue', 'migrate', 'collectstats'], Modules => ['bugzilla'], Extensions => ['extensions'], }; # This is basically copied from Pod::Simple::HTMLBatch, and overridden # so that we can format things more nicely. sub _write_contents_middle { my ($self, $Contents, $outfile, $toplevel2submodules) = @_; my $file_trans = FILE_TRANSLATION; # For every top-level category... foreach my $category (sort keys %$file_trans) { # Get all of the HTMLBatch categories that should be in this # category. my @category_data; foreach my $b_category (@{$file_trans->{$category}}) { my $data = $toplevel2submodules->{$b_category}; push(@category_data, @$data) if $data; } next unless @category_data; my @downlines = sort {$a->[-1] cmp $b->[-1]} @category_data; # And finally, actually print out the table for this category. printf $Contents qq[
$name | $description | END_HTML print $Contents $html; } print $Contents "
---|