⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bugzilla.pm

📁 buzilla软件
💻 PM
字号:
# -*- Mode: perl; indent-tabs-mode: nil -*- ## The contents of this file are subject to the Mozilla Public# License Version 1.1 (the "License"); you may not use this file# except in compliance with the License. You may obtain a copy of# the License at http://www.mozilla.org/MPL/## Software distributed under the License is distributed on an "AS# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or# implied. See the License for the specific language governing# rights and limitations under the License.## The Original Code is the Bugzilla Bug Tracking System.## The Initial Developer of the Original Code is Everything Solved.# Portions created by Everything Solved are Copyright (C) 2006# Everything Solved. All Rights Reserved.## Contributor(s): Max Kanat-Alexander <mkanat@bugzilla.org>package Pod::Simple::HTMLBatch::Bugzilla;use strict;use base 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'],    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[<dt><a name="%s">%s</a></dt>\n<dd>\n],                esc($category), esc($category);        print $Contents '<table class="pod_desc_table">' . "\n";        # For every POD...        my $row_count = 0;        foreach my $e (@downlines) {            $row_count++;            my $even_or_odd = $row_count % 2 ? 'even' : 'odd';            my $name = esc($e->[0]);            my $path = join( "/", '.', esc(@{$e->[3]}) )               . $Pod::Simple::HTML::HTML_EXTENSION;            my $description = $self->{bugzilla_desc}->{$name} || '';            my $html = <<END_HTML;<tr class="$even_or_odd">  <th><a href="$path">$name</a></th>  <td>$description</td></tr>END_HTML                  print $Contents $html;        }        print $Contents "</table></dd>\n\n";    }    return 1;}# This stores the name and description for each file, so that# we can get that information out later.sub note_for_contents_file {    my $self = shift;    my $retval = $self->SUPER::note_for_contents_file(@_);    my ($namelets, $infile) = @_;    my $parser   = $self->html_render_class->new;    $parser->set_source($infile);    my $full_title = $parser->get_title;    $full_title =~ /^\S+\s+-+\s+(.+)/;    my $description = $1;        $self->{bugzilla_desc} ||= {};    $self->{bugzilla_desc}->{join('::', @$namelets)} = $description;    return $retval;}1;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -