Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/archive/tutorial2/src/libraries/network/WANDiscovery.h

Last change on this file was 8858, checked in by landauf, 13 years ago

merged output branch back to trunk.

Changes:

  • you have to include util/Output.h instead of util/Debug.h
  • COUT(x) is now called orxout(level)
  • output levels are now defined by an enum instead of numbers. see util/Output.h for the definition
  • it's possible to use output contexts with orxout(level, context). see util/Output.h for some common contexts. you can define more contexts
  • you must use 'endl' at the end of an output message, '\n' does not flush the message

Output levels:

  • instead of COUT(0) use orxout()
  • instead of COUT(1) use orxout(user_error) or orxout(internal_error)
  • instead of COUT(2) use orxout(user_warning) or orxout(internal_warning)
  • instead of COUT(3) use orxout(user_status/user_info) or orxout(internal_status/internal_info)
  • instead of COUT(4) use orxout(verbose)
  • instead of COUT(5) use orxout(verbose_more)
  • instead of COUT(6) use orxout(verbose_ultra)

Guidelines:

  • user_* levels are for the user, visible in the console and the log-file
  • internal_* levels are for developers, visible in the log-file
  • verbose_* levels are for debugging, only visible if the context of the output is activated

Usage in C++:

  • orxout() << "message" << endl;
  • orxout(level) << "message" << endl;
  • orxout(level, context) << "message" << endl;

Usage in Lua:

  • orxout("message")
  • orxout(orxonox.level.levelname, "message")
  • orxout(orxonox.level.levelname, "context", "message")

Usage in Tcl (and in the in-game-console):

  • orxout levelname message
  • orxout_context levelname context message
  • shortcuts: log message, error message, warning message, status message, info message, debug message
  • Property svn:eol-style set to native
File size: 2.8 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist > www.orxonox.net <
3 *
4 *
5 *   License notice:
6 *
7 *   This program is free software; you can redistribute it and/or modify it
8 *   under the terms of the GNU General Public License as published by the Free
9 *   Software Foundation; either version 2 of the License, or (at your option)
10 *   any later version.
11 *
12 *   This program is distributed in the hope that it will be useful, but
13 *   WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 *   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
15 *   for more details.
16 *
17 *   You should have received a copy of the GNU General Public License along
18 *   with this program; if not, write to the Free Software Foundation, Inc., 51
19 *   Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
20 *
21 *   Author:
22 *      Sandro 'smerkli' Merkli
23 *   Co-authors:
24 *      Oliver Scheuss (original)
25 *
26 */
27
28#ifndef _WANDiscovery_H__
29#define _WANDiscovery_H__
30
31#include "NetworkPrereqs.h"
32#include "packet/ServerInformation.h"
33#include "core/ConfigFileManager.h"
34#include "core/OrxonoxClass.h"
35#include "core/ConfigValueIncludes.h"
36#include "core/CoreIncludes.h"
37#include "MasterServerComm.h"
38#include "MasterServerProtocol.h"
39
40#include <vector>
41
42#define WANDISC_MAXTRIES 5
43
44// tolua_begin
45namespace orxonox
46{
47
48  class _NetworkExport WANDiscovery
49// tolua_end
50    : public OrxonoxClass
51  { // tolua_export
52    public:
53      /** constructor */
54      WANDiscovery(); // tolua_export
55
56      /** destructor */
57      ~WANDiscovery();
58
59      /** \return Address of the master server
60       *
61       * Get the master server address
62       */
63      std::string getMSAddress()
64      { return this->msaddress; }
65
66      /** ask server for server list  */
67      void discover(); // tolua_export
68
69      /** \param index Index to get the name of
70       * \return The name of the server
71       *
72       * Get the name of the server at index index.
73       */
74      std::string getServerListItemName( unsigned int index ); // tolua_export
75
76      /** \param index Index to get the IP of
77       * \return The IP of the server
78       *
79       * Get the IP of the server at index index.
80       */
81      std::string getServerListItemIP( unsigned int index ); // tolua_export
82
83      /* todo: might make this private and use getter/setter methods
84       * at some later time.
85       */
86      /** game server list */
87      std::vector<packet::ServerInformation> servers_;
88
89      /** Function used for the configuration file parameter update */
90      void setConfigValues();
91
92      /** Master server communications object */
93      MasterServerComm msc;
94
95      int rhandler( char *addr, ENetEvent *ev );
96     
97    private:
98      /** master server address */
99      std::string msaddress;
100
101  }; // tolua_export
102
103} // tolua_export
104
105#endif // _WANDiscovery_H__
Note: See TracBrowser for help on using the repository browser.