Networking patch from Jasper Foreman

git-svn-id: https://svn.eduke32.com/eduke32@3270 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
terminx 2012-12-12 02:53:13 +00:00
parent 5c59f785a1
commit fbdbca2952
8 changed files with 541 additions and 640 deletions

View file

@ -490,8 +490,16 @@ void A_DeleteSprite(int32_t s)
A_DeleteLight(s); A_DeleteLight(s);
#endif #endif
// NetAlloc
if (Net_IsRelevantSprite(s))
{
Net_DeleteSprite(s);
}
else
{
deletesprite(s); deletesprite(s);
} }
}
void A_AddToDeleteQueue(int32_t i) void A_AddToDeleteQueue(int32_t i)
{ {

View file

@ -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 {

View file

@ -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

View file

@ -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

View file

@ -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,49 +99,35 @@ 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 pos;
vec3_t opos; vec3_t opos;
vec3_t vel; vec3_t vel;
@ -158,7 +142,8 @@ typedef struct {
#pragma pack(pop) #pragma pack(pop)
#pragma pack(push,1) #pragma pack(push,1)
typedef struct { typedef struct
{
int8_t header; int8_t header;
int8_t connection; int8_t connection;
int8_t level_number; int8_t level_number;
@ -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,6 +227,7 @@ 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);
@ -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

View file

@ -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;

View file

@ -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);