mirror of
https://github.com/cc65/cc65.git
synced 2025-01-10 19:29:45 +00:00
New option --add-source
git-svn-id: svn://svn.cc65.org/cc65/trunk@79 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
6d33db1291
commit
409d12534b
@ -56,11 +56,11 @@ unsigned char RegVarsToCallStack= 0; /* Save reg variables on call stack
|
|||||||
unsigned char LocalsAreStatic = 0; /* Make local variables static */
|
unsigned char LocalsAreStatic = 0; /* Make local variables static */
|
||||||
unsigned char SignedChars = 0; /* Make characters signed by default */
|
unsigned char SignedChars = 0; /* Make characters signed by default */
|
||||||
unsigned char Verbose = 0; /* Verbose flag */
|
unsigned char Verbose = 0; /* Verbose flag */
|
||||||
unsigned char IncSource = 0; /* Include source as comments */
|
unsigned char AddSource = 0; /* Add source lines as comments */
|
||||||
unsigned char DebugInfo = 0; /* Add debug info to the obj */
|
unsigned char DebugInfo = 0; /* Add debug info to the obj */
|
||||||
unsigned char Debug = 0; /* Debug mode */
|
unsigned char Debug = 0; /* Debug mode */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ extern unsigned char RegVarsToCallStack; /* Save reg variables on call stack */
|
|||||||
extern unsigned char LocalsAreStatic; /* Make local variables static */
|
extern unsigned char LocalsAreStatic; /* Make local variables static */
|
||||||
extern unsigned char SignedChars; /* Make characters signed by default */
|
extern unsigned char SignedChars; /* Make characters signed by default */
|
||||||
extern unsigned char Verbose; /* Verbose flag */
|
extern unsigned char Verbose; /* Verbose flag */
|
||||||
extern unsigned char IncSource; /* Include source as comments */
|
extern unsigned char AddSource; /* Add source lines as comments */
|
||||||
extern unsigned char DebugInfo; /* Add debug info to the obj */
|
extern unsigned char DebugInfo; /* Add debug info to the obj */
|
||||||
extern unsigned char Debug; /* Debug mode */
|
extern unsigned char Debug; /* Debug mode */
|
||||||
|
|
||||||
|
@ -162,7 +162,7 @@ int NextLine (void)
|
|||||||
/* Output the source line in the generated assembler file
|
/* Output the source line in the generated assembler file
|
||||||
* if requested.
|
* if requested.
|
||||||
*/
|
*/
|
||||||
if (IncSource && line[Start] != '\0') {
|
if (AddSource && line[Start] != '\0') {
|
||||||
AddCodeLine ("; %s", line+Start);
|
AddCodeLine ("; %s", line+Start);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -260,6 +260,14 @@ static void DefineSym (const char* Def)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static void OptAddSource (const char* Opt, const char* Arg)
|
||||||
|
/* Add source lines as comments in generated assembler file */
|
||||||
|
{
|
||||||
|
AddSource = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void OptAnsi (const char* Opt, const char* Arg)
|
static void OptAnsi (const char* Opt, const char* Arg)
|
||||||
/* Compile in strict ANSI mode */
|
/* Compile in strict ANSI mode */
|
||||||
{
|
{
|
||||||
@ -355,6 +363,7 @@ int main (int argc, char* argv[])
|
|||||||
{
|
{
|
||||||
/* Program long options */
|
/* Program long options */
|
||||||
static const LongOpt OptTab[] = {
|
static const LongOpt OptTab[] = {
|
||||||
|
{ "--add-source", 0, OptAddSource },
|
||||||
{ "--ansi", 0, OptAnsi },
|
{ "--ansi", 0, OptAnsi },
|
||||||
{ "--cpu", 1, OptCPU },
|
{ "--cpu", 1, OptCPU },
|
||||||
{ "--debug-info", 0, OptDebugInfo },
|
{ "--debug-info", 0, OptDebugInfo },
|
||||||
@ -394,7 +403,7 @@ int main (int argc, char* argv[])
|
|||||||
LongOption (&I, OptTab, sizeof(OptTab)/sizeof(OptTab[0]));
|
LongOption (&I, OptTab, sizeof(OptTab)/sizeof(OptTab[0]));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'd': /* debug mode */
|
case 'd': /* debug mode */
|
||||||
Debug = 1;
|
Debug = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -432,8 +441,8 @@ int main (int argc, char* argv[])
|
|||||||
while (*P) {
|
while (*P) {
|
||||||
switch (*P++) {
|
switch (*P++) {
|
||||||
case 'l':
|
case 'l':
|
||||||
LocalsAreStatic = 1;
|
LocalsAreStatic = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -442,7 +451,7 @@ int main (int argc, char* argv[])
|
|||||||
DefineSym (GetArg (&I, 2));
|
DefineSym (GetArg (&I, 2));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'I':
|
case 'I':
|
||||||
OptIncludeDir (Arg, GetArg (&I, 2));
|
OptIncludeDir (Arg, GetArg (&I, 2));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -468,26 +477,26 @@ int main (int argc, char* argv[])
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 'T':
|
case 'T':
|
||||||
IncSource = 1;
|
OptAddSource (Arg, 0);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'V':
|
case 'V':
|
||||||
OptVersion (Arg, 0);
|
OptVersion (Arg, 0);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'W':
|
case 'W':
|
||||||
NoWarn = 1;
|
NoWarn = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
UnknownOption (Arg);
|
UnknownOption (Arg);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (fin) {
|
if (fin) {
|
||||||
fprintf (stderr, "additional file specs ignored\n");
|
fprintf (stderr, "additional file specs ignored\n");
|
||||||
} else {
|
} else {
|
||||||
fin = xstrdup (Arg);
|
fin = xstrdup (Arg);
|
||||||
inp = fopen (fin, "r");
|
inp = fopen (fin, "r");
|
||||||
if (inp == 0) {
|
if (inp == 0) {
|
||||||
Fatal (FAT_CANNOT_OPEN_INPUT, strerror (errno));
|
Fatal (FAT_CANNOT_OPEN_INPUT, strerror (errno));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user