project_files/HedgewarsMobile/Classes/ServerProtocolNetwork.m
author S.D.
Tue, 27 Sep 2022 14:59:03 +0300
changeset 15878 fc3cb23fd26f
parent 12872 00215a7ec5f5
permissions -rw-r--r--
Allow to see rooms of incompatible versions in the lobby For the new clients the room version is shown in a separate column. There is also a hack for previous versions clients: the room vesion specifier is prepended to the room names for rooms of incompatible versions, and the server shows 'incompatible version' error if the client tries to join them.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     1
/*
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     2
 * Hedgewars-iOS, a Hedgewars port for iOS devices
6700
e04da46ee43c the most important commit of the year
koda
parents: 6337
diff changeset
     3
 * Copyright (c) 2009-2012 Vittorio Giovara <vittorio.giovara@gmail.com>
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     4
 *
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     8
 *
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    12
 * GNU General Public License for more details.
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    13
 *
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
10108
c68cf030eded update FSF address. note: two sdl include files (by Sam Lantinga) still have the old FSF address in their copyright - but I ain't gonna touch their copyright headers
sheepluva
parents: 8835
diff changeset
    16
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA.
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    17
 */
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    18
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    19
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    20
#import "ServerProtocolNetwork.h"
8835
01bcf9ea68c1 ios compiles again (using an old version of sdl)
koda
parents: 6908
diff changeset
    21
#import "hwconsts.h"
6832
fae8fd118da9 dates are no more!
koda
parents: 6822
diff changeset
    22
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    23
#define BUFFER_SIZE 256
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    24
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    25
static ServerProtocolNetwork *serverConnection;
6078
8c0cc07731e5 headers cleanup, converted some function-only sources into proper class method files, more use of OOP power, removed some 'respondsToSelector' calls, moved defines into their own header, more use of objc categories
koda
parents: 5483
diff changeset
    26
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    27
@implementation ServerProtocolNetwork
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    28
@synthesize serverPort, serverAddress, ssd;
6078
8c0cc07731e5 headers cleanup, converted some function-only sources into proper class method files, more use of OOP power, removed some 'respondsToSelector' calls, moved defines into their own header, more use of objc categories
koda
parents: 5483
diff changeset
    29
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    30
#pragma mark -
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    31
#pragma mark init and class methods
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    32
- (id)init:(NSInteger)onPort withAddress:(NSString *)address {
6908
896ed2afcfb8 ios: turn on more warning messages and start correcting them
koda
parents: 6832
diff changeset
    33
    if ((self = [super init])) {
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    34
        self.serverPort = onPort;
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    35
        self.serverAddress = address;
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    36
    }
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    37
    serverConnection = self;
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    38
    return self;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    39
}
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    40
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    41
- (id)init {
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    42
    return [self init:NETGAME_DEFAULT_PORT withAddress:@"netserver.hedgewars.org"];
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    43
}
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    44
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    45
- (id)initOnPort:(NSInteger)port {
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    46
    return [self init:port withAddress:@"netserver.hedgewars.org"];
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    47
}
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    48
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    49
- (id)initToAddress:(NSString *)address {
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    50
    return [self init:NETGAME_DEFAULT_PORT withAddress:address];
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    51
}
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    52
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    53
- (void)dealloc {
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    54
    serverConnection = nil;
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    55
}
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    56
6337
84e7d1a5e3df in class methods you can call [self alloc], as per objc specifications
koda
parents: 6320
diff changeset
    57
+(id) openServerConnection {
84e7d1a5e3df in class methods you can call [self alloc], as per objc specifications
koda
parents: 6320
diff changeset
    58
    id connection = [[self alloc] init];
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    59
    [NSThread detachNewThreadSelector:@selector(serverProtocol)
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    60
                             toTarget:connection
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    61
                           withObject:nil];
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    62
        // retain count here is +2
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    63
    return connection;
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    64
}
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    65
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    66
#pragma mark -
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
    67
#pragma mark Communication layer
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    68
-(int) sendToServer:(NSString *)command {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    69
    NSString *message = [[NSString alloc] initWithFormat:@"%@\n\n",command];
11240
57891137ffef - Fix for sending to engine non-english characters
antonc27 <antonc27@mail.ru>
parents: 11137
diff changeset
    70
    int result = SDLNet_TCP_Send(self.ssd, [message UTF8String], [message lengthOfBytesUsingEncoding:NSUTF8StringEncoding]);
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    71
    return result;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    72
}
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    73
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    74
-(int) sendToServer:(NSString *)command withArgument:(NSString *)argument {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    75
    NSString *message = [[NSString alloc] initWithFormat:@"%@\n%@\n\n",command,argument];
11240
57891137ffef - Fix for sending to engine non-english characters
antonc27 <antonc27@mail.ru>
parents: 11137
diff changeset
    76
    int result = SDLNet_TCP_Send(self.ssd, [message UTF8String], [message lengthOfBytesUsingEncoding:NSUTF8StringEncoding]);
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    77
    return result;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    78
}
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    79
12872
00215a7ec5f5 - BIG CHANGE: Convert iOS project to use ARC
antonc27 <antonc27@mail.ru>
parents: 11240
diff changeset
    80
- (void)serverProtocol {
11137
14f50dde3e8c - Using of @autoreleasepool is better
Anton Malmygin <antonc27@mail.ru>
parents: 10108
diff changeset
    81
    @autoreleasepool {
14f50dde3e8c - Using of @autoreleasepool is better
Anton Malmygin <antonc27@mail.ru>
parents: 10108
diff changeset
    82
    
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    83
    IPaddress ip;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    84
    BOOL clientQuit = NO;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    85
    char *buffer = (char *)malloc(sizeof(char)*BUFFER_SIZE);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    86
    int dim = BUFFER_SIZE;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    87
    uint8_t msgSize;
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    88
    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    89
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    90
    if (SDLNet_Init() < 0) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    91
        DLog(@"SDLNet_Init: %s", SDLNet_GetError());
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    92
        clientQuit = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    93
    }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    94
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    95
    // Resolving the host using NULL make network interface to listen
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    96
    if (SDLNet_ResolveHost(&ip, [self.serverAddress UTF8String] , self.serverPort) < 0 && !clientQuit) {
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
    97
        DLog(@"SDLNet_ResolveHost: %s", SDLNet_GetError());
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    98
        clientQuit = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
    99
    }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   100
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   101
    // Open a connection with the IP provided (listen on the host's port)
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
   102
    if (!(self.ssd = SDLNet_TCP_Open(&ip)) && !clientQuit) {
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   103
        DLog(@"SDLNet_TCP_Open: %s %d", SDLNet_GetError(), self.serverPort);
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   104
        clientQuit = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   105
    }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   106
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   107
    DLog(@"Found server on port %d", self.serverPort);
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   108
    while (!clientQuit) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   109
        int index = 0;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   110
        BOOL exitBufferLoop = NO;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   111
        memset(buffer, '\0', dim);
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   112
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   113
        while (exitBufferLoop != YES) {
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
   114
            msgSize = SDLNet_TCP_Recv(self.ssd, &buffer[index], 2);
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   115
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   116
            // exit in case of error
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   117
            if (msgSize <= 0) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   118
                DLog(@"SDLNet_TCP_Recv: %s", SDLNet_GetError());
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   119
                clientQuit = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   120
                break;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   121
            }
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   122
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   123
            // update index position and check for End-Of-Message
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   124
            index += msgSize;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   125
            if (strncmp(&buffer[index-2], "\n\n", 2) == 0) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   126
                exitBufferLoop = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   127
            }
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   128
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   129
            // if message is too big allocate new space
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   130
            if (index >= dim) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   131
                dim += BUFFER_SIZE;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   132
                buffer = (char *)realloc(buffer, dim);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   133
                if (buffer == NULL) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   134
                    clientQuit = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   135
                    break;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   136
                }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   137
            }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   138
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   139
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   140
        NSString *bufferedMessage = [[NSString alloc] initWithBytes:buffer length:index-2 encoding:NSASCIIStringEncoding];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   141
        NSArray *listOfCommands = [bufferedMessage componentsSeparatedByString:@"\n"];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   142
        NSString *command = [listOfCommands objectAtIndex:0];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   143
        DLog(@"size = %d, %@", index-2, listOfCommands);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   144
        if ([command isEqualToString:@"PING"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   145
            if ([listOfCommands count] > 1)
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   146
                [self sendToServer:@"PONG" withArgument:[listOfCommands objectAtIndex:1]];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   147
            else
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   148
                [self sendToServer:@"PONG"];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   149
            DLog(@"PONG");
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   150
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   151
        else if ([command isEqualToString:@"NICK"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   152
            //what is this for?
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   153
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   154
        else if ([command isEqualToString:@"PROTO"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   155
            //what is this for?
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   156
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   157
        else if ([command isEqualToString:@"ROOM"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   158
            //TODO: stub
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   159
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   160
        else if ([command isEqualToString:@"LOBBY:LEFT"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   161
            //TODO: stub
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   162
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   163
        else if ([command isEqualToString:@"LOBBY:JOINED"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   164
            //TODO: stub
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   165
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   166
        else if ([command isEqualToString:@"ASKPASSWORD"]) {
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   167
            NSString *pwd = [defaults objectForKey:@"password"];
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   168
            [self sendToServer:@"PASSWORD" withArgument:pwd];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   169
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   170
        else if ([command isEqualToString:@"CONNECTED"]) {
4603
d362ab6c7f53 damn. it.
koda
parents: 4547
diff changeset
   171
            int netProto;
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   172
            char *versionStr;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   173
            HW_versionInfo(&netProto, &versionStr);
6246
6b2d19ed521a just moving ios server stuff around
koda
parents: 6078
diff changeset
   174
            NSString *nick = [defaults objectForKey:@"username"];
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   175
            [self sendToServer:@"NICK" withArgument:nick];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   176
            [self sendToServer:@"PROTO" withArgument:[NSString stringWithFormat:@"%d",netProto]];
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   177
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   178
        else if ([command isEqualToString:@"SERVER_MESSAGE"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   179
            DLog(@"%@", [listOfCommands objectAtIndex:1]);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   180
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   181
        else if ([command isEqualToString:@"WARNING"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   182
            if ([listOfCommands count] > 1)
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   183
                DLog(@"Server warning - %@", [listOfCommands objectAtIndex:1]);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   184
            else
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   185
                DLog(@"Server warning - unknown");
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   186
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   187
        else if ([command isEqualToString:@"ERROR"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   188
            DLog(@"Server error - %@", [listOfCommands objectAtIndex:1]);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   189
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   190
        else if ([command isEqualToString:@"BYE"]) {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   191
            //TODO: handle "Reconnected too fast"
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   192
            DLog(@"Server disconnected, reason: %@", [listOfCommands objectAtIndex:1]);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   193
            clientQuit = YES;
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   194
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   195
        else {
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   196
            DLog(@"Unknown/Unsupported message received: %@", command);
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   197
        }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   198
    }
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   199
    DLog(@"Server closed connection, ending thread");
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   200
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   201
    free(buffer);
6320
238a6dc0e7ad minor updates to ServerProtocolNetwork class
koda
parents: 6246
diff changeset
   202
    SDLNet_TCP_Close(self.ssd);
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   203
    SDLNet_Quit();
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   204
11137
14f50dde3e8c - Using of @autoreleasepool is better
Anton Malmygin <antonc27@mail.ru>
parents: 10108
diff changeset
   205
    }
4547
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   206
}
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   207
b70004a576a3 move server connection stuff in its own class
koda
parents:
diff changeset
   208
@end