/[Frey]/trunk/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 /trunk/lib/Frey/Server.pm

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

revision 55 by dpavlin, Sat Jul 5 19:00:10 2008 UTC revision 66 by dpavlin, Wed Jul 9 12:08:07 2008 UTC
# Line 9  use Data::Dump qw/dump/; Line 9  use Data::Dump qw/dump/;
9    
10  use Frey;  use Frey;
11  use Frey::Introspect;  use Frey::Introspect;
12    use Frey::ObjectBrowser;
13    
14  my @messages;    # Global (shared) list of messages  my @messages;    # Global (shared) list of messages
15  my $got_message; # Flag to indicate that there is a new message to display  my $got_message; # Flag to indicate that there is a new message to display
# Line 16  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 41  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 {
46                  my $f = Frey::Introspect->new( package => $1 );  
47                  $f->html( $req );                  if ( $path =~ m!/~/([^/]+)(?:/([^/]*))?! ) {
48                            my $f = Frey::Introspect->new( package => $1 );
49                            $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
# Line 56  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                  $req->print( dump( $f->classes ) );                  ul => [
79                  $req->next;                          map {
80          }                                  warn dump( $_ );
81                                    my ( $package, $path ) = %$_;
82                                    ( li => [
83                                            a => { href => '/~/' . $package . '/' } => [ $package ],
84                                            ' ',
85                                            a => { href => '/ob/' . $package } => [ 'browse' ],
86                                            " <tt>$path</tt>"
87                                    ] )
88                            } @{ $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.55  
changed lines
  Added in v.66

  ViewVC Help
Powered by ViewVC 1.1.26