Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/network/src/lib/network/message_manager.h @ 7984

Last change on this file since 7984 was 7984, checked in by rennerc, 18 years ago

new NetworkGameManager

File size: 2.8 KB
RevLine 
[7631]1/*!
2 * @file message_manager.h
3 * @brief Definition of MessageManager
4*/
5
6#ifndef _MESSAGE_MANAGER_H
7#define _MESSAGE_MANAGER_H
8
9#include "synchronizeable.h"
10
[7671]11#include <map>
12#include <list>
[7631]13
[7671]14/*
15  Protocol:
16    int nacks
17    int acks[1..nacks]
18    int nmsg
19    (
20      int length
21      int number
[7678]22      int MessageId
[7671]23      byte * data
24    )[1..nmsg]
25*/
26
27
28enum MessageId
29{
[7984]30  TESTMESSAGEID = 1
[7671]31};
32
[7693]33typedef bool (*MessageCallback)( MessageId messageId, byte * data, int dataLength, void * someData, int userId );
[7678]34
[7671]35enum RecieverType
36{
37  RT_ALL = 1,   //!< message is sent to all users
38  RT_USER,      //!< message is only sent to reciever
39  RT_NOT_USER   //!< message is sent to all but reciever
40};
41
[7681]42//TODO implement priority handling
43enum MessagePriority
44{
45  MP_HIGHBANDWIDTH = 1,  //!< fast and reliable but uses a lot of bandwidth
46  MP_LOWBANDWIDTH,       //!< may take a long time to arrive. reliable
47  MP_UNRELIABLE          //!< unreliable. low bandwidth
48};
49
[7671]50struct NetworkMessage
51{
[7681]52  MessageId        messageId;
53  byte *           data;
54  int              length;
55  int              number;
56  MessagePriority  priority;
[7671]57};
58
59struct MessageUserQueue
60{
61  std::list<NetworkMessage> messages;
62  std::list<int>            toAck;
[7681]63  std::list<int>            recievedMessages;
[7671]64};
65
66typedef std::map<int,MessageUserQueue> MessageQueue;
67
68struct MessageHandler
69{
70  MessageCallback cb;
71  MessageId       messageId;
[7678]72  void *          someData;
[7671]73};
74
75typedef std::map<MessageId,MessageHandler> MessageHandlerMap;
76
[7631]77//! A class for sending messages over network
78class MessageManager : public Synchronizeable {
[7671]79 protected:
80   MessageManager();
[7631]81 public:
[7671]82   inline static MessageManager * getInstance(){ if (!singletonRef) singletonRef = new MessageManager();  return singletonRef; }
83   
[7631]84   virtual ~MessageManager();
[7671]85   
86   bool registerMessageHandler( MessageId messageId, MessageCallback cb, void * someData );
87   
[7681]88   void sendMessage( MessageId messageId, byte * data, int dataLength, RecieverType recieverType, int reciever, MessagePriority messagePriority );
[7631]89
90   virtual int getStateDiff( int userId, byte* data, int maxLength, int stateId, int fromStateId, int priorityTH );
91   virtual int setStateDiff( int userId, byte* data, int length, int stateId, int fromStateId );
92   virtual void cleanUpUser( int userId );
[7872]93   virtual void handleSentState( int userId, int stateId, int fromStateId ){}
94   virtual void handleRecvState( int userId, int stateId, int fromStateId ){}
[7671]95   
96   void initUser( int userId );
[7631]97
98
99 private:
[7693]100   static MessageManager *   singletonRef;
101   MessageQueue              messageQueue;           //!< stores messages to send
102   MessageHandlerMap         messageHandlerMap;      //!< contains handlers for messages
[7631]103
[7693]104   int                       newNumber;              //!< used to create unique message numbers
105   std::list<NetworkMessage> incomingMessabeBuffer; 
[7681]106
[7631]107};
108
109#endif /* _PROTO_CLASS_H */
Note: See TracBrowser for help on using the repository browser.