mirror of
https://github.com/Pecusx/libretro-atari800.git
synced 2026-05-20 22:33:22 +02:00
122 lines
3.1 KiB
C
122 lines
3.1 KiB
C
#include <ctype.h>
|
|
|
|
//Args for experimental_cmdline
|
|
static char ARGUV[64][1024];
|
|
static unsigned char ARGUC=0;
|
|
|
|
// Args for Core
|
|
static char XARGV[64][1024];
|
|
static const char* xargv_cmd[64];
|
|
int PARAMCOUNT=0;
|
|
|
|
extern int skel_main(int argc, char *argv[]);
|
|
void parse_cmdline( const char *argv );
|
|
|
|
void Add_Option(const char* option)
|
|
{
|
|
static int first=0;
|
|
|
|
if(first==0)
|
|
{
|
|
PARAMCOUNT=0;
|
|
first++;
|
|
}
|
|
|
|
sprintf(XARGV[PARAMCOUNT++],"%s\0",option);
|
|
}
|
|
|
|
int pre_main(const char *argv)
|
|
{
|
|
int i;
|
|
bool Only1Arg;
|
|
|
|
parse_cmdline(argv);
|
|
|
|
Only1Arg = (strcmp(ARGUV[0],"prg") == 0) ? 0 : 1;
|
|
|
|
for (i = 0; i<64; i++)
|
|
xargv_cmd[i] = NULL;
|
|
|
|
|
|
if(Only1Arg)
|
|
{
|
|
Add_Option("prg");
|
|
|
|
Add_Option(RPATH/*ARGUV[0]*/);
|
|
}
|
|
else
|
|
{ // Pass all cmdline args
|
|
for(i = 0; i < ARGUC; i++)
|
|
Add_Option(ARGUV[i]);
|
|
}
|
|
|
|
for (i = 0; i < PARAMCOUNT; i++)
|
|
{
|
|
xargv_cmd[i] = (char*)(XARGV[i]);
|
|
LOGI("%2d %s\n",i,XARGV[i]);
|
|
}
|
|
|
|
skel_main(PARAMCOUNT,( char **)xargv_cmd);
|
|
|
|
xargv_cmd[PARAMCOUNT - 2] = NULL;
|
|
}
|
|
|
|
void parse_cmdline(const char *argv)
|
|
{
|
|
char *p,*p2,*start_of_word;
|
|
int c,c2;
|
|
static char buffer[512*4];
|
|
enum states { DULL, IN_WORD, IN_STRING } state = DULL;
|
|
|
|
strcpy(buffer,argv);
|
|
strcat(buffer," \0");
|
|
|
|
for (p = buffer; *p != '\0'; p++)
|
|
{
|
|
c = (unsigned char) *p; /* convert to unsigned char for is* functions */
|
|
switch (state)
|
|
{
|
|
case DULL: /* not in a word, not in a double quoted string */
|
|
if (isspace(c)) /* still not in a word, so ignore this char */
|
|
continue;
|
|
/* not a space -- if it's a double quote we go to IN_STRING, else to IN_WORD */
|
|
if (c == '"')
|
|
{
|
|
state = IN_STRING;
|
|
start_of_word = p + 1; /* word starts at *next* char, not this one */
|
|
continue;
|
|
}
|
|
state = IN_WORD;
|
|
start_of_word = p; /* word starts here */
|
|
continue;
|
|
case IN_STRING:
|
|
/* we're in a double quoted string, so keep going until we hit a close " */
|
|
if (c == '"')
|
|
{
|
|
/* word goes from start_of_word to p-1 */
|
|
//... do something with the word ...
|
|
for (c2 = 0,p2 = start_of_word; p2 < p; p2++, c2++)
|
|
ARGUV[ARGUC][c2] = (unsigned char) *p2;
|
|
ARGUC++;
|
|
|
|
state = DULL; /* back to "not in word, not in string" state */
|
|
}
|
|
continue; /* either still IN_STRING or we handled the end above */
|
|
case IN_WORD:
|
|
/* we're in a word, so keep going until we get to a space */
|
|
if (isspace(c))
|
|
{
|
|
/* word goes from start_of_word to p-1 */
|
|
//... do something with the word ...
|
|
for (c2 = 0,p2 = start_of_word; p2 <p; p2++,c2++)
|
|
ARGUV[ARGUC][c2] = (unsigned char) *p2;
|
|
ARGUC++;
|
|
|
|
state = DULL; /* back to "not in word, not in string" state */
|
|
}
|
|
continue; /* either still IN_WORD or we handled the end above */
|
|
}
|
|
}
|
|
}
|
|
|