[go: up one dir, main page]

Menu

[r2]: / comm / gmp.h  Maximize  Restore  History

Download this file

147 lines (111 with data), 3.2 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
#ifndef __GMP_H__
#define __GMP_H__
#include <pthread.h>
#include <sys/time.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/stat.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <message.h>
#include <prec.h>
#include <vector>
#include <string>
#include <map>
#include <set>
#include <list>
#include <queue>
using namespace std;
class CGMPMessage
{
public:
CGMPMessage();
~CGMPMessage();
int32_t& m_iType; // 0 Data; 1 ACK
int32_t& m_iSession;
int32_t& m_iID; // message ID
int32_t& m_iInfo; //
char* m_pcData;
int m_iLength;
int32_t m_piHeader[4];
public:
void pack(const char* data, const int& len, const int32_t& info = 0);
void pack(const int32_t& type, const int32_t& info = 0);
public:
static int32_t g_iSession;
private:
static int32_t initSession();
static int32_t g_iID;
static pthread_mutex_t g_IDLock;
static const int32_t g_iMaxID = 0xFFFFFFF;
static const int m_iHdrSize = 16;
};
struct CMsgRecord
{
char m_pcIP[64];
int m_iPort;
CGMPMessage* m_pMsg;
timeval m_TimeStamp;
};
struct CFMsgRec
{
bool operator()(const CMsgRecord* m1, const CMsgRecord* m2) const
{
if (strcmp(m1->m_pcIP, m2->m_pcIP) == 0)
{
if (m1->m_iPort == m2->m_iPort)
return m1->m_pMsg->m_iID > m2->m_pMsg->m_iID;
return (m1->m_iPort > m2->m_iPort);
}
return strcmp(m1->m_pcIP, m2->m_pcIP);
}
};
class CGMP
{
public:
CGMP();
~CGMP();
public:
int init(const int& port = 0);
int close();
public:
int sendto(const char* ip, const int& port, int32_t& id, const char* data, const int& len, const bool& reliable = true);
int recvfrom(char* ip, int& port, int32_t& id, char* data, int& len);
int recv(const int32_t& id, char* data, int& len);
private:
int UDPsend(const char* ip, const int& port, int32_t& id, const char* data, const int& len, const bool& reliable = true);
int TCPsend(const char* ip, const int& port, int32_t& id, const char* data, const int& len);
public:
int sendto(const char* ip, const int& port, int32_t& id, const CUserMessage* msg);
int recvfrom(char* ip, int& port, int32_t& id, CUserMessage* msg);
int recv(const int32_t& id, CUserMessage* msg);
int rpc(const char* ip, const int& port, CUserMessage* req, CUserMessage* res);
int rtt(const char* ip, const int& port);
private:
pthread_t m_SndThread;
pthread_t m_RcvThread;
pthread_t m_TCPRcvThread;
static void* sndHandler(void*);
static void* rcvHandler(void*);
static void* tcpRcvHandler(void*);
pthread_mutex_t m_SndQueueLock;
pthread_cond_t m_SndQueueCond;
pthread_mutex_t m_RcvQueueLock;
pthread_cond_t m_RcvQueueCond;
pthread_mutex_t m_ResQueueLock;
pthread_cond_t m_ResQueueCond;
pthread_mutex_t m_RTTLock;
pthread_cond_t m_RTTCond;
private:
int m_iPort;
int m_iUDPSocket;
int m_iTCPSocket;
list<CMsgRecord*> m_lSndQueue;
queue<CMsgRecord*> m_qRcvQueue;
map<int32_t, CMsgRecord*> m_mResQueue;
CPeerManagement m_PeerHistory;
volatile bool m_bClosed;
private:
static const int m_iMaxUDPMsgSize = 1456;
};
#endif