Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/network/src/network/Synchronisable.h @ 1742

Last change on this file since 1742 was 1742, checked in by scheusso, 16 years ago

compressing and diffing works now (also shipCache on client). server can't move while client connected. preparations for synchronise frequency of synchronisables

  • Property svn:eol-style set to native
File size: 3.0 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 *      Oliver Scheuss, (C) 2007
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29#ifndef _Synchronisable_H__
30#define _Synchronisable_H__
31
32#include "NetworkPrereqs.h"
33
34#include <list>
35#include "core/OrxonoxClass.h"
36#include "NetworkCallback.h"
37
38namespace network
39{
40  enum variableType{
41    DATA,
42    STRING,
43  };
44
45  struct synchronisableHeader{
46    unsigned int size;
47    unsigned int objectID;
48    unsigned int classID;
49  };
50
51  typedef struct synchronisableVariable{
52    unsigned int size;
53    int mode; // this determines in which direction the variable gets synchronised
54    void *var;
55    variableType type;
56    NetworkCallbackBase *callback;
57  }SYNCVAR;
58
59
60  /**
61  * This class is the base class of all the Objects in the universe that need to be synchronised over the network
62   * Every class, t
63  int mode;hat inherits from this class has to link the DATA THAT NEEDS TO BE SYNCHRONISED into the linked list. Additionally it also has to provide a Constructor, that takes exactly the variables in this linked list.
64  * @author Oliver Scheuss
65  */
66  class _NetworkExport Synchronisable : virtual public orxonox::OrxonoxClass{
67  public:
68
69    virtual ~Synchronisable();
70    unsigned int objectID;
71    unsigned int classID;
72
73    void registerVar(void *var, int size, variableType t, int mode=1, NetworkCallbackBase *cb=0);
74    bool getData(unsigned char*& men, unsigned int id, int mode=0x0);
75    int getSize2(unsigned int id, int mode=0x0);
76    bool updateData(unsigned char*& mem, int mode=0x0);
77    bool isMyData(unsigned char* mem);
78    void setBacksync(bool sync);
79    bool getBacksync();
80    virtual void registerAllVariables()=0;
81    virtual bool create();
82    static void setClient(bool b);
83   
84    static bool fabricate(unsigned char*& mem, int mode=0x0);
85  protected:
86    Synchronisable();
87  private:
88    int getSize(unsigned int id, int mode=0x0);
89    bool isMyTick(unsigned int id);
90    std::list<synchronisableVariable *> *syncList;
91    int datasize;
92    static int state_; // detemines wheter we are server (default) or client
93    bool backsync_; // if true the variables with mode > 1 will be synchronised to server (client -> server)
94    unsigned int objectFrequency_;
95  };
96}
97
98#endif /* _Synchronisable_H__ */
Note: See TracBrowser for help on using the repository browser.