Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/presentation/src/libraries/network/MasterServerComm.h @ 7765

Last change on this file since 7765 was 7765, checked in by smerkli, 13 years ago

prepared MSC for singleton usage.

File size: 3.4 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#ifndef MASTERSERVERCOMM_H
30#define MASTERSERVERCOMM_H
31
32#include <cstdlib>
33#include <cstdio>
34#include <string>
35#include <cstring>
36#include <enet/enet.h>
37
38// tolua_begin
39namespace orxonox
40{
41  class _NetworkExport MasterServerComm 
42    : public Singleton<MasterServerComm>, public OrxonoxClass
43  { // tolua_export
44    friend class Singleton<MasterServerComm>;
45    public: 
46      /** constructor */
47      MasterServerComm();
48
49      /** destructor */
50      ~MasterServerComm();
51
52      /** \return 0 for success, other for error
53       *
54       * Initialize everything for the master server communication
55       */
56      int initialize();
57
58
59      /** \param address Address to connect to (Host name or IP in text form)
60       * \param port Port to connect on
61       * \return 0 for success, other for error
62       *
63       * Connect to the master server with the given address on the given port.
64       */
65      int connect( const char *address, unsigned int port );
66
67      /** \return 0 for success, other for error
68       *
69       * Disconnect from master server.
70       */
71      int disconnect( void );
72
73      /** \param data The data to be sent.
74       * \return 0 for success, other for error.
75       *
76       * Send a request to the master server containing data specified in data
77       */
78      int sendRequest( const char *data );
79
80      /** \param data The data to be sent.
81       * \return 0 for success, other for error.
82       *
83       * Send a request to the master server containing data specified in data
84       * (string version)
85       */
86      int sendRequest( std::string data );
87
88      /** \param callback The callback function to call with data receivced.
89       * \return 0 for success, other for error
90       *
91       * Poll the master server for new data and act accordingly */
92      int pollForReply( int (*callback)( char*, ENetEvent* ), int delayms );
93
94      /** \return an instance of WANDiscovery
95       *
96       * Create and return an instance of WANDiscovery.
97       */
98      static MasterServerComm& getInstance() { return Singleton<MasterServerComm>::getInstance(); } // tolua_export
99
100    private:
101      /** client handle */
102      ENetHost *client;
103
104      /** event data holder */
105      ENetEvent *event;
106
107      /** address holder */
108      ENetAddress address;
109
110      /** peer data holder */
111      ENetPeer *peer;
112
113      /** Singleton pointer */
114      static MasterServerComm* singletonPtr_s;
115  }; // tolua_export
116
117} // tolua_export
118
119#endif /* MASTERSERVERCOMM_H */
Note: See TracBrowser for help on using the repository browser.