summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Howard2006-05-05 19:49:34 +0000
committerSimon Howard2006-05-05 19:49:34 +0000
commit319f427c9369bfe1c5a6cad636ecd91934c3024d (patch)
tree070bef41921a855a7e39d380e87d8c38978e97a1
parentcbd744280545a38e62ecc0290a1312b3aeff9ae0 (diff)
downloadchocolate-doom-319f427c9369bfe1c5a6cad636ecd91934c3024d.tar.gz
chocolate-doom-319f427c9369bfe1c5a6cad636ecd91934c3024d.tar.bz2
chocolate-doom-319f427c9369bfe1c5a6cad636ecd91934c3024d.zip
Syncronise the -timer/-avg parameters across all clients to avoid desyncs.
Subversion-branch: /trunk/chocolate-doom Subversion-revision: 475
-rw-r--r--src/d_main.c17
-rw-r--r--src/d_net.c19
-rw-r--r--src/doomstat.h5
-rw-r--r--src/g_game.c10
-rw-r--r--src/net_client.c4
-rw-r--r--src/net_defs.h3
-rw-r--r--src/net_structrw.c6
-rw-r--r--src/p_spec.c25
8 files changed, 53 insertions, 36 deletions
diff --git a/src/d_main.c b/src/d_main.c
index d9b5853b..d7d94145 100644
--- a/src/d_main.c
+++ b/src/d_main.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: d_main.c 467 2006-04-09 02:50:34Z fraggle $
+// $Id: d_main.c 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -184,7 +184,7 @@
//-----------------------------------------------------------------------------
-static const char rcsid[] = "$Id: d_main.c 467 2006-04-09 02:50:34Z fraggle $";
+static const char rcsid[] = "$Id: d_main.c 475 2006-05-05 19:49:34Z fraggle $";
#define BGCOLOR 7
#define FGCOLOR 8
@@ -1600,21 +1600,22 @@ void D_DoomMain (void)
autostart = true;
}
+ timelimit = 0;
+
p = M_CheckParm ("-timer");
if (p && p < myargc-1 && deathmatch)
{
- int time;
- time = atoi(myargv[p+1]);
- printf(DEH_String("Levels will end after %d minute"),time);
- if (time>1)
- printf("s");
- printf(".\n");
+ timelimit = atoi(myargv[p+1]);
+ printf("timer: %i\n", timelimit);
}
p = M_CheckParm ("-avg");
if (p && p < myargc-1 && deathmatch)
+ {
printf(DEH_String("Austin Virtual Gaming: Levels will end "
"after 20 minutes\n"));
+ timelimit = 20;
+ }
p = M_CheckParm ("-warp");
if (p && p < myargc-1)
diff --git a/src/d_net.c b/src/d_net.c
index 1a51c4df..5370e623 100644
--- a/src/d_net.c
+++ b/src/d_net.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: d_net.c 470 2006-04-14 15:25:42Z fraggle $
+// $Id: d_net.c 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -117,7 +117,7 @@
//-----------------------------------------------------------------------------
-static const char rcsid[] = "$Id: d_net.c 470 2006-04-14 15:25:42Z fraggle $";
+static const char rcsid[] = "$Id: d_net.c 475 2006-05-05 19:49:34Z fraggle $";
#include "doomfeatures.h"
@@ -131,6 +131,8 @@ static const char rcsid[] = "$Id: d_net.c 470 2006-04-14 15:25:42Z fraggle $";
#include "doomdef.h"
#include "doomstat.h"
+#include "deh_main.h"
+
#include "net_client.h"
#include "net_gui.h"
#include "net_io.h"
@@ -375,12 +377,21 @@ void D_CheckNetGame (void)
++num_players;
}
- printf ("startskill %i deathmatch: %i startmap: %i startepisode: %i\n",
+ printf (DEH_String("startskill %i deathmatch: %i startmap: %i startepisode: %i\n"),
startskill, deathmatch, startmap, startepisode);
- printf ("player %i of %i (%i nodes)\n",
+ printf(DEH_String("player %i of %i (%i nodes)\n"),
consoleplayer+1, num_players, num_players);
+ // Show players here; the server might have specified a time limit
+
+ if (timelimit > 0)
+ {
+ printf(DEH_String("Levels will end after %d minute"),timelimit);
+ if (timelimit > 1)
+ printf("s");
+ printf(".\n");
+ }
}
diff --git a/src/doomstat.h b/src/doomstat.h
index fe850b19..6a220c1c 100644
--- a/src/doomstat.h
+++ b/src/doomstat.h
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: doomstat.h 429 2006-03-23 17:43:15Z fraggle $
+// $Id: doomstat.h 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -86,6 +86,9 @@ extern skill_t gameskill;
extern int gameepisode;
extern int gamemap;
+// If non-zero, exit the level after this number of minutes
+extern int timelimit;
+
// vertical movement from mouse/joystick disabled
extern int novert;
diff --git a/src/g_game.c b/src/g_game.c
index 39d68918..6fe36116 100644
--- a/src/g_game.c
+++ b/src/g_game.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: g_game.c 472 2006-04-28 17:31:21Z fraggle $
+// $Id: g_game.c 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -134,7 +134,7 @@
static const char
-rcsid[] = "$Id: g_game.c 472 2006-04-28 17:31:21Z fraggle $";
+rcsid[] = "$Id: g_game.c 475 2006-05-05 19:49:34Z fraggle $";
#include <string.h>
#include <stdlib.h>
@@ -218,7 +218,11 @@ skill_t gameskill;
boolean respawnmonsters;
int gameepisode;
int gamemap;
-
+
+// If non-zero, exit the level after this number of minutes.
+
+int timelimit;
+
boolean paused;
boolean sendpause; // send a pause event next tic
boolean sendsave; // send a save event next tic
diff --git a/src/net_client.c b/src/net_client.c
index 7aa26f86..4116e8fc 100644
--- a/src/net_client.c
+++ b/src/net_client.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: net_client.c 470 2006-04-14 15:25:42Z fraggle $
+// $Id: net_client.c 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 2005 Simon Howard
//
@@ -470,6 +470,7 @@ void NET_CL_StartGame(void)
settings.skill = startskill;
settings.gameversion = gameversion;
settings.nomonsters = nomonsters;
+ settings.timelimit = timelimit;
if (M_CheckParm("-oldsync") > 0)
settings.new_sync = 0;
@@ -674,6 +675,7 @@ static void NET_CL_ParseGameStart(net_packet_t *packet)
lowres_turn = settings.lowres_turn;
nomonsters = settings.nomonsters;
net_cl_new_sync = settings.new_sync != 0;
+ timelimit = settings.timelimit;
if (net_cl_new_sync == false)
{
diff --git a/src/net_defs.h b/src/net_defs.h
index db056d77..05bfb93c 100644
--- a/src/net_defs.h
+++ b/src/net_defs.h
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: net_defs.h 470 2006-04-14 15:25:42Z fraggle $
+// $Id: net_defs.h 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 2005 Simon Howard
//
@@ -179,6 +179,7 @@ typedef struct
int gameversion;
int lowres_turn;
int new_sync;
+ int timelimit;
} net_gamesettings_t;
#define NET_TICDIFF_FORWARD (1 << 0)
diff --git a/src/net_structrw.c b/src/net_structrw.c
index d3e5a2bd..0e527ebc 100644
--- a/src/net_structrw.c
+++ b/src/net_structrw.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: net_structrw.c 470 2006-04-14 15:25:42Z fraggle $
+// $Id: net_structrw.c 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 2005 Simon Howard
//
@@ -80,6 +80,7 @@ void NET_WriteSettings(net_packet_t *packet, net_gamesettings_t *settings)
NET_WriteInt8(packet, settings->gameversion);
NET_WriteInt8(packet, settings->lowres_turn);
NET_WriteInt8(packet, settings->new_sync);
+ NET_WriteInt32(packet, settings->timelimit);
}
boolean NET_ReadSettings(net_packet_t *packet, net_gamesettings_t *settings)
@@ -93,7 +94,8 @@ boolean NET_ReadSettings(net_packet_t *packet, net_gamesettings_t *settings)
&& NET_ReadInt8(packet, (unsigned int *) &settings->skill)
&& NET_ReadInt8(packet, (unsigned int *) &settings->gameversion)
&& NET_ReadInt8(packet, (unsigned int *) &settings->lowres_turn)
- && NET_ReadInt8(packet, (unsigned int *) &settings->new_sync);
+ && NET_ReadInt8(packet, (unsigned int *) &settings->new_sync)
+ && NET_ReadInt32(packet, (unsigned int *) &settings->timelimit);
}
void NET_WriteTiccmdDiff(net_packet_t *packet, net_ticdiff_t *diff,
diff --git a/src/p_spec.c b/src/p_spec.c
index 586d2ec2..6e5df166 100644
--- a/src/p_spec.c
+++ b/src/p_spec.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: p_spec.c 344 2006-01-25 17:38:40Z fraggle $
+// $Id: p_spec.c 475 2006-05-05 19:49:34Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -45,7 +45,7 @@
//-----------------------------------------------------------------------------
static const char
-rcsid[] = "$Id: p_spec.c 344 2006-01-25 17:38:40Z fraggle $";
+rcsid[] = "$Id: p_spec.c 475 2006-05-05 19:49:34Z fraggle $";
#include <stdlib.h>
@@ -1271,23 +1271,16 @@ void P_SpawnSpecials (void)
episode = 2;
- // See if -TIMER needs to be used.
- levelTimer = false;
-
- i = M_CheckParm("-avg");
- if (i && deathmatch)
+ // See if -TIMER was specified.
+
+ if (timelimit > 0)
{
- levelTimer = true;
- levelTimeCount = 20 * 60 * 35;
+ levelTimer = true;
+ levelTimeCount = timelimit * 60 * 35;
}
-
- i = M_CheckParm("-timer");
- if (i && deathmatch)
+ else
{
- int time;
- time = atoi(myargv[i+1]) * 60 * 35;
- levelTimer = true;
- levelTimeCount = time;
+ levelTimer = false;
}
// Init special SECTORs.