summaryrefslogtreecommitdiff
path: root/source/net_chan.h
blob: 64d57facd1f267dff96c5455fd30bc4154dfaae2 (plain)
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
/*
Copyright (C) 1997-2001 Id Software, Inc.

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program 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 General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

*/
// net_chan.h

typedef struct netchan_old_s {
	netchan_t	pub;

// sequencing variables
	int			incoming_reliable_acknowledged;	// single bit
	int			incoming_reliable_sequence;		// single bit, maintained local
	int			reliable_sequence;			// single bit
	int			last_reliable_sequence;		// sequence number of last send

	byte		*message_buf;		// leave space for header

// message is copied to this buffer when it is first transfered
	byte		*reliable_buf;	// unacked reliable message
} netchan_old_t;

typedef struct netchan_new_s {
	netchan_t	pub;

// sequencing variables
	int			incoming_reliable_acknowledged;	// single bit
	int			incoming_reliable_sequence;		// single bit, maintained local
	int			reliable_sequence;			// single bit
	int			last_reliable_sequence;		// sequence number of last send
	int			fragment_sequence;

// reliable staging and holding areas
	byte		message_buf[MAX_MSGLEN];		// leave space for header

// message is copied to this buffer when it is first transfered
	byte		reliable_buf[MAX_MSGLEN];	// unacked reliable message

	sizebuf_t   fragment_in;
	byte		fragment_in_buf[MAX_MSGLEN];

	sizebuf_t	fragment_out;
	byte		fragment_out_buf[MAX_MSGLEN];
} netchan_new_t;