X-Git-Url: https://git.deb.at/?a=blobdiff_plain;f=cgi-bin%2Fdispatcher.pl;h=e776a83086c7293205f6df2013a9da74c770a370;hb=d712994b08af4e71e52930ddf1081f1e13384573;hp=b0913eab684e2bea963f85224af167bf3818cd5f;hpb=1cb33b0e2bfcb76ab7b8854f7f36362726f0cd09;p=deb%2Fpackages.git diff --git a/cgi-bin/dispatcher.pl b/cgi-bin/dispatcher.pl index b0913ea..e776a83 100755 --- a/cgi-bin/dispatcher.pl +++ b/cgi-bin/dispatcher.pl @@ -32,6 +32,7 @@ use Packages::I18N::Locale; use Packages::DoSearch; use Packages::DoSearchContents; use Packages::DoShow; +use Packages::DoIndex; use Packages::DoDownload; use Packages::DoFilelist; @@ -75,7 +76,9 @@ my $source = 0; if (my $path = $input->path_info() || $input->param('PATH_INFO')) { my @components = grep { $_ } map { lc $_ } split /\/+/, $path; - debug( "components[0]=$components[0]", 2 ) if @components>0; + push @components, 'index' if $path =~ m,/$,; + + debug( "components[0]=$components[0]", 2 ) if DEBUG and @components>0; if (@components > 0 and $components[0] eq 'source') { shift @components; $input->param( 'source', 1 ); @@ -85,7 +88,7 @@ if (my $path = $input->path_info() || $input->param('PATH_INFO')) { $what_to_do = 'search'; # Done fatal_error( _g( "search doesn't take any more path elements" ) ) - if @components > 0; + if @components; } elsif (@components == 0) { fatal_error( _g( "We're supposed to display the homepage here, instead of getting dispatch.pl" ) ); } elsif (@components == 1) { @@ -93,7 +96,7 @@ if (my $path = $input->path_info() || $input->param('PATH_INFO')) { } else { for ($components[-1]) { - /^(changelog|copyright|download|filelist)$/ && do { + /^(index|changelog|copyright|download|filelist)$/ && do { pop @components; $what_to_do = $1; last; @@ -220,8 +223,6 @@ my $pet1 = new Benchmark; my $petd = timediff($pet1, $pet0); debug( "Parameter evaluation took ".timestr($petd) ) if DEBUG; -print $input->header( -charset => $charset ); - my (%html_header, $menu, $page_content); unless (@Packages::CGI::fatal_errors) { no strict 'refs'; @@ -244,6 +245,8 @@ unless (@Packages::CGI::fatal_errors) { ); } +print $input->header( -charset => $charset ); + print Packages::HTML::header( %html_header ); print $menu||'';