X-Git-Url: https://git.deb.at/?a=blobdiff_plain;ds=sidebyside;f=bin%2Fcreate_index_pages;h=30962ea8653bef1dc4ab969ca8c77ad5b14bc5c9;hb=cfd901631e57f7184e96c132817cbb4de0fd7929;hp=8b20ebd7fcf010be4e0306ea4b18d328a990c965;hpb=e23d2d2080a904ddd6d989a878f3c9b164f0a075;p=deb%2Fpackages.git
diff --git a/bin/create_index_pages b/bin/create_index_pages
index 8b20ebd..30962ea 100755
--- a/bin/create_index_pages
+++ b/bin/create_index_pages
@@ -8,14 +8,17 @@ use File::Path;
use DB_File;
use Storable;
use HTML::Entities;
+use URI::Escape;
use Locale::gettext;
+use Compress::Zlib;
use lib './lib';
use Packages::Config qw( $TOPDIR $DBDIR @ARCHIVES @SUITES @LANGUAGES $LOCALES);
-use Packages::HTML;
+use Packages::Template;
use Packages::I18N::Locale;
use Packages::Page;
+use Packages::SrcPage;
use Packages::Sections;
&Packages::Config::init( './' );
@@ -32,11 +35,15 @@ my $wwwdir = "$TOPDIR/www";
tie my %packages, 'DB_File', "$DBDIR/packages_small.db",
O_RDONLY, 0666, $DB_BTREE
or die "couldn't tie DB $DBDIR/packages_small.db: $!";
+tie my %src_packages, 'DB_File', "$DBDIR/sources_small.db",
+ O_RDONLY, 0666, $DB_BTREE
+ or die "couldn't tie DB $DBDIR/sources_small.db: $!";
+tie my %src2bin, 'DB_File', "$DBDIR/sources_packages.db",
+ O_RDONLY, 0666, $DB_BTREE
+ or die "couldn't open $DBDIR/sources_packages.db: $!";
my $sections = retrieve "$DBDIR/sections.info";
my $subsections = retrieve "$DBDIR/subsections.info";
-# work around problems with non-US security updates
-$subsections->{oldstable}{us}{'non-US'}++;
my $priorities = retrieve "$DBDIR/priorities.info";
#use Data::Dumper;
@@ -44,127 +51,74 @@ my $priorities = retrieve "$DBDIR/priorities.info";
my (%pages);
+my $template = new Packages::Template( "$TOPDIR/templates", 'html', {} );
+
print "write suite index files ...\n";
foreach my $s (@SUITES) {
- foreach my $a (@ARCHIVES) {
- next if $a eq 'security';
- next if $a eq 'non-US';
- my $key = ($a eq 'us') ? $s : "$s/$a";
- my $root = ($a eq 'us') ? '' : '../';
- mkpath ( "$wwwdir/$key" );
- foreach my $lang (@LANGUAGES) {
- my $locale = get_locale( $lang );
- setlocale ( LC_ALL, $locale ) or do {
- warn "couldn't set locale ($lang/$locale)\n";
- next;
- };
- open $pages{$key}{$lang}{index}{fh}, '>', "$wwwdir/$key/index.$lang.html.new"
- or die "can't open index file for output: $!";
- my $index_title = sprintf( _g( "List of sections in \"%s\"" ),
- $key );
- print {$pages{$key}{$lang}{index}{fh}} header( title => $index_title,
- title_keywords => "debian, $s",
- desc => encode_entities( $index_title, '"' ),
- lang => $lang ),
- title( $index_title ), '
';
- my $i = 0; my $num_sections = keys %{$subsections->{$s}{$a}};
- foreach my $ssec ((keys %{$subsections->{$s}{$a}}, 'virtual')) {
- next if $ssec eq '-';
- if ($sections_descs{$ssec}) {
- print {$pages{$key}{$lang}{index}{fh}} "- ".dgettext( 'sections', $sections_descs{$ssec}[0] )."
- ".dgettext( 'sections', $sections_descs{$ssec}[1] )."
\n";
- $i++;
- if ($i eq ceil($num_sections/2)) {
- print {$pages{$key}{$lang}{index}{fh}} "
\n
\n\n
\n";
- }
- }
- }
+ my $key = $s;
+ mkpath ( "$wwwdir/$key" );
+ mkpath ( "$wwwdir/source/$key" );
+ foreach my $lang (@LANGUAGES) {
+ my $locale = get_locale( $lang );
+ my $charset = get_locale( $lang );
+ setlocale ( LC_ALL, $locale ) or do {
+ warn "couldn't set locale ($lang/$locale)\n";
+ next;
+ };
+ print "writing $key/index (lang=$lang)...\n";
- print {$pages{$key}{$lang}{index}{fh}} '
',
- "".
- _g( "All packages" ) ."
(".
- _g( "compact compressed textlist" ).")
\n";
- print {$pages{$key}{$lang}{index}{fh}} trailer( "$root../", 'index', $lang, @LANGUAGES );
- close $pages{$key}{$lang}{index}{fh} or
- warn "can't close index file $wwwdir/$key/index.$lang.html.new: $!";
- rename( "$wwwdir/$key/index.$lang.html.new",
- "$wwwdir/$key/index.$lang.html" );
+ my %content = ( subsections => [], suite => $s,
+ lang => $lang, charset => $charset,
+ used_langs => \@LANGUAGES, suites => \@SUITES );
+ $content{make_search_url} = sub { return &Packages::CGI::make_search_url(@_) };
+ $content{make_url} = sub { return &Packages::CGI::make_url(@_) };
+ # needed to work around the limitations of the the FILTER syntax
+ $content{html_encode} = sub { return HTML::Entities::encode_entities(@_,'<>&"') };
+ $content{uri_escape} = sub { return URI::Escape::uri_escape(@_) };
+ $content{quotemeta} = sub { return quotemeta($_[0]) };
+ foreach my $ssec ((keys %{$subsections->{$s}}, 'virtual')) {
+ next if $ssec eq '-';
+ if ($sections_descs{$ssec}) {
+ push @{$content{subsections}}, {
+ id => $ssec,
+ name => dgettext( 'sections', $sections_descs{$ssec}[0] ),
+ desc => dgettext( 'sections', $sections_descs{$ssec}[1] ),
+ };
+ }
}
- }
-}
-setlocale( LC_ALL, 'C' ) or die "couldn't reset locale";
-print "opening files ...\n";
-foreach my $s (@SUITES) {
- foreach my $a (@ARCHIVES) {
- next if $a eq 'security';
- next if $a eq 'non-US';
- my $key = ($a eq 'us') ? $s : "$s/$a";
- mkpath ( "$wwwdir/$key" );
- open $pages{$key}{fh}, '>', "$wwwdir/$key/allpackages.en.html.new"
+ open $pages{$key}{$lang}{index}{fh}, '>', "$wwwdir/$key/index.$lang.html.new"
or die "can't open index file for output: $!";
+ print {$pages{$key}{$lang}{index}{fh}} $template->page( 'suite_index', \%content );
+ close $pages{$key}{$lang}{index}{fh} or
+ warn "can't close index file $wwwdir/$key/index.$lang.html.new: $!";
+ rename( "$wwwdir/$key/index.$lang.html.new",
+ "$wwwdir/$key/index.$lang.html" );
- my $title = sprintf( _g( "Software Packages in \"%s\"" ),
- $key );
- print {$pages{$key}{fh}} header( title => $title,
- title_keywords => "debian, $s",
- desc => encode_entities( $title, '"' ),
- lang => 'en' ),
- title( $title ), '';
+ $content{source} = 'source';
+ open $pages{$key}{$lang}{source_index}{fh}, '>', "$wwwdir/source/$key/index.$lang.html.new"
+ or die "can't open index file for output: $!";
+ print {$pages{$key}{$lang}{source_index}{fh}} $template->page( 'suite_index', \%content );
+ close $pages{$key}{$lang}{source_index}{fh} or
+ warn "can't close index file $wwwdir/source/$key/index.$lang.html.new: $!";
+ rename( "$wwwdir/source/$key/index.$lang.html.new",
+ "$wwwdir/source/$key/index.$lang.html" );
- foreach my $sec (keys %{$sections->{$s}{$a}}) {
- mkpath ( "$wwwdir/$key/$sec" );
- open $pages{$key}{$sec}{fh}, '>', "$wwwdir/$key/$sec/index.en.html.new"
- or die "can't open index file for output: $!";
- $title = sprintf( _g( "Software Packages in \"%s\", section %s" ),
- $key, $sec );
- print {$pages{$key}{$sec}{fh}} header( title => $title,
- title_keywords => "debian, $s, $sec",
- desc => encode_entities( $title, '"' ),
- lang => 'en' ),
- title( $title ), '';
- }
- foreach my $ssec ((keys %{$subsections->{$s}{$a}}, 'virtual')) {
- next if $ssec eq '-';
- mkpath ( "$wwwdir/$key/$ssec" );
- open $pages{$key}{$ssec}{fh}, '>', "$wwwdir/$key/$ssec/index.en.html.new"
- or die "can't open index file for output: $!";
- $title = sprintf( _g( "Software Packages in \"%s\", subsection %s" ),
- $key, $ssec );
- print {$pages{$key}{$ssec}{fh}} header( title => $title,
- title_keywords => "debian, $s, $ssec",
- desc => encode_entities( $title, '"' ),
- lang => 'en' ),
- title( $title ), '';
- }
- foreach my $prio (keys %{$priorities->{$s}{$a}}) {
- next if $prio eq '-';
- mkpath ( "$wwwdir/$key/$prio" );
- open $pages{$key}{$prio}{fh}, '>', "$wwwdir/$key/$prio/index.en.html.new"
- or die "can't open index file for output: $!";
- $title = sprintf( _g( "Software Packages in \"%s\", priority %s" ),
- $key, $prio );
- print {$pages{$key}{$prio}{fh}} header( title => $title,
- title_keywords => "debian, $s, $prio",
- desc => encode_entities( $title, '"' ),
- lang => 'en' ),
- title( $title ), '';
- }
}
}
+setlocale( LC_ALL, 'C' ) or die "couldn't reset locale";
-print "writing package info ...\n";
+print "collecting package info ...\n";
+my %allpkgs;
while (my ($pkg, $data) = each %packages) {
- my %pkg;
- foreach (split /\000/o, $data) {
+ my (%pkg,%virt);
+ my ($virt, $p_data) = split /\000/o, $data, 2;
+ %virt = split /\01/o, $virt;
+ foreach (split /\000/o, $p_data||'') {
my @data = split ( /\s/o, $_, 8 );
- my $key = $data[1];
- if ($data[0] !~ /^(?:us|security|non-US)$/o) {
- $key = "$data[1]/$data[0]";
- }
- $pkg{$key} ||= new Packages::Page( $pkg );
- if ($data[2] ne 'virtual') {
- $pkg{$key}->merge_package( { package => $pkg,
+ $pkg{$data[1]} ||= new Packages::Page( $pkg );
+ $pkg{$data[1]}->merge_package( { package => $pkg,
archive => $data[0],
suite => $data[1],
architecture => $data[2],
@@ -173,89 +127,141 @@ while (my ($pkg, $data) = each %packages) {
priority => $data[5],
version => $data[6],
description => $data[7] } );
- } else {
- $pkg{$key}->add_provided_by([split /\s+/, $data[7]]);
- }
}
+ foreach (keys %virt) {
+ next if $_ eq '-';
+ $pkg{$_} ||= new Packages::Page( $pkg );
+ $pkg{$_}->add_provided_by([split /\s+/, $virt{$_}]);
+ }
+
while (my ($key, $entry) = each %pkg) {
+ $allpkgs{$key} ||= [];
+
+ my %p = ( name => $pkg, providers => [], versions => '' );
if (my $provided_by = $entry->{provided_by}) {
- my $str = "- $pkg ".
- "
\n - virtual package provided by ".
- join( ', ',map { "$_" } @$provided_by)."
\n";
- my $txt_str = "$pkg\tvirtual package provided by ".join(', ', @$provided_by)."\n";
- print {$pages{$key}{virtual}{fh}} $str
- or die "couldn't write to output file: $!";
+ $p{providers} = $provided_by;
+ }
+ $p{subsection} = $p{section} = $p{archive} = $p{desc} = $p{priority} = '';
+ unless ($entry->is_virtual) {
+ (undef, $p{versions}) = $entry->get_version_string;
+ $p{subsection} = $entry->get_newest( 'subsection' );
+ $p{section} = $entry->get_newest( 'section' );
+ $p{archive} = $entry->get_newest( 'archive' );
+ $p{desc} = $entry->get_newest( 'description' );
+ $p{priority} = $entry->get_newest( 'priority' );
}
- next if $entry->is_virtual;
- my (undef, $v_str) = $entry->get_version_string;
- my $subsection = $entry->get_newest( 'subsection' );
- my $section = $entry->get_newest( 'section' );
- my $archive = $entry->get_newest( 'archive' );
- my $short_desc_txt = $entry->get_newest( 'description' );
- my $short_desc = encode_entities( $short_desc_txt, "<>&\"" );
- my $priority = $entry->get_newest( 'priority' );
+ push @{$allpkgs{$key}}, \%p;
+ }
+}
- my $str = "- $pkg ($v_str) ";
- my $txt_str = "$pkg ($v_str)";
- if ($section ne 'main') {
- $str .= marker( $section );
- $txt_str .= " [$section]";
- }
- if ($archive ne 'us') {
- $str .= marker( $archive );
- $txt_str .= " [$archive]";
- }
- $str .= "
\n - $short_desc
\n";
- $txt_str .= " $short_desc_txt\n";
- print {$pages{$key}{fh}} $str
- or die "couldn't write to output file: $!";
- print {$pages{$key}{$section}{fh}} $str
- or die "couldn't write to output file: $!";
- if ($subsection ne '-') {
- print {$pages{$key}{$subsection}{fh}} $str
- or die "couldn't write to output file: $!";
- }
- if ($priority ne '-') {
- print {$pages{$key}{$priority}{fh}} $str
- or die "couldn't write to output file: $!";
- }
+write_files(\%allpkgs);
+
+print "collecting source package info ...\n";
+my %allsrcpkgs;
+while (my ($pkg, $data) = each %src_packages) {
+ my %pkg;
+ foreach (split /\000/o, $data||'') {
+ my @data = split ( /\s/o, $_ );
+ $pkg{$data[1]} ||= new Packages::SrcPage( $pkg );
+ $pkg{$data[1]}->merge_package( { package => $pkg,
+ archive => $data[0],
+ suite => $data[1],
+ section => $data[2],
+ subsection => $data[3],
+ priority => $data[4],
+ version => $data[5],
+ } );
+ }
+
+ while (my ($key, $entry) = each %pkg) {
+ $allsrcpkgs{$key} ||= [];
+
+ my %p = ( name => $pkg, providers => [], versions => '' );
+ $p{versions} = $entry->{version};
+ $p{subsection} = $entry->get_newest( 'subsection' );
+ $p{section} = $entry->get_newest( 'section' );
+ $p{archive} = $entry->get_newest( 'archive' );
+ $p{priority} = $entry->get_newest( 'priority' );
+
+ $p{desc} = '';
+ $p{binaries} = [];
+# my $binaries = find_binaries( $pkg, $p{archive}, $p{suite}, \%src2bin );
+# if ($binaries && @$binaries) {
+# pkg_list( \%packages, $opts, $binaries, 'en', $contents{binaries} );
+# }
+
+ push @{$allsrcpkgs{$key}}, \%p;
}
}
-print "closing files ...\n";
-foreach my $s (@SUITES) {
- foreach my $a (@ARCHIVES) {
- next if $a eq 'security';
- next if $a eq 'non-US';
- my $key = ($a eq 'us') ? $s : "$s/$a";
- my $root = ($a eq 'us') ? '' : '../';
- print {$pages{$key}{fh}} '
', trailer( "$root../" );
- close $pages{$key}{fh} or
- warn "can't close index file $wwwdir/$key/allpackages.en.html.new: $!";
- rename( "$wwwdir/$key/allpackages.en.html.new",
- "$wwwdir/$key/allpackages.en.html" );
- foreach my $sec (keys %{$sections->{$s}{$a}}) {
- print {$pages{$key}{$sec}{fh}} '
', trailer( "$root../../" );
- close $pages{$key}{$sec}{fh} or
- warn "can't close index file $wwwdir/$key/$sec/index.en.html.new: $!";
- rename( "$wwwdir/$key/$sec/index.en.html.new",
- "$wwwdir/$key/$sec/index.en.html" );
- }
- foreach my $ssec ((keys %{$subsections->{$s}{$a}}, 'virtual')) {
+write_files(\%allsrcpkgs, 1);
+
+sub write_files {
+ my ($pkgs, $source) = @_;
+
+ $source = $source ? 'source/' : '';
+ print "writing files ...\n";
+ foreach my $s (@SUITES) {
+ my $key = $s;
+ mkpath ( "$wwwdir/$source$key" );
+ print "writing $source$s/allpackages...\n";
+ $template->process( 'html/index.tmpl', { packages => $pkgs->{$key}, suite => $s, lang => 'en', is_source => $source },
+ "$wwwdir/$source$key/allpackages.en.html.new" )
+ or die "error writing allpackages for $key: ".$template->error();
+ print "writing $source$s/allpackages (txt)...\n";
+ my $gzfh = gzopen("$wwwdir/$source$key/allpackages.en.txt.gz.new",
+ 'wb9')
+ or die "can't open text index file for output: $!";
+ my $gztxt;
+ $template->process( 'txt/index.tmpl', { packages => $pkgs->{$key}, suite => $s, lang => 'en', is_source => $source },
+ \$gztxt )
+ or die "error writing allpackages txt for $key: ".$template->error();
+ $gzfh->gzwrite($gztxt);
+ ($gzfh->gzclose == Z_OK) or
+ warn "can't close text index file $wwwdir/$source$key/allpackages.en.txt.gz.new: ".$gzfh->gzerror;
+
+ rename( "$wwwdir/$source$key/allpackages.en.html.new",
+ "$wwwdir/$source$key/allpackages.en.html" );
+ rename( "$wwwdir/$source$key/allpackages.en.txt.gz.new",
+ "$wwwdir/$source$key/allpackages.en.txt.gz" );
+
+ foreach my $sec (keys %{$sections->{$s}}) {
+ mkpath ( "$wwwdir/$source$key/$sec" );
+
+ print "writing $source$s/$sec/index...\n";
+ $template->process( 'html/index.tmpl', { packages => [ grep { $_->{section} eq $sec } @{$pkgs->{$key}} ],
+ suite => $s, lang => 'en', is_source => $source,
+ category => { id => 'section', name => $sec } },
+ "$wwwdir/$source$key/$sec/index.en.html.new" )
+ or die "error writing section index for $key/$sec: ".$template->error();
+ rename( "$wwwdir/$source$key/$sec/index.en.html.new",
+ "$wwwdir/$source$key/$sec/index.en.html" );
+ }
+ foreach my $ssec ((keys %{$subsections->{$s}}, 'virtual')) {
next if $ssec eq '-';
- print {$pages{$key}{$ssec}{fh}} '
', trailer( "$root../../" );
- close $pages{$key}{$ssec}{fh} or
- warn "can't close index file $wwwdir/$key/$ssec/index.en.html.new: $!";
- rename( "$wwwdir/$key/$ssec/index.en.html.new",
- "$wwwdir/$key/$ssec/index.en.html" );
+ mkpath ( "$wwwdir/$source$key/$ssec" );
+
+ print "writing $source$s/$ssec/index...\n";
+ $template->process( 'html/index.tmpl', { packages => [ grep { $_->{subsection} eq $ssec } @{$pkgs->{$key}} ],
+ suite => $s, lang => 'en', is_source => $source,
+ category => { id => 'subsection', name => $ssec } },
+ "$wwwdir/$source$key/$ssec/index.en.html.new" )
+ or die "error writing subsection index for $key/$ssec: ".$template->error();
+ rename( "$wwwdir/$source$key/$ssec/index.en.html.new",
+ "$wwwdir/$source$key/$ssec/index.en.html" );
}
- foreach my $prio (keys %{$priorities->{$s}{$a}}) {
+ foreach my $prio (keys %{$priorities->{$s}}) {
next if $prio eq '-';
- print {$pages{$key}{$prio}{fh}} '
', trailer( "$root../../" );
- close $pages{$key}{$prio}{fh} or
- warn "can't close index file $wwwdir/$key/$prio/index.en.html.new: $!";
- rename( "$wwwdir/$key/$prio/index.en.html.new",
- "$wwwdir/$key/$prio/index.en.html" );
+ mkpath ( "$wwwdir/$source$key/$prio" );
+
+ print "writing $source$s/$prio/index...\n";
+ $template->process( 'html/index.tmpl', { packages => [ grep { $_->{priority} eq $prio } @{$pkgs->{$key}} ],
+ suite => $s, lang => 'en', is_source => $source,
+ category => { id => 'priority', name => $prio } },
+ "$wwwdir/$source$key/$prio/index.en.html.new" )
+ or die "error writing priority index for $key/$prio: ".$template->error();
+ rename( "$wwwdir/$source$key/$prio/index.en.html.new",
+ "$wwwdir/$source$key/$prio/index.en.html" );
}
}
}