shithub: scc

Download patch

ref: 0298b8c6607844bc77deb5d21da651a4954af076
parent: 30d5a2c869c5f47cca98fdedb9024d462c6b9191
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Mon Dec 11 14:26:41 EST 2017

[as] Add command line options

--- a/as/as.h
+++ b/as/as.h
@@ -175,4 +175,4 @@
 extern TUINT maxaddr;
 extern int endian;
 extern Symbol *linesym, *symlist;
-extern char *filename;
+extern char *infile;
--- a/as/main.c
+++ b/as/main.c
@@ -7,8 +7,20 @@
 #include <string.h>
 
 #include "../inc/scc.h"
+#include "../inc/arg.h"
 #include "as.h"
 
+char *argv0;
+char *outfile, *infile;
+
+
+static void
+cleanup(void)
+{
+	if (outfile)
+		remove(outfile);
+}
+
 static int
 cmp(const void *f1, const void *f2)
 {
@@ -81,7 +93,7 @@
 	if (fclose(fp))
 		die("as: error reading from input file '%s'", fname);
 	if (pass == 2)
-		writeout("a.out");
+		writeout(outfile);
 	/*
 	 * kill tmp symbols because they are not needed anymore
 	 */
@@ -100,15 +112,27 @@
 int
 main(int argc, char *argv[])
 {
-	if (argc != 2)
+	outfile = "a.out";
+
+	ARGBEGIN {
+	case 'o':
+		outfile = EARGF(usage());
+		break;
+	default:
 		usage();
+	} ARGEND
 
+	if (argc != 1)
+		usage();
+	infile = *argv;
+
+	atexit(cleanup);
 	iarch();
-	filename = argv[1];
 	for (pass = 1; pass <= 2; pass++) {
-		if (!dopass(filename))
+		if (!dopass(infile))
 			return 1;
 	}
+	outfile = NULL;
 
 	return 0;
 }
--- a/as/parser.c
+++ b/as/parser.c
@@ -12,7 +12,6 @@
 #define NARGS 20
 #define MAXLINE 100
 
-char *filename;
 int nerrors;
 jmp_buf recover;
 
@@ -24,7 +23,7 @@
 	va_list va;
 
 	va_start(va, msg);
-	fprintf(stderr, "as:%s:%u: ", filename, lineno);
+	fprintf(stderr, "as:%s:%u: ", infile, lineno);
 	vfprintf(stderr, msg, va);
 	putc('\n', stderr);
 	nerrors++;