[go: up one dir, main page]

Menu

[r19]: / udt / channel.h  Maximize  Restore  History

Download this file

220 lines (168 with data), 6.6 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
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
/*****************************************************************************
Copyright © 2001 - 2006, The Board of Trustees of the University of Illinois.
All Rights Reserved.
UDP-based Data Transfer Library (UDT) version 3
Laboratory for Advanced Computing (LAC)
National Center for Data Mining (NCDM)
University of Illinois at Chicago
http://www.lac.uic.edu/
This library is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or (at
your option) any later version.
This library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser
General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this library; if not, write to the Free Software Foundation, Inc.,
59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
*****************************************************************************/
/*****************************************************************************
This header file contains the definition of the UDP channel.
*****************************************************************************/
/*****************************************************************************
written by
Yunhong Gu [gu@lac.uic.edu], last updated 06/13/2006
*****************************************************************************/
#ifndef __UDT_CHANNEL_H__
#define __UDT_CHANNEL_H__
#include "udt.h"
#include "packet.h"
class CChannel
{
public:
CChannel();
CChannel(const int& version);
~CChannel();
// Functionality:
// Opne a UDP channel.
// Parameters:
// 0) [in] addr: The local address that UDP will use.
// Returned value:
// None.
void open(const sockaddr* addr = NULL);
// Functionality:
// Send data through the channel.
// Parameters:
// 0) [in] buffer: pointer to the data to be sent.
// 1) [in] size: size of the buffer.
// Returned value:
// Actual size of data sent.
int send(char* buffer, const int& size) const;
// Functionality:
// Receive data from the channel.
// Parameters:
// 0) [out] buffer: received data.
// 1) [in] size: size of the expected data received.
// Returned value:
// Actual size of data received.
int recv(char* buffer, const int& size) const;
// Functionality:
// Read the data from the channel but the data is not removed from UDP buffer.
// Parameters:
// 0) [out] buffer: previewed received data.
// 1) [in] size: size of the expected data received.
// Returned value:
// Actual size of data received.
int peek(char* buffer, const int& size) const;
// Functionality:
// Send a packet through the channel.
// Parameters:
// 0) [in] packet: reference to a CPacket entity.
// Returned value:
// The channel itself for serial output.
const CChannel& operator<<(CPacket& packet) const;
// Functionality:
// Receive a packet from the channel.
// Parameters:
// 0) [out] packet: reference to a CPacket entity.
// Returned value:
// The channel itself for serial input.
const CChannel& operator>>(CPacket& packet) const;
// Functionality:
// Send a packet to the given address.
// Parameters:
// 0) [in] packet: reference to a CPacket entity.
// 1) [in] addr: pointer to the destination address.
// Returned value:
// Actual size of data sent.
int sendto(CPacket& packet, const sockaddr* addr) const;
// Functionality:
// Receive a packet from the channel and record the source address.
// Parameters:
// 0) [in] packet: reference to a CPacket entity.
// 1) [in] addr: pointer to the source address.
// Returned value:
// Actual size of data received.
int recvfrom(CPacket& packet, sockaddr* addr) const;
// Functionality:
// Connect to the peer side whose address is in the sockaddr structure.
// Parameters:
// 0) [in] addr: pointer to the peer side address.
// Returned value:
// None.
void connect(const sockaddr* addr);
// Functionality:
// Disconnect and close the UDP entity.
// Parameters:
// None.
// Returned value:
// None.
void disconnect() const;
// Functionality:
// Get the UDP sending buffer size.
// Parameters:
// None.
// Returned value:
// Current UDP sending buffer size.
int getSndBufSize();
// Functionality:
// Get the UDP receiving buffer size.
// Parameters:
// None.
// Returned value:
// Current UDP receiving buffer size.
int getRcvBufSize();
// Functionality:
// Set the UDP sending buffer size.
// Parameters:
// 0) [in] size: expected UDP sending buffer size.
// Returned value:
// None.
void setSndBufSize(const int& size);
// Functionality:
// Set the UDP receiving buffer size.
// Parameters:
// 0) [in] size: expected UDP receiving buffer size.
// Returned value:
// None.
void setRcvBufSize(const int& size);
// Functionality:
// Query the socket address that the channel is using.
// Parameters:
// 0) [out] addr: pointer to store the returned socket address.
// Returned value:
// None.
void getSockAddr(sockaddr* addr) const;
// Functionality:
// Query the peer side socket address that the channel is connect to.
// Parameters:
// 0) [out] addr: pointer to store the returned socket address.
// Returned value:
// None.
void getPeerAddr(sockaddr* addr) const;
private:
int m_iIPversion; // IP version
#ifndef WIN32
int m_iSocket; // socket descriptor
#else
SOCKET m_iSocket;
#endif
int m_iSndBufSize; // UDP sending buffer size
int m_iRcvBufSize; // UDP receiving buffer size
char* m_pcChannelBuf; // buffer for temporally storage of in/out data
private:
void setChannelOpt();
};
#endif