From 1a910dd8949a5a4ce3c93fa581a1f70fe5675997 Mon Sep 17 00:00:00 2001 From: Jeroen van Wolffelaar Date: Thu, 2 Feb 2006 15:29:20 +0000 Subject: [PATCH] Bluntly copy package_pages_walker --- cgi-bin/show_package.pl | 287 +++++++++++++++++++++++++++++++++++++++- 1 file changed, 284 insertions(+), 3 deletions(-) diff --git a/cgi-bin/show_package.pl b/cgi-bin/show_package.pl index bf84db0..260d5ce 100755 --- a/cgi-bin/show_package.pl +++ b/cgi-bin/show_package.pl @@ -41,6 +41,8 @@ my %SECTIONS = map { $_ => 1 } @SECTIONS; my %ARCHIVES = map { $_ => 1 } @ARCHIVES; my %ARCHITECTURES = map { $_ => 1 } @ARCHITECTURES; + + $ENV{PATH} = "/bin:/usr/bin"; # Read in all the variables set by the form @@ -56,7 +58,7 @@ my $pet0 = new Benchmark; my $debug_allowed = 1; my $debug = $debug_allowed && $input->param("debug"); $debug = 0 if not defined($debug); -$Search::Param::debug = 1 if $debug > 1; +$Packages::Search::debug = 1 if $debug > 1; # If you want, just print out a list of all of the variables and exit. print $input->header if $debug; @@ -93,9 +95,9 @@ my $suite = $params{values}{suite}{final}; # for output if ($format eq 'html') { -print Packages::HTML::header( title => 'Package Details' , +print Packages::HTML::header( title => "Details of package $package in $suite" , lang => 'en', - title_tag => 'Package Details', + title_tag => "Details of package $package in $suite", print_title_above => 1 ); } @@ -152,6 +154,285 @@ for my $entry (@results) { print "
".$packages_all{"$package $arch $version"}."
"; } +&showpackage($package); + +sub showpackage { + my ( $pkg ) = @_; + + my $name = $pkg->get_name; + + if ( $pkg->is_virtual ) { + print_virt_pack( @_ ); + return; + } + + my @all_archs = ( @{$env->{archs}}, 'all' ); + + my $page = new Packages::Page( $name, + { architectures => $env->{archs} } ); + my $d = $page->set_data( $env->{db}, $pkg ); + + my %versions = $pkg->get_arch_versions( $env->{archs} ); + my %subsuites = $pkg->get_arch_fields( 'subdistribution', + $env->{archs} ); + my %filenames = $pkg->get_arch_fields( 'filename', + $env->{archs} ); + my %file_md5s = $pkg->get_arch_fields( 'md5sum', + $env->{archs} ); + + my $subsuite_kw = $d->{subsuite} || $env->{distribution}; + my $size_kw = exists $d->{sizes_deb}{i386} ? $d->{sizes_deb}{i386} : first_val($d->{sizes_deb}); + + + foreach my $lang (@{$env->{langs}}) { + &Generated::Strings::string_lang($lang); + + my $dirname = "$env->{dest_dir}/$d->{subsection}"; + my $filename = "$dirname/$name.$lang.html"; + + unless (( $lang eq 'en' ) + || $env->{db}->is_translated( $name, $d->{version}, + ${$versions{v2a}{$d->{version}}}[0], + $lang )) { + $files->delete_file( $filename ) + if $files->file_exists( $filename ); + next; + } + progress() if $env->{opts}{progress}; + + # + # process description + # + my $short_desc = encode_entities( $env->{db}->get_short_desc( $d->{desc_md5}, + $lang ), "<>&\"" ); + my $long_desc = encode_entities( $env->{db}->get_long_desc( $d->{desc_md5}, + $lang ), "<>&\"" ); + + $long_desc =~ s,((ftp|http|https)://[\S~-]+?/?)((\>\;)?[)]?[']?[:.\,]?(\s|$)),$1$3,go; # syntax highlighting -> ']; + $long_desc =~ s/\A //o; + $long_desc =~ s/\n /\n/sgo; + $long_desc =~ s/\n.\n/\n

\n/go; + $long_desc =~ s/(((\n|\A) [^\n]*)+)/\n

$1\n<\/pre>/sgo;
+	
+	$long_desc = conv_desc( $lang, $long_desc );
+	$short_desc = conv_desc( $lang, $short_desc );
+	
+	#
+	# begin output
+	#
+	my $package_page = header( title => $name, lang => $lang,
+				   desc => $short_desc,
+				   keywords => "$env->{distribution}, $subsuite_kw, $d->{section}, $d->{subsection}, size:$size_kw $d->{version}" );
+	$package_page .= simple_menu( [ gettext( "Distribution:" ),
+					gettext( "Overview over this distribution" ),
+					"../",
+					$env->{distribution} ],
+				      [ gettext( "Section:" ),
+					gettext( "All packages in this section" ),
+					"../$d->{subsection}/",
+					$d->{subsection} ],
+				      );
+	
+	my $title .= sprintf( gettext( "Package: %s (%s)" ), $name, $d->{v_str_simple} );
+	$title .=  " ".marker( $d->{subsuite} ) if $d->{subsuite};
+	$title .=  " ".marker( $d->{section} ) if $d->{section} ne 'main';
+	$package_page .= title( $title );
+	
+	$package_page .= "

".gettext( "Versions:" )." $d->{v_str_arch}

\n" + unless $d->{version} eq $d->{v_str_simple}; + + if ($env->{distribution} eq "experimental") { + $package_page .= note( gettext( "Experimental package"), + gettext( "Warning: This package is from the experimental distribution. That means it is likely unstable or buggy, and it may even cause data loss. If you ignore this warning and install it nevertheless, you do it on your own risk.")."

". + gettext( "Users of experimental packages are encouraged to contact the package maintainers directly in case of problems." ) + ); + } + if ($d->{section} eq "debian-installer") { + $package_page .= note( gettext( "debian-installer udeb package"), + gettext( "Warning: This package is intended for the use in building debian-installer images only. Do not install it on a normal Debian system." ) + ); + } + $package_page .= pdesc( $short_desc, $long_desc ); + + # + # display dependencies + # + my $dep_list = print_deps( $env, $lang, $pkg, $d->{depends}, 'depends' ); + $dep_list .= print_deps( $env, $lang, $pkg, $d->{recommends}, 'recommends' ); + $dep_list .= print_deps( $env, $lang, $pkg, $d->{suggests}, 'suggests' ); + + if ( $dep_list ) { + $package_page .= "

\n"; + $package_page .= sprintf( "

".gettext( "Other Packages Related to %s" )."

\n", $name ); + if ($env->{distribution} eq "experimental") { + $package_page .= note( gettext( "Note that the \"experimental\" distribution is not self-contained; missing dependencies are likely found in the \"unstable\" distribution." ) ); + } + + $package_page .= pdeplegend( [ 'dep', gettext( 'depends' ) ], + [ 'rec', gettext( 'recommends' ) ], + [ 'sug', gettext( 'suggests' ) ], ); + + $package_page .= $dep_list; + $package_page .= "
\n"; + } + + # + # Download package + # + my $encodedpack = uri_escape( $name ); + $package_page .= "
"; + $package_page .= sprintf( "

".gettext( "Download %s\n" )."

", + $name ) ; + $package_page .= "\n"; + $package_page .= "\n"; + $package_page .= "\n"; + $package_page .= "\n"; + foreach my $a ( @all_archs ) { + if ( exists $versions{a2v}{$a} ) { + $package_page .= "\n"; + $package_page .= "\n"; + $package_page .= "\n\n\n"; + } + } + $package_page .= "
".gettext("Download for all available architectures")."
".gettext("Architecture")."".gettext("Files")."".gettext( "Package Size")."".gettext("Installed Size")."
\n

"; + $package_page .= "&file=".uri_escape($filenames{a2f}->{$a}); + $package_page .= "&md5sum=$file_md5s{a2f}->{$a}"; + $package_page .= "&arch=$a"; + # there was at least one package with two + # different source packages on different + # archs where one had a security update + # and the other one not + if ($subsuites{a2f}{$a} + && ($subsuites{a2f}{$a} =~ /security/o) ) { + $package_page .= "&type=security"; + } elsif ($subsuites{a2f}{$a} + && ($subsuites{a2f}{$a} =~ /volatile/o) ) { + $package_page .= "&type=volatile"; + } elsif ($d->{is_nonus}) { + $package_page .= "&type=nonus"; + } else { + $package_page .= "&type=main"; + } + $package_page .= "\">$a

"; + if ( $env->{distribution} ne "experimental" ) { + $package_page .= sprintf( "[".gettext( "list of files" )."]\n", "$FILELIST_URL$encodedpack&version=$env->{distribution}&arch=$a", $name ); + } else { + $package_page .= "no files"; + } + $package_page .= ""; + my $size = $d->{sizes_deb}{$a}; + $package_page .= "$size"; + $package_page .= ""; + my $inst_size = $d->{sizes_inst}{$a}; + $package_page .= "$inst_size"; + $package_page .= "

".gettext ( "Size is measured in kBytes." )."

\n"; + $package_page .= "
\n"; + + # + # more information + # + $package_page .= pmoreinfo( name => $name, env => $env, data => $d, + bugreports => 1, sourcedownload => 1, + changesandcopy => 1, maintainers => 1, + search => 1 ); + + # + # Trailer + # + my @tr_langs = (); + foreach my $l (@{$env->{langs}}) { + next if $l eq $lang; + push @tr_langs, $l if ( $l eq 'en' ) + || $env->{db}->is_translated( $name, $d->{version}, + ${$versions{v2a}{$d->{version}}}[0], + $l ); + } + $package_page .= trailer( '../..', $name, $lang, @tr_langs ); + + # + # write file + # + $files->update_file( $filename, $package_page ); + + # + # create data sheet + # + if($lang eq 'en') { + my $data_sheet = header( title => "$name -- Data sheet", + lang => "en", + desc => $short_desc, + keywords => "$env->{distribution}, $subsuite_kw, $d->{section}, $d->{subsection}, size:$size_kw $d->{version}" ); + + my $ds_title = $name; + if ( $d->{subsuite} ) { + $ds_title .= " ".marker( $d->{subsuite} ); + } + if ( $d->{section} ne 'main' ) { + $ds_title .= " ".marker( $d->{section} ); + } + $data_sheet .= title( $ds_title ); + + $data_sheet .= ds_begin; + $data_sheet .= ds_item(gettext( "Version" ), $d->{v_str_arch}); + + my @uploaders = @{$d->{uploaders}}; + my ( $maint_name, $maint_email ) = @{shift @uploaders}; + $data_sheet .= ds_item(gettext( "Maintainer" ), + "".encode_entities($maint_name, '&<>')."" ); + if (@uploaders) { + my @uploaders_str; + foreach (@uploaders) { + push @uploaders_str, "[1])."\">".encode_entities($_->[0], '&<>').""; + } + $data_sheet .= ds_item(gettext( "Uploaders" ), + join( ",\n ", @uploaders_str )); + } + $data_sheet .= ds_item(gettext( "Section" ), + "{subsection}/\">$d->{subsection}"); + $data_sheet .= ds_item(gettext( "Priority" ), + "{priority}\">$d->{priority}"); + $data_sheet .= ds_item(gettext( "Essential" ), + "". + gettext("yes")."") + if $d->{essential} =~ /yes/i; + $data_sheet .= ds_item(gettext( "Source package" ), + "{src_name}\">$d->{src_name}"); + $data_sheet .= print_deps_ds( $env, $pkg, $d->{depends}, 'Depends' ); + $data_sheet .= print_deps_ds( $env, $pkg, $d->{recommends}, 'Recommends' ); + $data_sheet .= print_deps_ds( $env, $pkg, $d->{suggests}, 'Suggests' ); + $data_sheet .= print_deps_ds( $env, $pkg, $d->{enhances}, 'Enhances' ); + $data_sheet .= print_deps_ds( $env, $pkg, $d->{conflicts}, 'Conflicts' ); + $data_sheet .= print_deps_ds( $env, $pkg, $d->{provides}, 'Provides' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Depends' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Recommends' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Suggests' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Enhances' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Provides' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Conflicts' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Build-Depends' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Build-Depends-Indep' ); +# $data_sheet .= print_reverse_rel_ds( $env, $pkg, \%versions, 'Build-Conflicts' ); + +# if ( $name eq 'libc6' ) { +# use Data::Dumper; +# print STDERR Dumper( $pkg ); +# } + + $data_sheet .= ds_end; + + $data_sheet .= trailer( '../..', $name ); + + my $ds_filename = "$dirname/ds_$name.$lang.html"; + # + # write file + # + print $data_sheet; + } + } +} &printfooter; -- 2.39.2