diff options
author | Simon Howard | 2006-03-02 00:03:48 +0000 |
---|---|---|
committer | Simon Howard | 2006-03-02 00:03:48 +0000 |
commit | 4846529e74168926e8e7b381b994fabb13f34e82 (patch) | |
tree | eb6063d699aaaa0bfba5ad3b6a96613c42fe9be7 /src | |
parent | a01d3d479e293dc6109093ec78c00baf145f5266 (diff) | |
download | chocolate-doom-4846529e74168926e8e7b381b994fabb13f34e82.tar.gz chocolate-doom-4846529e74168926e8e7b381b994fabb13f34e82.tar.bz2 chocolate-doom-4846529e74168926e8e7b381b994fabb13f34e82.zip |
Rearrange client connect code; fix name resolving under windows
Subversion-branch: /trunk/chocolate-doom
Subversion-revision: 403
Diffstat (limited to 'src')
-rw-r--r-- | src/d_net.c | 44 |
1 files changed, 26 insertions, 18 deletions
diff --git a/src/d_net.c b/src/d_net.c index 42c2efdc..98e8a2f6 100644 --- a/src/d_net.c +++ b/src/d_net.c @@ -1,7 +1,7 @@ // Emacs style mode select -*- C++ -*- //----------------------------------------------------------------------------- // -// $Id: d_net.c 397 2006-02-27 19:39:26Z fraggle $ +// $Id: d_net.c 403 2006-03-02 00:03:48Z fraggle $ // // Copyright(C) 1993-1996 Id Software, Inc. // Copyright(C) 2005 Simon Howard @@ -117,7 +117,7 @@ //----------------------------------------------------------------------------- -static const char rcsid[] = "$Id: d_net.c 397 2006-02-27 19:39:26Z fraggle $"; +static const char rcsid[] = "$Id: d_net.c 403 2006-03-02 00:03:48Z fraggle $"; #include "d_main.h" @@ -254,7 +254,8 @@ extern int viewangleoffset; void D_CheckNetGame (void) { - net_addr_t *addr = NULL; + net_module_t *connect_module = NULL; + char *connect_addr; int i; int num_players; @@ -281,7 +282,8 @@ void D_CheckNetGame (void) { NET_SV_Init(); - addr = net_loop_client_module.ResolveAddress(""); + connect_module = &net_loop_client_module; + connect_addr = ""; } else { @@ -289,27 +291,33 @@ void D_CheckNetGame (void) if (i > 0) { - addr = net_sdl_module.ResolveAddress(myargv[i+1]); - - if (addr == NULL) - { - I_Error("Unable to resolve \"%s\"", myargv[i+1]); - } + connect_module = &net_sdl_module; + connect_addr = myargv[i+1]; } } - - if (addr != NULL) + + if (connect_module != NULL) { - if (NET_CL_Connect(addr)) - { - printf("D_CheckNetGame: Connected to %s\n", NET_AddrToString(addr)); + net_addr_t *addr; + + connect_module->InitClient(); - NET_WaitForStart(); + addr = connect_module->ResolveAddress(connect_addr); + + if (addr == NULL) + { + I_Error("Unable to resolve \"%s\"", connect_addr); } - else + + if (!NET_CL_Connect(addr)) { - I_Error("D_CheckNetGame: Failed to connect to %s\n", NET_AddrToString(addr)); + I_Error("D_CheckNetGame: Failed to connect to %s\n", + NET_AddrToString(addr)); } + + printf("D_CheckNetGame: Connected to %s\n", NET_AddrToString(addr)); + + NET_WaitForStart(); } num_players = 0; |