* Split off q_platform.h from q_shared.h
* Removed lcc PATH hack and replaced with something slightly less hacky * Removed all platform specific hostfiles from lcc and replaced with bytecode.c (from ankon) * Turned lcc option "-S" on permanently * Improved q3cpp so that it recursively adds include dirs to its list
This commit is contained in:
parent
48683c91a8
commit
87cd6f8a93
15 changed files with 452 additions and 715 deletions
66
code/tools/lcc/etc/bytecode.c
Normal file
66
code/tools/lcc/etc/bytecode.c
Normal file
|
@ -0,0 +1,66 @@
|
|||
/* quake3 bytecode target */
|
||||
|
||||
#include <string.h>
|
||||
#include <stdio.h>
|
||||
#include "../../../qcommon/q_platform.h"
|
||||
|
||||
#ifdef _WIN32
|
||||
#define BINEXT ".exe"
|
||||
#else
|
||||
#define BINEXT ""
|
||||
#endif
|
||||
|
||||
char *suffixes[] = { ".c", ".i", ".asm", ".o", ".out", 0 };
|
||||
char inputs[256] = "";
|
||||
char *cpp[] = { "q3cpp" BINEXT,
|
||||
"-D__STDC__=1", "-D__STRICT_ANSI__", "-D__signed__=signed", "-DQ3_VM",
|
||||
"$1", "$2", "$3", 0 };
|
||||
char *include[] = { 0 };
|
||||
char *com[] = { "q3rcc" BINEXT, "-target=bytecode", "$1", "$2", "$3", 0 };
|
||||
char *ld[] = { 0 };
|
||||
char *as[] = { 0 };
|
||||
|
||||
extern char *concat(char *, char *);
|
||||
|
||||
/*
|
||||
===============
|
||||
UpdatePaths
|
||||
|
||||
Updates the paths to q3cpp and q3rcc based on
|
||||
the directory that contains q3lcc
|
||||
===============
|
||||
*/
|
||||
void UpdatePaths( const char *lccBinary )
|
||||
{
|
||||
char basepath[ 1024 ];
|
||||
char *p;
|
||||
|
||||
strncpy( basepath, lccBinary, 1024 );
|
||||
p = strrchr( basepath, PATH_SEP );
|
||||
|
||||
if( p )
|
||||
{
|
||||
*( p + 1 ) = '\0';
|
||||
|
||||
cpp[ 0 ] = concat( basepath, "q3cpp" BINEXT );
|
||||
com[ 0 ] = concat( basepath, "q3rcc" BINEXT );
|
||||
}
|
||||
}
|
||||
|
||||
int option(char *arg) {
|
||||
if (strncmp(arg, "-lccdir=", 8) == 0) {
|
||||
cpp[0] = concat(&arg[8], "/q3cpp" BINEXT);
|
||||
include[0] = concat("-I", concat(&arg[8], "/include"));
|
||||
com[0] = concat(&arg[8], "/q3rcc" BINEXT);
|
||||
} else if (strcmp(arg, "-p") == 0 || strcmp(arg, "-pg") == 0) {
|
||||
fprintf( stderr, "no profiling supported, %s ignored.\n", arg);
|
||||
} else if (strcmp(arg, "-b") == 0)
|
||||
;
|
||||
else if (strcmp(arg, "-g") == 0)
|
||||
fprintf( stderr, "no debugging supported, %s ignored.\n", arg);
|
||||
else if (strncmp(arg, "-ld=", 4) == 0 || strcmp(arg, "-static") == 0) {
|
||||
fprintf( stderr, "no linking supported, %s ignored.\n", arg);
|
||||
} else
|
||||
return 0;
|
||||
return 1;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue