summaryrefslogtreecommitdiff
path: root/src/game
diff options
context:
space:
mode:
authorTim Angus <tim@ngus.net>2003-09-21 18:23:47 +0000
committerTim Angus <tim@ngus.net>2003-09-21 18:23:47 +0000
commit51f8195fe9846eaf3482da7ccce44064a7c2900a (patch)
tree62fa42690362537f3419753bf738765a12aaac80 /src/game
parent84e75ec07a5027e76726bc28073438d8c9a8d04a (diff)
* Fully generalised scriptable paricle system
* Changes to Makefile and depend file for above * Tweaks to entities.def * Apparently a bunch of other stuff I've forgotten about
Diffstat (limited to 'src/game')
-rw-r--r--src/game/bg_public.h4
-rw-r--r--src/game/g_main.c29
-rw-r--r--src/game/q_shared.h7
3 files changed, 35 insertions, 5 deletions
diff --git a/src/game/bg_public.h b/src/game/bg_public.h
index 494c3cf7..920df33b 100644
--- a/src/game/bg_public.h
+++ b/src/game/bg_public.h
@@ -76,9 +76,9 @@
#define CS_PLAYERS (CS_SHADERS+MAX_SHADERS)
#define CS_PRECACHES (CS_PLAYERS+MAX_CLIENTS)
#define CS_LOCATIONS (CS_PRECACHES+MAX_CLIENTS)
-/*#define CS_PARTICLES (CS_LOCATIONS+MAX_LOCATIONS) TA: never used?!*/
+#define CS_PARTICLE_FILES (CS_LOCATIONS+MAX_LOCATIONS)
-#define CS_MAX (CS_LOCATIONS+MAX_LOCATIONS)
+#define CS_MAX (CS_PARTICLE_FILES+MAX_PARTICLE_FILES)
#if (CS_MAX) > MAX_CONFIGSTRINGS
#error overflow: (CS_MAX) > MAX_CONFIGSTRINGS
diff --git a/src/game/g_main.c b/src/game/g_main.c
index 4283b8eb..f74f7e7d 100644
--- a/src/game/g_main.c
+++ b/src/game/g_main.c
@@ -402,6 +402,34 @@ void G_UpdateCvars( void )
/*
+===============
+G_GenerateParticleFileList
+
+Make a list of particle files for each client to parse since fsr
+the client does not have trap_FS_GetFileList
+===============
+*/
+static void G_GenerateParticleFileList( void )
+{
+ int i, numFiles, fileLen;
+ char fileList[ MAX_PARTICLE_FILES ];
+ char fileName[ MAX_QPATH ];
+ char *filePtr;
+
+ numFiles = trap_FS_GetFileList( "scripts", ".particle", fileList, 1024 );
+ filePtr = fileList;
+
+ for( i = 0; i < numFiles; i++, filePtr += fileLen + 1 )
+ {
+ fileLen = strlen( filePtr );
+ strcpy( fileName, "scripts/" );
+ strcat( fileName, filePtr );
+ trap_SetConfigstring( CS_PARTICLE_FILES + i, fileName );
+ }
+}
+
+
+/*
============
G_InitGame
@@ -482,6 +510,7 @@ void G_InitGame( int levelTime, int randomSeed, int restart )
//TA:
G_InitDamageLocations( );
+ G_GenerateParticleFileList( );
//reset stages
trap_Cvar_Set( "g_alienStage", va( "%d", S1 ) );
diff --git a/src/game/q_shared.h b/src/game/q_shared.h
index fefeed3b..34d2ffb7 100644
--- a/src/game/q_shared.h
+++ b/src/game/q_shared.h
@@ -1095,9 +1095,10 @@ typedef enum {
#define ENTITYNUM_MAX_NORMAL (MAX_GENTITIES-2)
-#define MAX_MODELS 256 // these are sent over the net as 8 bits
-#define MAX_SOUNDS 256 // so they cannot be blindly increased
-#define MAX_SHADERS 256 //TA: should be in bg_public.h
+#define MAX_MODELS 256 // these are sent over the net as 8 bits
+#define MAX_SOUNDS 256 // so they cannot be blindly increased
+#define MAX_SHADERS 128 //TA: should be in bg_public.h
+#define MAX_PARTICLE_FILES 128
#define MAX_CONFIGSTRINGS 1024