Umstellung des Dispatcher-Moduls auf Objekt-Aufrufsyntax
authorMoritz Bunkus <m.bunkus@linet-services.de>
Mon, 3 Jan 2011 13:30:34 +0000 (14:30 +0100)
committerMoritz Bunkus <m.bunkus@linet-services.de>
Mon, 3 Jan 2011 13:30:34 +0000 (14:30 +0100)
SL/Dispatcher.pm
admin.pl
dispatcher.fpl

index cc886d8..e6aa547 100644 (file)
@@ -22,6 +22,15 @@ use File::Basename;
 # number 'die' was called in.
 use constant END_OF_REQUEST => "END-OF-REQUEST\n";
 
+sub new {
+  my ($class, $interface) = @_;
+
+  my $self           = bless {}, $class;
+  $self->{interface} = lc($interface || 'cgi');
+
+  return $self;
+}
+
 sub pre_request_checks {
   if (!$::auth->session_tables_present) {
     if ($::form->{script} eq 'admin.pl') {
@@ -138,15 +147,16 @@ sub _run_controller {
 }
 
 sub handle_request {
+  my $self = shift;
+
   $::lxdebug->enter_sub;
   $::lxdebug->begin_request;
 
-  my $interface = lc(shift || 'cgi');
   my ($script, $path, $suffix, $script_name, $action, $routing_type);
 
   $script_name = $ENV{SCRIPT_NAME};
 
-  unrequire_bin_mozilla($interface);
+  $self->unrequire_bin_mozilla;
 
   $::cgi         = CGI->new('');
   $::locale      = Locale->new($::language);
@@ -230,7 +240,8 @@ sub handle_request {
 }
 
 sub unrequire_bin_mozilla {
-  return unless $_[0] =~ m/^(?:fastcgi|fcgid|fcgi)$/;
+  my $self = shift;
+  return unless $self->{interface} =~ m/^(?:fastcgi|fcgid|fcgi)$/;
 
   for (keys %INC) {
     next unless m#^bin/mozilla/#;
index 603d166..60c4ff2 100755 (executable)
--- a/admin.pl
+++ b/admin.pl
@@ -4,7 +4,8 @@ use strict;
 
 use SL::Dispatcher;
 
-SL::Dispatcher::pre_startup();
-SL::Dispatcher::handle_request('CGI');
+my $dispatcher = SL::Dispatcher->new('CGI');
+$dispatcher->pre_startup;
+$dispatcher->handle_request;
 
 1;
index afe1bc6..e5c8ca9 100755 (executable)
@@ -8,8 +8,10 @@ use SL::FCGIFixes;
 
 SL::FCGIFixes::apply_fixes();
 
-SL::Dispatcher::pre_startup();
+my $dispatcher = SL::Dispatcher->new('FastCGI');
+$dispatcher->pre_startup;
+
 my $request = FCGI::Request();
-SL::Dispatcher::handle_request('FastCGI') while $request->Accept() >= 0;
+$dispatcher->handle_request($request) while $request->Accept() >= 0;
 
 1;