/[Frey]/branches/mojo/lib/Frey/Server.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /branches/mojo/lib/Frey/Server.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 60 by dpavlin, Tue Jul 8 12:20:08 2008 UTC revision 66 by dpavlin, Wed Jul 9 12:08:07 2008 UTC
# Line 17  my $got_message; # Flag to indicate that Line 17  my $got_message; # Flag to indicate that
17  use vars qw( $repl $server );  use vars qw( $repl $server );
18    
19  #$repl = Continuity::REPL->new;  #$repl = Continuity::REPL->new;
 $server = Continuity->new(  
         port => 16001,  
         path_session => 1,  
         cookie_session => 'sid',  
         callback => \&main,  
         debug_level => 1,  
         staticp => sub { $_[0]->url =~ m/\.(jpg|jpeg|gif|png|css|ico|js|html?)$/ },  
 );  
20    
21  sub run {  sub run {
22            $server = Continuity->new(
23                    port => 16001,
24                    path_session => 1,
25                    cookie_session => 'sid',
26                    callback => \&main,
27                    debug_level => 1,
28                    staticp => sub { $_[0]->url =~ m/\.(jpg|jpeg|gif|png|css|ico|js|html?)$/ },
29            );
30          $server->loop;          $server->loop;
31  }  }
32    
# Line 42  sub main { Line 42  sub main {
42          warn $req->request->header('User_Agent');          warn $req->request->header('User_Agent');
43  #warn dump( $req );  #warn dump( $req );
44    
45          if ( $path =~ m!/~/([^/]+)(?:/([^/]*))?! ) {          eval {
                 my $f = Frey::Introspect->new( package => $1 );  
                 $f->html( $req );  
         }  
46    
47          if ( $path =~ m!/ob/([^/]+)(?:/([^/]*))?! ) {                  if ( $path =~ m!/~/([^/]+)(?:/([^/]*))?! ) {
48                  my $f = Frey::ObjectBrowser->new;                          my $f = Frey::Introspect->new( package => $1 );
49                  $f->html( $req );                          $f->html( $req );
50                    }
51    
52                    if ( $path =~ m!/ob/([^/]+)(?:/([^/]*))?! ) {
53                            my $f = Frey::ObjectBrowser->new;
54                            $f->html( $req );
55                    }
56    
57            };
58    
59            if ( $@ ) {
60                    warn $@;
61                    #$req->conn->send_error( 404 ); # FIXME this should probably be 500, but we can't ship page with it
62                    $req->print( qq{<pre class="error">$@<pre>} );
63                    $req->next;
64          }          }
65    
66          # If this is a request for the pushtream, then give them that          # If this is a request for the pushtream, then give them that
67          if($path =~ /pushstream/) {          if($path =~ /pushstream/) {
68                  pushstream($req);                  pushstream($req);
# Line 61  sub main { Line 73  sub main {
73                  send_message($req);                  send_message($req);
74          }          }
75    
76          while ( 1 ) {          my $f = Frey->new;
77                  my $f = Frey->new;          my $classes = Continuity::Widget::DomNode->create(
78                  my $classes = Continuity::Widget::DomNode->create(                  ul => [
79                          ul => [                          map {
80                                  map {                                  warn dump( $_ );
81                                          warn dump( $_ );                                  my ( $package, $path ) = %$_;
82                                          my ( $package, $path ) = %$_;                                  ( li => [
83                                          ( li => [ a => { href => '/~/' . $package . '/' } => [ $package ], " <tt>$path</tt>" ] )                                          a => { href => '/~/' . $package . '/' } => [ $package ],
84                                  } @{ $f->classes }                                          ' ',
85                          ],                                          a => { href => '/ob/' . $package } => [ 'browse' ],
86                  )->to_string;                                          " <tt>$path</tt>"
87                  $req->print( $classes );                                  ] )
88                  $req->next;                          } @{ $f->classes }
89          }                  ],
90            )->to_string;
91            $req->print( $classes );
92  }  }
93    
94  # Here we accept a connection to the browser, and keep it open. Meanwhile we  # Here we accept a connection to the browser, and keep it open. Meanwhile we

Legend:
Removed from v.60  
changed lines
  Added in v.66

  ViewVC Help
Powered by ViewVC 1.1.26