1
0
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:
Christian Groessler 2014-03-25 15:36:38 +01:00
parent 2a9cdf9152
commit 18c2289784

View File

@ -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 ();
} }