1
0
Fork 0
forked from fte/fteqw
fteqw/engine/partcfgs/generatebuiltin.c
Spoike c4d3497054 some Q2 compat tweaks. moved all q2 temp-ents to particle scripts.
PF_VarString can now shortcircuit, directly returning the first argument (which also bypasses related length limitations). this required const correctness fixes.
r_showshaders cvar reports the wall texture being pointed at.
improve dp compat in a number of areas, should now mostly be able to run xonotic 0.8.2, but will need some more extra cvars/defaults/stuff.
fix q3bsp loader race condition.
fix dpm loader multi-surface issue.
remove limit on stringbuffer count.
don't poll xinput (because its disturbingly slow), instead wait for some window message before re-checking.
fixed splitscreen saved games.

git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@5140 fc73d0e0-1445-4013-8a0c-d673dee63da5
2017-08-14 16:38:44 +00:00

117 lines
2.8 KiB
C

//simple tool to read the particle configs and generate a header file for inclusion in the engine.
#include <stdio.h>
#include <string.h>
struct
{
char filename[64];
char *ifdef;
} effects[] =
{
{"spikeset.cfg"},
{"faithful.cfg"},
{"highfps.cfg"},
{"high.cfg"},
{"minimal.cfg"},
{"h2part.cfg", "#ifdef HEXEN2\n"},
{"q2part.cfg", "#ifdef Q2CLIENT\n"},
{"tsshaft.cfg"},
{""}
};
int main(void)
{
FILE *c, *h, *s;
char line[1024], *f;
int i, j;
c = fopen("../client/r_partset.c", "wt");
h = fopen("../client/r_partset.h", "wt");
if (!c || !h)
{
printf("unable to open a file\n");
return;
}
fprintf(h, "/*\nWARNING: THIS FILE IS GENERATED BY '"__FILE__"'.\nYOU SHOULD NOT EDIT THIS FILE BY HAND\n*/\n\n");
fprintf(c, "/*\nWARNING: THIS FILE IS GENERATED BY '"__FILE__"'.\nYOU SHOULD NOT EDIT THIS FILE BY HAND\n*/\n\n");
fprintf(c, "#include \"bothdefs.h\"\n");
fprintf(c, "#ifndef QUAKETC\n");
fprintf(h, "#ifndef QUAKETC\n");
fprintf(c, "#include \"r_partset.h\"\n\n\n");
for (i = 0; *effects[i].filename; i++)
{
s = fopen(effects[i].filename, "rt");
if (!s)
{
printf("unable to open %s\n", effects[i].filename);
return;
}
*strchr(effects[i].filename, '.') = 0;
if (effects[i].ifdef)
fprintf(h, "%s", effects[i].ifdef);
fprintf(h, "extern char *particle_set_%s;\n", effects[i].filename);
fprintf(h, "#define R_PARTSET_BUILTINS_%s {\"%s\", &particle_set_%s},\n", effects[i].filename, effects[i].filename, effects[i].filename);
if (effects[i].ifdef)
{
fputs("#else\n", h);
fprintf(h, "#define R_PARTSET_BUILTINS_%s\n", effects[i].filename);
fputs("#endif\n", h);
}
if (i)
fprintf(c, "\n\n\n//////////////////////////////////////////////////////\n\n\n");
if (effects[i].ifdef)
fprintf(c, "%s", effects[i].ifdef);
fprintf(c, "char *particle_set_%s =\n", effects[i].filename);
while(fgets(line, sizeof(line), s))
{
j = 0;
while (line[j] == ' ' || line[j] == '\t')
j++;
if ((line[j] == '/' && line[j+1] == '/') || line[j] == '\r' || line[j] == '\n')
{
while (line[j])
fputc(line[j++], c);
}
else
{
fputc('\"', c);
while (line[j] && line[j] != '\r' && line[j] != '\n')
{
if (line[j] == '\t')
fputc(' ', c);
else if (line[j] == '\"')
{
fputc('\\', c);
fputc(line[j], c);
}
else
fputc(line[j], c);
j++;
}
fputs("\\n\"\n", c);
}
}
fputs(";\n", c);
if (effects[i].ifdef)
fputs("#endif\n", c);
fclose(s);
}
fputs("#define R_PARTSET_BUILTINS ", h);
for (i = 0; *effects[i].filename; i++)
{
fprintf(h, "R_PARTSET_BUILTINS_%s ", effects[i].filename);
}
fputs("\n", h);
fprintf(c, "#endif\n");
fprintf(h, "#endif\n");
fclose(h);
fclose(c);
}