BLIP/Demo/BLIPEchoServer.m
author Jens Alfke <jens@mooseyard.com>
Tue Jun 03 16:56:33 2008 -0700 (2008-06-03)
changeset 11 29e8b03c05d4
child 26 cb9cdf247239
permissions -rw-r--r--
* Initial checkin of BLIP.py. (Receiving seems to work.)
* FIXED: Abbreviation list in BLIPProperties was messed up.
* Renamed some instance variables to use 'request' instead of 'query'.
* Test client doesn't throw an assertion-failure now when the number of unresponded requests exceeds 100.
     1 //
     2 //  BLIPEchoServer.m
     3 //  MYNetwork
     4 //
     5 //  Created by Jens Alfke on 5/24/08.
     6 //  Copyright 2008 Jens Alfke. All rights reserved.
     7 //
     8 
     9 #import "BLIPEchoServer.h"
    10 #import "BLIP.h"
    11 
    12 
    13 @implementation BLIPEchoServer
    14 
    15 
    16 - (id) init
    17 {
    18     self = [super init];
    19     if (self != nil) {
    20         _listener = [[BLIPListener alloc] initWithPort: 12345];
    21         _listener.delegate = self;
    22         _listener.pickAvailablePort = YES;
    23         _listener.bonjourServiceType = @"_blipecho._tcp";
    24         [_listener open];
    25         NSLog(@"%@ is listening...",self);
    26     }
    27     return self;
    28 }
    29 
    30 - (void) dealloc
    31 {
    32     [_listener close];
    33     [_listener release];
    34     [super dealloc];
    35 }
    36 
    37 - (void) listener: (TCPListener*)listener failedToOpen: (NSError*)error
    38 {
    39     NSLog(@"** %@ failed to open: %@",self,error);
    40 }
    41 
    42 - (void) listener: (TCPListener*)listener didAcceptConnection: (TCPConnection*)connection
    43 {
    44     NSLog(@"** %@ accepted %@",self,connection);
    45     connection.delegate = self;
    46 }
    47 
    48 - (void) connection: (TCPConnection*)connection failedToOpen: (NSError*)error
    49 {
    50     NSLog(@"** %@ failedToOpen: %@",connection,error);
    51 }
    52 
    53 - (void) connection: (BLIPConnection*)connection receivedRequest: (BLIPRequest*)request
    54 {
    55     NSLog(@"***** %@ received %@",connection,request);
    56     [request respondWithData: request.body contentType: request.contentType];
    57 }
    58 
    59 
    60 @end
    61 
    62 
    63 int main( int argc, const char **argv )
    64 {
    65     NSAutoreleasePool *pool = [NSAutoreleasePool new];
    66     BLIPEchoServer *listener = [[BLIPEchoServer alloc] init];
    67     [[NSRunLoop currentRunLoop] run];
    68     [listener release];
    69     [pool drain];
    70 }