mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-18 15:01:41 +00:00
win32 portability fixes
This commit is contained in:
parent
267e51eaaf
commit
40d47e91cb
7 changed files with 66 additions and 28 deletions
|
@ -39,7 +39,7 @@ AC_CHECK_LIB(z, gztell,,
|
||||||
|
|
||||||
dnl Checks for header files.
|
dnl Checks for header files.
|
||||||
AC_HEADER_STDC
|
AC_HEADER_STDC
|
||||||
AC_CHECK_HEADERS(sys/types.h sys/wait.h unistd.h)
|
AC_CHECK_HEADERS(process.h string.h strings.h sys/types.h sys/wait.h unistd.h)
|
||||||
|
|
||||||
dnl Checks for typedefs, structures, and compiler characteristics.
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
||||||
AC_ARG_ENABLE(profile,
|
AC_ARG_ENABLE(profile,
|
||||||
|
@ -60,6 +60,8 @@ AC_DEFINE_UNQUOTED(PATH_SEPARATOR, '/')
|
||||||
|
|
||||||
dnl Checks for library functions.
|
dnl Checks for library functions.
|
||||||
|
|
||||||
|
AC_CHECK_FUNCS(snprintf _snprintf vsnprintf _vsnprintf)
|
||||||
|
|
||||||
AC_MSG_CHECKING(for timeGetTime in -lwinmm)
|
AC_MSG_CHECKING(for timeGetTime in -lwinmm)
|
||||||
save_LIBS="$LIBS"
|
save_LIBS="$LIBS"
|
||||||
LIBS="$LIBS -lwinmm"
|
LIBS="$LIBS -lwinmm"
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
See file, 'COPYING', for details.
|
See file, 'COPYING', for details.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "cmdlib.h"
|
#include "cmdlib.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@ -25,6 +28,16 @@
|
||||||
#include "QF/pr_comp.h"
|
#include "QF/pr_comp.h"
|
||||||
#include "QF/pr_debug.h"
|
#include "QF/pr_debug.h"
|
||||||
|
|
||||||
|
/* These may be underscored... */
|
||||||
|
#if defined(HAVE__SNPRINTF)
|
||||||
|
# undef snprintf
|
||||||
|
# define snprintf _snprintf
|
||||||
|
#endif
|
||||||
|
#if defined(HAVE__VSNPRINTF)
|
||||||
|
# undef vsnprintf
|
||||||
|
# define vsnprintf _vsnprintf
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
TODO:
|
TODO:
|
||||||
o "stopped at 10 errors"
|
o "stopped at 10 errors"
|
||||||
|
|
|
@ -301,7 +301,7 @@ new_label_name (void)
|
||||||
char *lname = malloc (len);
|
char *lname = malloc (len);
|
||||||
if (!lname)
|
if (!lname)
|
||||||
Sys_Error ("new_label_expr: Memory Allocation Failure\n");
|
Sys_Error ("new_label_expr: Memory Allocation Failure\n");
|
||||||
sprintf (lname, "$%s_%d", fname, lnum);
|
snprintf (lname, len, "$%s_%d", fname, lnum);
|
||||||
return lname;
|
return lname;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -200,7 +200,8 @@ static char *posixly_correct;
|
||||||
|
|
||||||
# if HAVE_STRING_H
|
# if HAVE_STRING_H
|
||||||
# include <string.h>
|
# include <string.h>
|
||||||
# else
|
# endif
|
||||||
|
# if HAVE_STRINGS_H
|
||||||
# include <strings.h>
|
# include <strings.h>
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
|
|
@ -131,17 +131,17 @@ PR_GetDef (type_t *type, const char *name, def_t *scope, int *allocate)
|
||||||
if (type->type == ev_vector) {
|
if (type->type == ev_vector) {
|
||||||
def_t *d;
|
def_t *d;
|
||||||
|
|
||||||
sprintf (element, "%s_x", name);
|
snprintf (element, sizeof (element), "%s_x", name);
|
||||||
d = PR_GetDef (&type_float, element, scope, allocate);
|
d = PR_GetDef (&type_float, element, scope, allocate);
|
||||||
d->used = 1;
|
d->used = 1;
|
||||||
d->parent = def;
|
d->parent = def;
|
||||||
|
|
||||||
sprintf (element, "%s_y", name);
|
snprintf (element, sizeof (element), "%s_y", name);
|
||||||
d = PR_GetDef (&type_float, element, scope, allocate);
|
d = PR_GetDef (&type_float, element, scope, allocate);
|
||||||
d->used = 1;
|
d->used = 1;
|
||||||
d->parent = def;
|
d->parent = def;
|
||||||
|
|
||||||
sprintf (element, "%s_z", name);
|
snprintf (element, sizeof (element), "%s_z", name);
|
||||||
d = PR_GetDef (&type_float, element, scope, allocate);
|
d = PR_GetDef (&type_float, element, scope, allocate);
|
||||||
d->used = 1;
|
d->used = 1;
|
||||||
d->parent = def;
|
d->parent = def;
|
||||||
|
@ -155,17 +155,17 @@ PR_GetDef (type_t *type, const char *name, def_t *scope, int *allocate)
|
||||||
if (type->aux_type->type == ev_vector) {
|
if (type->aux_type->type == ev_vector) {
|
||||||
def_t *d;
|
def_t *d;
|
||||||
|
|
||||||
sprintf (element, "%s_x", name);
|
snprintf (element, sizeof (element), "%s_x", name);
|
||||||
d = PR_GetDef (&type_floatfield, element, scope, allocate);
|
d = PR_GetDef (&type_floatfield, element, scope, allocate);
|
||||||
d->used = 1; // always `used'
|
d->used = 1; // always `used'
|
||||||
d->parent = def;
|
d->parent = def;
|
||||||
|
|
||||||
sprintf (element, "%s_y", name);
|
snprintf (element, sizeof (element), "%s_y", name);
|
||||||
d = PR_GetDef (&type_floatfield, element, scope, allocate);
|
d = PR_GetDef (&type_floatfield, element, scope, allocate);
|
||||||
d->used = 1; // always `used'
|
d->used = 1; // always `used'
|
||||||
d->parent = def;
|
d->parent = def;
|
||||||
|
|
||||||
sprintf (element, "%s_z", name);
|
snprintf (element, sizeof (element), "%s_z", name);
|
||||||
d = PR_GetDef (&type_floatfield, element, scope, allocate);
|
d = PR_GetDef (&type_floatfield, element, scope, allocate);
|
||||||
d->used = 1; // always `used'
|
d->used = 1; // always `used'
|
||||||
d->parent = def;
|
d->parent = def;
|
||||||
|
|
|
@ -48,7 +48,7 @@ float_imm_get_key (void *_def, void *unused)
|
||||||
{
|
{
|
||||||
def_t *def = (def_t*)_def;
|
def_t *def = (def_t*)_def;
|
||||||
static char rep[20];
|
static char rep[20];
|
||||||
sprintf (rep, "\001float:%08X\001", G_INT(def->ofs));
|
snprintf (rep, sizeof (rep), "\001float:%08X\001", G_INT(def->ofs));
|
||||||
return rep;
|
return rep;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,7 +57,7 @@ vector_imm_get_key (void *_def, void *unused)
|
||||||
{
|
{
|
||||||
def_t *def = (def_t*)_def;
|
def_t *def = (def_t*)_def;
|
||||||
static char rep[60];
|
static char rep[60];
|
||||||
sprintf (rep, "\001vector:%08X\001%08X\001%08X\001",
|
snprintf (rep, sizeof (rep), "\001vector:%08X\001%08X\001%08X\001",
|
||||||
G_INT(def->ofs), G_INT(def->ofs+1), G_INT(def->ofs+2));
|
G_INT(def->ofs), G_INT(def->ofs+1), G_INT(def->ofs+2));
|
||||||
return rep;
|
return rep;
|
||||||
}
|
}
|
||||||
|
@ -67,7 +67,8 @@ quaternion_imm_get_key (void *_def, void *unused)
|
||||||
{
|
{
|
||||||
def_t *def = (def_t*)_def;
|
def_t *def = (def_t*)_def;
|
||||||
static char rep[60];
|
static char rep[60];
|
||||||
sprintf (rep, "\001quaternion:%08X\001%08X\001%08X\001%08X\001",
|
snprintf (rep, sizeof (rep),
|
||||||
|
"\001quaternion:%08X\001%08X\001%08X\001%08X\001",
|
||||||
G_INT(def->ofs), G_INT(def->ofs+1),
|
G_INT(def->ofs), G_INT(def->ofs+1),
|
||||||
G_INT(def->ofs+2), G_INT(def->ofs+3));
|
G_INT(def->ofs+2), G_INT(def->ofs+3));
|
||||||
return rep;
|
return rep;
|
||||||
|
@ -79,7 +80,7 @@ int_imm_get_key (void *_def, void *_str)
|
||||||
def_t *def = (def_t*)_def;
|
def_t *def = (def_t*)_def;
|
||||||
static char rep[60];
|
static char rep[60];
|
||||||
char *str = (char*)_str;
|
char *str = (char*)_str;
|
||||||
sprintf (rep, "\001%s:%08X\001", str, G_INT(def->ofs));
|
snprintf (rep, sizeof (rep), "\001%s:%08X\001", str, G_INT(def->ofs));
|
||||||
return rep;
|
return rep;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,29 +113,29 @@ PR_ReuseConstant (expr_t *expr, def_t *def)
|
||||||
}
|
}
|
||||||
switch (e.type) {
|
switch (e.type) {
|
||||||
case ex_entity:
|
case ex_entity:
|
||||||
sprintf (rep, "\001entity:%08X\001", e.e.integer_val);
|
snprintf (rep, sizeof (rep), "\001entity:%08X\001", e.e.integer_val);
|
||||||
tab = entity_imm_defs;
|
tab = entity_imm_defs;
|
||||||
type = &type_entity;
|
type = &type_entity;
|
||||||
break;
|
break;
|
||||||
case ex_field:
|
case ex_field:
|
||||||
sprintf (rep, "\001field:%08X\001", e.e.integer_val);
|
snprintf (rep, sizeof (rep), "\001field:%08X\001", e.e.integer_val);
|
||||||
tab = field_imm_defs;
|
tab = field_imm_defs;
|
||||||
type = &type_field;
|
type = &type_field;
|
||||||
break;
|
break;
|
||||||
case ex_func:
|
case ex_func:
|
||||||
sprintf (rep, "\001func:%08X\001", e.e.integer_val);
|
snprintf (rep, sizeof (rep), "\001func:%08X\001", e.e.integer_val);
|
||||||
tab = func_imm_defs;
|
tab = func_imm_defs;
|
||||||
type = &type_function;
|
type = &type_function;
|
||||||
break;
|
break;
|
||||||
case ex_pointer:
|
case ex_pointer:
|
||||||
sprintf (rep, "\001pointer:%08X\001", e.e.integer_val);
|
snprintf (rep, sizeof (rep), "\001pointer:%08X\001", e.e.integer_val);
|
||||||
tab = pointer_imm_defs;
|
tab = pointer_imm_defs;
|
||||||
type = &type_pointer;
|
type = &type_pointer;
|
||||||
break;
|
break;
|
||||||
case ex_integer:
|
case ex_integer:
|
||||||
case ex_uinteger:
|
case ex_uinteger:
|
||||||
if (!def || def->type != &type_float) {
|
if (!def || def->type != &type_float) {
|
||||||
sprintf (rep, "\001integer:%08X\001", e.e.integer_val);
|
snprintf (rep, sizeof (rep), "\001integer:%08X\001", e.e.integer_val);
|
||||||
tab = integer_imm_defs;
|
tab = integer_imm_defs;
|
||||||
if (e.type == ex_uinteger)
|
if (e.type == ex_uinteger)
|
||||||
type = &type_uinteger;
|
type = &type_uinteger;
|
||||||
|
@ -147,7 +148,7 @@ PR_ReuseConstant (expr_t *expr, def_t *def)
|
||||||
else
|
else
|
||||||
e.e.float_val = e.e.integer_val;
|
e.e.float_val = e.e.integer_val;
|
||||||
case ex_float:
|
case ex_float:
|
||||||
sprintf (rep, "\001float:%08X\001", e.e.integer_val);
|
snprintf (rep, sizeof (rep), "\001float:%08X\001", e.e.integer_val);
|
||||||
tab = float_imm_defs;
|
tab = float_imm_defs;
|
||||||
type = &type_float;
|
type = &type_float;
|
||||||
break;
|
break;
|
||||||
|
@ -157,7 +158,7 @@ PR_ReuseConstant (expr_t *expr, def_t *def)
|
||||||
type = &type_string;
|
type = &type_string;
|
||||||
break;
|
break;
|
||||||
case ex_vector:
|
case ex_vector:
|
||||||
sprintf (rep, "\001vector:%08X\001%08X\001%08X\001",
|
snprintf (rep, sizeof (rep), "\001vector:%08X\001%08X\001%08X\001",
|
||||||
*(int*)&e.e.vector_val[0],
|
*(int*)&e.e.vector_val[0],
|
||||||
*(int*)&e.e.vector_val[1],
|
*(int*)&e.e.vector_val[1],
|
||||||
*(int*)&e.e.vector_val[2]);
|
*(int*)&e.e.vector_val[2]);
|
||||||
|
@ -165,7 +166,7 @@ PR_ReuseConstant (expr_t *expr, def_t *def)
|
||||||
type = &type_vector;
|
type = &type_vector;
|
||||||
break;
|
break;
|
||||||
case ex_quaternion:
|
case ex_quaternion:
|
||||||
sprintf (rep, "\001quaternion:%08X\001%08X\001%08X\001%08X\001",
|
snprintf (rep, sizeof (rep), "\001quaternion:%08X\001%08X\001%08X\001%08X\001",
|
||||||
*(int*)&e.e.quaternion_val[0],
|
*(int*)&e.e.quaternion_val[0],
|
||||||
*(int*)&e.e.quaternion_val[1],
|
*(int*)&e.e.quaternion_val[1],
|
||||||
*(int*)&e.e.quaternion_val[2],
|
*(int*)&e.e.quaternion_val[2],
|
||||||
|
|
|
@ -41,6 +41,9 @@
|
||||||
#ifdef HAVE_UNISTD_H
|
#ifdef HAVE_UNISTD_H
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef HAVE_PROCESS_H
|
||||||
|
# include <process.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
@ -136,7 +139,7 @@ WriteFiles (void)
|
||||||
int i;
|
int i;
|
||||||
char filename[1024];
|
char filename[1024];
|
||||||
|
|
||||||
sprintf (filename, "%s%cfiles.dat", sourcedir, PATH_SEPARATOR);
|
snprintf (filename, sizeof (filename), "%s%cfiles.dat", sourcedir, PATH_SEPARATOR);
|
||||||
f = fopen (filename, "w");
|
f = fopen (filename, "w");
|
||||||
if (!f)
|
if (!f)
|
||||||
Error ("Couldn't open %s", filename);
|
Error ("Couldn't open %s", filename);
|
||||||
|
@ -899,7 +902,7 @@ main (int argc, char **argv)
|
||||||
|
|
||||||
InitData ();
|
InitData ();
|
||||||
|
|
||||||
sprintf (filename, "%s/progs.src", sourcedir);
|
snprintf (filename, sizeof (filename), "%s/progs.src", sourcedir);
|
||||||
LoadFile (filename, (void *) &src);
|
LoadFile (filename, (void *) &src);
|
||||||
|
|
||||||
if (!(src = Parse (src)))
|
if (!(src = Parse (src)))
|
||||||
|
@ -932,11 +935,13 @@ main (int argc, char **argv)
|
||||||
// compile all the files
|
// compile all the files
|
||||||
while ((src = Parse (src))) {
|
while ((src = Parse (src))) {
|
||||||
#ifdef USE_CPP
|
#ifdef USE_CPP
|
||||||
|
# ifndef _WIN32
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
|
int tempfd;
|
||||||
|
# endif
|
||||||
char *temp1;
|
char *temp1;
|
||||||
char *temp2 = strrchr (argv[0], PATH_SEPARATOR);
|
char *temp2 = strrchr (argv[0], PATH_SEPARATOR);
|
||||||
char tempname[1024];
|
char tempname[1024];
|
||||||
int tempfd;
|
|
||||||
#endif
|
#endif
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
|
@ -947,7 +952,7 @@ main (int argc, char **argv)
|
||||||
//extern int yydebug;
|
//extern int yydebug;
|
||||||
//yydebug = 1;
|
//yydebug = 1;
|
||||||
|
|
||||||
sprintf (filename, "%s%c%s", sourcedir, PATH_SEPARATOR, com_token);
|
snprintf (filename, sizeof (filename), "%s%c%s", sourcedir, PATH_SEPARATOR, com_token);
|
||||||
if (options.verbosity >= 2)
|
if (options.verbosity >= 2)
|
||||||
printf ("compiling %s\n", filename);
|
printf ("compiling %s\n", filename);
|
||||||
|
|
||||||
|
@ -963,13 +968,29 @@ main (int argc, char **argv)
|
||||||
|
|
||||||
snprintf (tempname, sizeof (tempname), "%s%c%sXXXXXX", temp1,
|
snprintf (tempname, sizeof (tempname), "%s%c%sXXXXXX", temp1,
|
||||||
PATH_SEPARATOR, temp2 ? temp2 + 1 : argv[0]);
|
PATH_SEPARATOR, temp2 ? temp2 + 1 : argv[0]);
|
||||||
tempfd = mkstemp (tempname);
|
|
||||||
|
|
||||||
|
# ifdef _WIN32
|
||||||
|
|
||||||
|
mktemp (tempname);
|
||||||
|
yyin = fopen (tempname, "wt");
|
||||||
|
fclose (yyin);
|
||||||
|
|
||||||
|
{
|
||||||
|
int status = spawnvp (_P_WAIT, "cpp", cpp_argv);
|
||||||
|
|
||||||
|
if (status) {
|
||||||
|
fprintf (stderr, "cpp returned error code %d", status);
|
||||||
|
exit (1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
yyin = fopen (tempname, "rt");
|
||||||
|
# else
|
||||||
|
tempfd = mkstemp (tempname);
|
||||||
if ((pid = fork ()) == -1) {
|
if ((pid = fork ()) == -1) {
|
||||||
perror ("fork");
|
perror ("fork");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!pid) { // we're a child, check for abuse
|
if (!pid) { // we're a child, check for abuse
|
||||||
cpp_argv[cpp_argc++] = "-o";
|
cpp_argv[cpp_argc++] = "-o";
|
||||||
cpp_argv[cpp_argc++] = tempname;
|
cpp_argv[cpp_argc++] = tempname;
|
||||||
|
@ -1004,8 +1025,8 @@ main (int argc, char **argv)
|
||||||
exit (1);
|
exit (1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
yyin = fdopen (tempfd, "r+t");
|
yyin = fdopen (tempfd, "r+t");
|
||||||
|
# endif
|
||||||
} else {
|
} else {
|
||||||
yyin = fopen (filename, "rt");
|
yyin = fopen (filename, "rt");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue