Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/masterserver/src/libraries/network/MasterServerComm.cc @ 7667

Last change on this file since 7667 was 7662, checked in by smerkli, 14 years ago

fatal bug found.

File size: 6.3 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Sandro 'smerkli' Merkli
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29#include "MasterServerComm.h"
30
31namespace orxonox
32{
33 
34  MasterServerComm::MasterServerComm()
35  { /* nothing anymore, everything's been outsourced to
36     * the initialize method to facilitate debugging
37     */
38  } 
39
40
41  int MasterServerComm::initialize()
42  {
43    /* initialize Enet */
44    if (enet_initialize () != 0)
45    { COUT(1) << "An error occurred while initializing ENet.\n";
46      return 1;
47    }
48   
49    /* install atexit handler for enet */
50    atexit( enet_deinitialize );
51
52
53    /* initiate the client */
54    this->client = enet_host_create( NULL /* create a client host */,
55        1,
56        2, /* allow up 2 channels to be used, 0 and 1 */
57        0, 
58        0 ); 
59
60    /* see if it worked */
61    if (this->client == NULL)
62    { COUT(1) << "An error occurred while trying to create an ENet client host.\n";
63      return 1;
64    }
65
66    return 0;
67  }
68
69  MasterServerComm::~MasterServerComm()
70  {
71    /* destroy the enet facilities */
72    enet_host_destroy(this->client);
73  }
74
75  int MasterServerComm::connect( char *address, unsigned int port )
76  {
77    /* Connect to address:port. */
78    enet_address_set_host( &this->address, address );
79    this->address.port = port;
80
81    /* Initiate the connection, allocating the two channels 0 and 1. */
82    this->peer = enet_host_connect(this->client, &this->address, 2, 0);   
83
84    if (this->peer == NULL )
85    { COUT(2) << "ERROR: No available peers for initiating an ENet connection.\n";
86    //exit (EXIT_FAILURE);
87    return -1;
88    }
89
90    /* Wait up to 2 seconds for the connection attempt to succeed. */
91    if (enet_host_service (this->client, &this->event, 2000) > 0 &&
92        this->event.type == ENET_EVENT_TYPE_CONNECT )
93      fprintf( stdout, "Connection to server succeeded." );
94    else
95    {
96      enet_peer_reset (this->peer);
97      fprintf( stdout, "Connection to %s failed.", address );
98      //exit(EXIT_FAILURE);
99      return -1;
100    }
101
102    return 0;
103  }
104
105  int MasterServerComm::pollForReply( int (*callback)( char*, ENetEvent* ) )
106  { 
107    /* see whether anything happened */
108    if( enet_host_service( this->client, &this->event, 100 ) >= 0 )
109    { 
110      /* address buffer */
111      char *addrconv = NULL;
112      int retval = 0;
113
114      /* check what type of event it is and react accordingly */
115      switch (this->event.type)
116      { /* new connection, not supposed to happen. */
117        case ENET_EVENT_TYPE_CONNECT: break;
118
119        /* disconnect */
120        case ENET_EVENT_TYPE_DISCONNECT: /* ?? */ break;
121
122        /* incoming data */
123        case ENET_EVENT_TYPE_RECEIVE: 
124          addrconv = (char *) calloc( 50, 1 );
125          enet_address_get_host_ip( &(this->event.peer->address), addrconv, 49 );
126
127          /* DEBUG */
128          printf( "A packet of length %u containing %s was "
129            "received from %s on channel %u.\n",
130            this->event.packet->dataLength,
131            this->event.packet->data,
132            addrconv,
133            this->event.channelID );
134          /* END DEBUG */
135
136          /* call the supplied callback, if any. */
137          if( (*callback) != NULL )
138            retval = (*callback)( addrconv, &(this->event) );
139
140          enet_packet_destroy( event.packet );
141          if( addrconv ) free( addrconv );
142          break;
143        default: break;
144      }
145
146      /* event handled, return 0 */
147      return retval;
148    }
149
150    /* show that no event occured */
151    return 1;
152  }
153
154  int MasterServerComm::sendRequest( char *data )
155  {
156    /* send the data to the friend */
157    /* Create a reliable packet of size 7 containing "packet\0" */
158    ENetPacket * packet = enet_packet_create( data, 
159        strlen( data ) + 1, 
160        ENET_PACKET_FLAG_RELIABLE);
161
162    /* Send the packet to the peer over channel id 0. */
163    enet_peer_send (this->peer, 0, packet);
164
165    /* One could just use enet_host_service() instead. */
166    enet_host_flush( this->client );
167    if( packet ) free( packet );
168
169    /* all done. */
170    return 0;
171  }
172
173  int MasterServerComm::sendRequest( std::string data )
174  {
175    /* send the data to the friend */
176    /* Create a reliable packet of size 7 containing "packet\0" */
177    ENetPacket * packet = enet_packet_create( data.c_str(), 
178        data.length() + 1, 
179        ENET_PACKET_FLAG_RELIABLE);
180
181    /* Send the packet to the peer over channel id 0. */
182    enet_peer_send (this->peer, 0, packet);
183
184    /* One could just use enet_host_service() instead. */
185    enet_host_flush( this->client );
186    if( packet ) free( packet );
187
188    /* all done. */
189    return 0;
190  }
191
192}
193
194
195/* DON'T DELETE THIS I MIGHT NEED IT AGAIN -smerkli */
196/* not needed anymore, only here for testing purposes */
197/*
198//[> sample callback to output debugging info. <]
199//int callb( char *addr, ENetEvent *ev )
200//{
201  //printf( "A packet of length %u containing %s was "
202      //"received from %s on channel %u.\n",
203      //ev->packet->dataLength,
204      //ev->packet->data,
205      //addr,
206      //ev->channelID );
207  //return 0;
208//}
209
210//[> small testing implementation <]
211//int
212//main( int argc, char *argv[] )
213//{
214  //[> setup object and connect <]
215  //MasterServerComm msc = MasterServerComm();
216  //if( msc.connect( argv[1], 1234 ) )
217    //exit(EXIT_FAILURE);
218 
219  //[> send some data and poll for replies <]
220  //char *theinput = (char *)calloc( 100,1 );
221  //while( true )
222  //{
223    //fgets( theinput, 90, stdin );
224    //if( !strncmp( theinput, "quit", 4 ) )
225      //break;
226
227    //msc.sendRequest( theinput );
228    //msc.pollForReply( &callb );
229  //}
230
231//}
232*/
Note: See TracBrowser for help on using the repository browser.