mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Networking patch from Jasper Foreman
git-svn-id: https://svn.eduke32.com/eduke32@3270 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
5c59f785a1
commit
fbdbca2952
8 changed files with 541 additions and 640 deletions
|
@ -490,7 +490,15 @@ void A_DeleteSprite(int32_t s)
|
||||||
A_DeleteLight(s);
|
A_DeleteLight(s);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
deletesprite(s);
|
// NetAlloc
|
||||||
|
if (Net_IsRelevantSprite(s))
|
||||||
|
{
|
||||||
|
Net_DeleteSprite(s);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
deletesprite(s);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void A_AddToDeleteQueue(int32_t i)
|
void A_AddToDeleteQueue(int32_t i)
|
||||||
|
|
|
@ -45,6 +45,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
#define STAT_FALLER 12
|
#define STAT_FALLER 12
|
||||||
#define STAT_DUMMYPLAYER 13
|
#define STAT_DUMMYPLAYER 13
|
||||||
#define STAT_LIGHT 14
|
#define STAT_LIGHT 14
|
||||||
|
#define STAT_NETALLOC 15
|
||||||
|
|
||||||
|
|
||||||
// Defines the motion characteristics of an actor
|
// Defines the motion characteristics of an actor
|
||||||
|
@ -165,6 +166,9 @@ typedef struct {
|
||||||
|
|
||||||
int16_t actorstayput, dispicnum, shootzvel, cgg; // 8b
|
int16_t actorstayput, dispicnum, shootzvel, cgg; // 8b
|
||||||
|
|
||||||
|
spritetype sprite;
|
||||||
|
int16_t netIndex;
|
||||||
|
|
||||||
} netactor_t;
|
} netactor_t;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
|
@ -3948,7 +3948,19 @@ static void G_DumpDebugInfo(void)
|
||||||
int32_t A_InsertSprite(int32_t whatsect,int32_t s_x,int32_t s_y,int32_t s_z,int32_t s_pn,int32_t s_s,
|
int32_t A_InsertSprite(int32_t whatsect,int32_t s_x,int32_t s_y,int32_t s_z,int32_t s_pn,int32_t s_s,
|
||||||
int32_t s_xr,int32_t s_yr,int32_t s_a,int32_t s_ve,int32_t s_zv,int32_t s_ow,int32_t s_ss)
|
int32_t s_xr,int32_t s_yr,int32_t s_a,int32_t s_ve,int32_t s_zv,int32_t s_ow,int32_t s_ss)
|
||||||
{
|
{
|
||||||
int32_t p, i = insertsprite(whatsect,s_ss);
|
int32_t p;
|
||||||
|
int32_t i;
|
||||||
|
|
||||||
|
// NetAlloc
|
||||||
|
if (Net_IsRelevantStat(s_ss))
|
||||||
|
{
|
||||||
|
i = Net_InsertSprite(whatsect,s_ss);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
i = insertsprite(whatsect,s_ss);
|
||||||
|
}
|
||||||
|
|
||||||
spritetype *s = &sprite[i];
|
spritetype *s = &sprite[i];
|
||||||
spritetype spr_temp;
|
spritetype spr_temp;
|
||||||
|
|
||||||
|
@ -6036,21 +6048,6 @@ SPAWN_END:
|
||||||
VM_OnEvent(EVENT_SPAWN,i, pl, p, 0);
|
VM_OnEvent(EVENT_SPAWN,i, pl, p, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// spawning is technically not allowed to fail in BUILD, so we just hide whatever
|
|
||||||
// the client spawns with SPRITE_NULL because the server will send it anyway
|
|
||||||
/*
|
|
||||||
if (g_netClient && j >= 0)
|
|
||||||
{
|
|
||||||
int32_t zz;
|
|
||||||
for (zz = 0; (unsigned)zz < (sizeof(g_netStatnums)/sizeof(g_netStatnums[0])); zz++)
|
|
||||||
if (sprite[i].statnum == g_netStatnums[zz])
|
|
||||||
{
|
|
||||||
actor[i].flags |= SPRITE_NULL;
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9932,7 +9929,6 @@ int32_t app_main(int32_t argc, const char **argv)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Bassert(sizeof(actor_t)==128);
|
Bassert(sizeof(actor_t)==128);
|
||||||
Bassert(offsetof(actor_t, lightId) == sizeof(netactor_t));
|
|
||||||
Bassert(sizeof(DukePlayer_t)%4 == 0);
|
Bassert(sizeof(DukePlayer_t)%4 == 0);
|
||||||
|
|
||||||
initialize_globals();
|
initialize_globals();
|
||||||
|
@ -10963,9 +10959,10 @@ int32_t G_DoMoveThings(void)
|
||||||
G_AnimateWalls();
|
G_AnimateWalls();
|
||||||
A_MoveCyclers();
|
A_MoveCyclers();
|
||||||
|
|
||||||
// Map updates are disabled for now
|
if (g_netServer && (everyothertime % 10) == 0)
|
||||||
// if (g_netServer && (everyothertime % 10) == 0)
|
{
|
||||||
// Net_SendMapUpdate();
|
Net_SendMapUpdate();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_netClient) //Slave
|
if (g_netClient) //Slave
|
||||||
|
|
|
@ -200,6 +200,7 @@ labels =
|
||||||
STAT_FALLER = 12,
|
STAT_FALLER = 12,
|
||||||
STAT_DUMMYPLAYER = 13,
|
STAT_DUMMYPLAYER = 13,
|
||||||
STAT_LIGHT = 14,
|
STAT_LIGHT = 14,
|
||||||
|
STAT_NETALLOC = 15,
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -25,7 +25,6 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "enet/enet.h"
|
#include "enet/enet.h"
|
||||||
|
|
||||||
extern uint32_t g_netMapRevision;
|
|
||||||
extern ENetHost *g_netClient;
|
extern ENetHost *g_netClient;
|
||||||
extern ENetHost *g_netServer;
|
extern ENetHost *g_netServer;
|
||||||
extern ENetPeer *g_netClientPeer;
|
extern ENetPeer *g_netClientPeer;
|
||||||
|
@ -34,10 +33,11 @@ extern int32_t g_netDisconnect;
|
||||||
extern int32_t g_netPlayersWaiting;
|
extern int32_t g_netPlayersWaiting;
|
||||||
extern enet_uint16 g_netPort;
|
extern enet_uint16 g_netPort;
|
||||||
extern int32_t g_networkMode;
|
extern int32_t g_networkMode;
|
||||||
|
extern int32_t g_netIndex;
|
||||||
extern int32_t lastsectupdate[MAXSECTORS];
|
extern int32_t lastsectupdate[MAXSECTORS];
|
||||||
extern int32_t lastupdate[MAXSPRITES];
|
extern int32_t lastupdate[MAXSPRITES];
|
||||||
extern int32_t lastwallupdate[MAXWALLS];
|
extern int32_t lastwallupdate[MAXWALLS];
|
||||||
extern int16_t g_netStatnums[10];
|
extern int16_t g_netStatnums[];
|
||||||
|
|
||||||
#define NET_REVISIONS 64
|
#define NET_REVISIONS 64
|
||||||
|
|
||||||
|
@ -45,7 +45,6 @@ enum netchan_t
|
||||||
{
|
{
|
||||||
CHAN_MOVE, // unreliable movement packets
|
CHAN_MOVE, // unreliable movement packets
|
||||||
CHAN_GAMESTATE, // gamestate changes... frags, respawns, player names, etc
|
CHAN_GAMESTATE, // gamestate changes... frags, respawns, player names, etc
|
||||||
CHAN_SYNC, // client join sync packets
|
|
||||||
CHAN_CHAT, // chat and RTS
|
CHAN_CHAT, // chat and RTS
|
||||||
CHAN_MISC, // whatever else
|
CHAN_MISC, // whatever else
|
||||||
CHAN_MAX
|
CHAN_MAX
|
||||||
|
@ -61,7 +60,6 @@ enum DukePacket_t
|
||||||
PACKET_PLAYER_DISCONNECTED,
|
PACKET_PLAYER_DISCONNECTED,
|
||||||
PACKET_PLAYER_SPAWN,
|
PACKET_PLAYER_SPAWN,
|
||||||
PACKET_FRAG,
|
PACKET_FRAG,
|
||||||
PACKET_REQUEST_GAMESTATE,
|
|
||||||
PACKET_VERSION,
|
PACKET_VERSION,
|
||||||
PACKET_AUTH,
|
PACKET_AUTH,
|
||||||
PACKET_PLAYER_PING,
|
PACKET_PLAYER_PING,
|
||||||
|
@ -101,77 +99,64 @@ enum netmode_t
|
||||||
NET_DEDICATED_SERVER
|
NET_DEDICATED_SERVER
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define NETMAXACTORS 1024
|
||||||
|
|
||||||
#pragma pack(push,1)
|
#pragma pack(push,1)
|
||||||
typedef struct {
|
typedef struct
|
||||||
uint32_t revision;
|
{
|
||||||
int32_t animategoal[MAXANIMATES], animatevel[MAXANIMATES], g_animateCount;
|
|
||||||
int32_t animateptr[MAXANIMATES];
|
|
||||||
int32_t msx[2048], msy[2048];
|
|
||||||
int32_t randomseed, g_globalRandom;
|
|
||||||
|
|
||||||
int16_t SpriteDeletionQueue[1024],g_spriteDeleteQueuePos;
|
uint32_t numActors;
|
||||||
int16_t animatesect[MAXANIMATES];
|
netactor_t actor[NETMAXACTORS];
|
||||||
int16_t cyclers[MAXCYCLERS][6];
|
|
||||||
int16_t g_mirrorWall[64], g_mirrorSector[64], g_mirrorCount;
|
|
||||||
int16_t g_numAnimWalls;
|
|
||||||
int16_t g_numCyclers;
|
|
||||||
int16_t headspritesect[MAXSECTORS+1];
|
|
||||||
int16_t headspritestat[MAXSTATUS+1];
|
|
||||||
int16_t nextspritesect[MAXSPRITES];
|
|
||||||
int16_t nextspritestat[MAXSPRITES];
|
|
||||||
int16_t numsectors;
|
|
||||||
int16_t numwalls;
|
|
||||||
int16_t prevspritesect[MAXSPRITES];
|
|
||||||
int16_t prevspritestat[MAXSPRITES];
|
|
||||||
|
|
||||||
uint8_t g_earthquakeTime;
|
|
||||||
int8_t g_numPlayerSprites;
|
|
||||||
uint8_t scriptptrs[MAXSPRITES];
|
|
||||||
|
|
||||||
netactor_t actor[MAXSPRITES];
|
|
||||||
playerspawn_t g_playerSpawnPoints[MAXPLAYERS];
|
|
||||||
animwalltype animwall[MAXANIMWALLS];
|
|
||||||
sectortype sector[MAXSECTORS];
|
|
||||||
spriteext_t spriteext[MAXSPRITES];
|
|
||||||
spritetype sprite[MAXSPRITES];
|
|
||||||
walltype wall[MAXWALLS];
|
|
||||||
uint32_t crc;
|
|
||||||
} netmapstate_t;
|
} netmapstate_t;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
|
||||||
|
uint32_t numActors;
|
||||||
|
uint32_t numToDelete;
|
||||||
|
uint32_t fromRevision;
|
||||||
|
uint32_t toRevision;
|
||||||
|
char data[MAXSPRITES *sizeof(netactor_t)];
|
||||||
|
|
||||||
|
} netmapdiff_t;
|
||||||
|
|
||||||
extern netmapstate_t *g_multiMapState[MAXPLAYERS];
|
extern netmapstate_t *g_multiMapState[MAXPLAYERS];
|
||||||
extern netmapstate_t *g_multiMapRevisions[NET_REVISIONS];
|
extern netmapstate_t *g_multiMapRevisions[NET_REVISIONS];
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
#pragma pack(push,1)
|
#pragma pack(push,1)
|
||||||
typedef struct {
|
typedef struct
|
||||||
vec3_t pos;
|
{
|
||||||
vec3_t opos;
|
vec3_t pos;
|
||||||
vec3_t vel;
|
vec3_t opos;
|
||||||
int16_t ang;
|
vec3_t vel;
|
||||||
int16_t horiz;
|
int16_t ang;
|
||||||
int16_t horizoff;
|
int16_t horiz;
|
||||||
int16_t ping;
|
int16_t horizoff;
|
||||||
int16_t playerindex;
|
int16_t ping;
|
||||||
int16_t deadflag;
|
int16_t playerindex;
|
||||||
int16_t playerquitflag;
|
int16_t deadflag;
|
||||||
|
int16_t playerquitflag;
|
||||||
} playerupdate_t;
|
} playerupdate_t;
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
#pragma pack(push,1)
|
#pragma pack(push,1)
|
||||||
typedef struct {
|
typedef struct
|
||||||
int8_t header;
|
{
|
||||||
int8_t connection;
|
int8_t header;
|
||||||
int8_t level_number;
|
int8_t connection;
|
||||||
int8_t volume_number;
|
int8_t level_number;
|
||||||
int8_t player_skill;
|
int8_t volume_number;
|
||||||
int8_t monsters_off;
|
int8_t player_skill;
|
||||||
int8_t respawn_monsters;
|
int8_t monsters_off;
|
||||||
int8_t respawn_items;
|
int8_t respawn_monsters;
|
||||||
int8_t respawn_inventory;
|
int8_t respawn_items;
|
||||||
int8_t marker;
|
int8_t respawn_inventory;
|
||||||
int8_t ffire;
|
int8_t marker;
|
||||||
int8_t noexits;
|
int8_t ffire;
|
||||||
int8_t coop;
|
int8_t noexits;
|
||||||
|
int8_t coop;
|
||||||
} newgame_t;
|
} newgame_t;
|
||||||
#pragma pack(pop)
|
#pragma pack(pop)
|
||||||
|
|
||||||
|
@ -212,11 +197,22 @@ void Net_ReceiveClientInfo(uint8_t *pbuf, int32_t packbufleng, int32_t fromse
|
||||||
void Net_SendUserMapName(void);
|
void Net_SendUserMapName(void);
|
||||||
void Net_ReceiveUserMapName(uint8_t *pbuf, int32_t packbufleng);
|
void Net_ReceiveUserMapName(uint8_t *pbuf, int32_t packbufleng);
|
||||||
|
|
||||||
void Net_SendClientSync(ENetEvent *event, int32_t player);
|
netmapstate_t *Net_GetRevision(uint8_t revision, uint8_t cancreate);
|
||||||
void Net_ReceiveClientSync(ENetEvent *event);
|
|
||||||
|
|
||||||
void Net_SendMapUpdate(void);
|
void Net_SendMapUpdate(void);
|
||||||
void Net_ReceiveMapUpdate(uint8_t *pbuf, int32_t packbufleng);
|
void Net_ReceiveMapUpdate(ENetEvent *event);
|
||||||
|
|
||||||
|
void Net_FillMapDiff(uint32_t fromRevision, uint32_t toRevision);
|
||||||
|
void Net_SaveMapState(netmapstate_t *save);
|
||||||
|
void Net_RestoreMapState();
|
||||||
|
|
||||||
|
void Net_CopyToNet(int32_t i, netactor_t &netactor);
|
||||||
|
void Net_CopyFromNet(int32_t i, netactor_t &netactor);
|
||||||
|
int32_t Net_ActorsAreDifferent(netactor_t &actor1, netactor_t &actor2);
|
||||||
|
int32_t Net_IsRelevantSprite(int32_t i);
|
||||||
|
int32_t Net_IsRelevantStat(int32_t stat);
|
||||||
|
int32_t Net_InsertSprite(int32_t sect, int32_t stat);
|
||||||
|
void Net_DeleteSprite(int32_t spritenum);
|
||||||
|
|
||||||
void Net_FillPlayerUpdate(playerupdate_t *update, int32_t player);
|
void Net_FillPlayerUpdate(playerupdate_t *update, int32_t player);
|
||||||
void Net_ExtractPlayerUpdate(playerupdate_t *update);
|
void Net_ExtractPlayerUpdate(playerupdate_t *update);
|
||||||
|
@ -231,11 +227,12 @@ void Net_SendMessage(void);
|
||||||
void Net_ReceiveMessage(uint8_t *pbuf, int32_t packbufleng);
|
void Net_ReceiveMessage(uint8_t *pbuf, int32_t packbufleng);
|
||||||
|
|
||||||
void Net_StartNewGame();
|
void Net_StartNewGame();
|
||||||
|
void Net_NotifyNewGame();
|
||||||
void Net_SendNewGame(int32_t frommenu, ENetPeer *peer);
|
void Net_SendNewGame(int32_t frommenu, ENetPeer *peer);
|
||||||
void Net_ReceiveNewGame(ENetEvent *event);
|
void Net_ReceiveNewGame(ENetEvent *event);
|
||||||
|
|
||||||
void Net_FillNewGame(newgame_t* newgame, int32_t frommenu);
|
void Net_FillNewGame(newgame_t *newgame, int32_t frommenu);
|
||||||
void Net_ExtractNewGame(newgame_t* newgame, int32_t menuonly);
|
void Net_ExtractNewGame(newgame_t *newgame, int32_t menuonly);
|
||||||
|
|
||||||
void Net_SendMapVoteInitiate(void);
|
void Net_SendMapVoteInitiate(void);
|
||||||
void Net_RecieveMapVoteInitiate(uint8_t *pbuf);
|
void Net_RecieveMapVoteInitiate(uint8_t *pbuf);
|
||||||
|
@ -250,12 +247,12 @@ void Net_RecieveMapVoteCancel(uint8_t *pbuf);
|
||||||
//////////
|
//////////
|
||||||
|
|
||||||
void Net_ResetPrediction(void);
|
void Net_ResetPrediction(void);
|
||||||
void Net_RestoreMapState(netmapstate_t *save);
|
|
||||||
void Net_SyncPlayer(ENetEvent *event);
|
void Net_SyncPlayer(ENetEvent *event);
|
||||||
void Net_WaitForServer(void);
|
void Net_WaitForServer(void);
|
||||||
void faketimerhandler(void);
|
void faketimerhandler(void);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
/* NETCODE_ENABLE is not defined */
|
/* NETCODE_ENABLE is not defined */
|
||||||
|
|
||||||
// Connect/Disconnect
|
// Connect/Disconnect
|
||||||
|
|
|
@ -1992,6 +1992,7 @@ int32_t G_EnterLevel(int32_t g)
|
||||||
|
|
||||||
//PREMAP.C - replace near the my's at the end of the file
|
//PREMAP.C - replace near the my's at the end of the file
|
||||||
|
|
||||||
|
Net_NotifyNewGame();
|
||||||
Net_ResetPrediction();
|
Net_ResetPrediction();
|
||||||
|
|
||||||
//g_player[myconnectindex].ps->palette = palette;
|
//g_player[myconnectindex].ps->palette = palette;
|
||||||
|
|
|
@ -1947,6 +1947,12 @@ void A_DamageObject(int32_t i,int32_t sn)
|
||||||
int16_t j;
|
int16_t j;
|
||||||
int32_t k, rpg=0;
|
int32_t k, rpg=0;
|
||||||
spritetype *s;
|
spritetype *s;
|
||||||
|
|
||||||
|
if (g_netClient)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// int32_t switchpicnum = PN;
|
// int32_t switchpicnum = PN;
|
||||||
|
|
||||||
i &= (MAXSPRITES-1);
|
i &= (MAXSPRITES-1);
|
||||||
|
|
Loading…
Reference in a new issue