mirror of
https://github.com/cc65/cc65.git
synced 2025-01-02 09:34:22 +00:00
Make ld65 -L command line option position dependent again.
This commit is contained in:
parent
2a9cdf9152
commit
18c2289784
@ -522,18 +522,19 @@ static void OptVersion (const char* Opt attribute ((unused)),
|
|||||||
|
|
||||||
static void ParseCommandLine(void)
|
static void ParseCommandLine(void)
|
||||||
{
|
{
|
||||||
/* struct InputFile.Flag definitions */
|
/* struct InputFile.Type definitions */
|
||||||
#define INPUT_FILES_FILE 0 /* Entry is a file */
|
#define INPUT_FILES_FILE 0 /* Entry is a file */
|
||||||
#define INPUT_FILES_SGROUP 1 /* Entry is 'StartGroup' */
|
#define INPUT_FILES_SGROUP 1 /* Entry is 'StartGroup' */
|
||||||
#define INPUT_FILES_EGROUP 2 /* Entry is 'EndGroup' */
|
#define INPUT_FILES_EGROUP 2 /* Entry is 'EndGroup' */
|
||||||
|
#define INPUT_FILES_LIBPATH 3 /* Entry is a library search path */
|
||||||
|
|
||||||
#define MAX_INPUTFILES 256
|
#define MAX_INPUTFILES 256
|
||||||
|
|
||||||
struct InputFile {
|
struct InputFile {
|
||||||
const char *FileName;
|
const char *FileName;
|
||||||
unsigned Flag;
|
unsigned Type;
|
||||||
} *InputFiles;
|
} *InputFiles;
|
||||||
unsigned InputFilesCount = 0;
|
unsigned InputFilesCount = 0;
|
||||||
|
|
||||||
/* Program long options */
|
/* Program long options */
|
||||||
static const LongOpt OptTab[] = {
|
static const LongOpt OptTab[] = {
|
||||||
@ -558,7 +559,7 @@ static void ParseCommandLine(void)
|
|||||||
|
|
||||||
unsigned I;
|
unsigned I;
|
||||||
unsigned OutNameGiven = 0, CfgFileGiven = 0, TargetGiven = 0, StartAddressGiven = 0,
|
unsigned OutNameGiven = 0, CfgFileGiven = 0, TargetGiven = 0, StartAddressGiven = 0,
|
||||||
MapFileGiven = 0;
|
MapFileGiven = 0, LabelFileGiven = 0;
|
||||||
const char *CfgFile = NULL, *Target = NULL;
|
const char *CfgFile = NULL, *Target = NULL;
|
||||||
|
|
||||||
/* Allocate memory for input file array */
|
/* Allocate memory for input file array */
|
||||||
@ -582,14 +583,14 @@ static void ParseCommandLine(void)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case '(':
|
case '(':
|
||||||
InputFiles[InputFilesCount].Flag = INPUT_FILES_SGROUP;
|
InputFiles[InputFilesCount].Type = INPUT_FILES_SGROUP;
|
||||||
InputFiles[InputFilesCount].FileName = Arg; /* Unused */
|
InputFiles[InputFilesCount].FileName = Arg; /* Unused */
|
||||||
if (++InputFilesCount >= MAX_INPUTFILES)
|
if (++InputFilesCount >= MAX_INPUTFILES)
|
||||||
Error ("Too many input files");
|
Error ("Too many input files");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ')':
|
case ')':
|
||||||
InputFiles[InputFilesCount].Flag = INPUT_FILES_EGROUP;
|
InputFiles[InputFilesCount].Type = INPUT_FILES_EGROUP;
|
||||||
InputFiles[InputFilesCount].FileName = Arg; /* Unused */
|
InputFiles[InputFilesCount].FileName = Arg; /* Unused */
|
||||||
if (++InputFilesCount >= MAX_INPUTFILES)
|
if (++InputFilesCount >= MAX_INPUTFILES)
|
||||||
Error ("Too many input files");
|
Error ("Too many input files");
|
||||||
@ -650,9 +651,20 @@ static void ParseCommandLine(void)
|
|||||||
|
|
||||||
case 'L':
|
case 'L':
|
||||||
switch (Arg [2]) {
|
switch (Arg [2]) {
|
||||||
/* ## The first one is obsolete and will go */
|
case 'n':
|
||||||
case 'n': LabelFileName = GetArg (&I, 3); break;
|
/* ## This one is obsolete and will go */
|
||||||
default: OptLibPath (Arg, GetArg (&I, 2)); break;
|
if (LabelFileGiven) {
|
||||||
|
Error ("Cannot use -Ln twice");
|
||||||
|
}
|
||||||
|
LabelFileGiven = 1;
|
||||||
|
LabelFileName = GetArg (&I, 3);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
InputFiles[InputFilesCount].Type = INPUT_FILES_LIBPATH;
|
||||||
|
InputFiles[InputFilesCount].FileName = GetArg (&I, 2);
|
||||||
|
if (++InputFilesCount >= MAX_INPUTFILES)
|
||||||
|
Error ("Too many input files");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -676,7 +688,7 @@ static void ParseCommandLine(void)
|
|||||||
} else {
|
} else {
|
||||||
|
|
||||||
/* A filename */
|
/* A filename */
|
||||||
InputFiles[InputFilesCount].Flag = INPUT_FILES_FILE;
|
InputFiles[InputFilesCount].Type = INPUT_FILES_FILE;
|
||||||
InputFiles[InputFilesCount].FileName = Arg;
|
InputFiles[InputFilesCount].FileName = Arg;
|
||||||
if (++InputFilesCount >= MAX_INPUTFILES)
|
if (++InputFilesCount >= MAX_INPUTFILES)
|
||||||
Error ("Too many input files");
|
Error ("Too many input files");
|
||||||
@ -699,7 +711,7 @@ static void ParseCommandLine(void)
|
|||||||
|
|
||||||
/* Process input files */
|
/* Process input files */
|
||||||
for (I = 0; I < InputFilesCount; ++I) {
|
for (I = 0; I < InputFilesCount; ++I) {
|
||||||
switch (InputFiles[I].Flag) {
|
switch (InputFiles[I].Type) {
|
||||||
case INPUT_FILES_FILE:
|
case INPUT_FILES_FILE:
|
||||||
LinkFile (InputFiles[I].FileName, FILETYPE_UNKNOWN);
|
LinkFile (InputFiles[I].FileName, FILETYPE_UNKNOWN);
|
||||||
break;
|
break;
|
||||||
@ -709,6 +721,9 @@ static void ParseCommandLine(void)
|
|||||||
case INPUT_FILES_EGROUP:
|
case INPUT_FILES_EGROUP:
|
||||||
OptEndGroup (NULL, 0);
|
OptEndGroup (NULL, 0);
|
||||||
break;
|
break;
|
||||||
|
case INPUT_FILES_LIBPATH:
|
||||||
|
OptLibPath (NULL, InputFiles[I].FileName);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
abort ();
|
abort ();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user