Merge branch '18-add-possibility-to-pass-input-file-and-output-filename' into 'master'
Added possibility to pass filenames for input / output Closes #18 See merge request mkais001/klang!9
This commit is contained in:
8
makefile
8
makefile
@@ -2,13 +2,13 @@
|
|||||||
.PHONY: cleanTests
|
.PHONY: cleanTests
|
||||||
|
|
||||||
run: code.k target/klang-1.0-jar-with-dependencies.jar
|
run: code.k target/klang-1.0-jar-with-dependencies.jar
|
||||||
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang < code.k > code.s
|
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang -o code.s code.k
|
||||||
|
|
||||||
pretty: code.k target/klang-1.0-jar-with-dependencies.jar
|
pretty: code.k target/klang-1.0-jar-with-dependencies.jar
|
||||||
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang --pretty --no-compile < code.k > pretty.k
|
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang --pretty -o pretty.k code.k
|
||||||
|
|
||||||
eval: code.k target/klang-1.0-jar-with-dependencies.jar
|
eval: code.k target/klang-1.0-jar-with-dependencies.jar
|
||||||
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang --evaluate --no-compile < code.k
|
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang --evaluate code.k
|
||||||
|
|
||||||
build: clean target/klang-1.0-jar-with-dependencies.jar
|
build: clean target/klang-1.0-jar-with-dependencies.jar
|
||||||
|
|
||||||
@@ -22,7 +22,7 @@ test: ./src/test/test
|
|||||||
gcc -o ./src/test/test ./src/test/test.s ./src/test/**/*.c ./src/test/test.c
|
gcc -o ./src/test/test ./src/test/test.s ./src/test/**/*.c ./src/test/test.c
|
||||||
|
|
||||||
./src/test/test.s: target/klang-1.0-jar-with-dependencies.jar
|
./src/test/test.s: target/klang-1.0-jar-with-dependencies.jar
|
||||||
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang --no-main < ./src/test/test.k > ./src/test/test.s
|
java -cp target/klang-1.0-jar-with-dependencies.jar de.hsrm.compiler.Klang.Klang --no-main -o ./src/test/test.s ./src/test/test.k
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f ./src/test/test.s
|
rm -f ./src/test/test.s
|
||||||
|
|||||||
@@ -15,24 +15,40 @@ import de.hsrm.compiler.Klang.helper.*;
|
|||||||
|
|
||||||
public class Klang {
|
public class Klang {
|
||||||
|
|
||||||
|
private static void generateOutput(String file, String output) {
|
||||||
|
if (file != null) {
|
||||||
|
try {
|
||||||
|
var outFile = new FileWriter(file);
|
||||||
|
outFile.write(output);
|
||||||
|
outFile.close();
|
||||||
|
} catch (Exception e) {
|
||||||
|
System.err.println("Cannot write output to file");
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
System.out.println(output);
|
||||||
|
}
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
boolean evaluate = false;
|
boolean evaluate = false;
|
||||||
boolean prettyPrint = false;
|
boolean prettyPrint = false;
|
||||||
boolean compile = true;
|
|
||||||
String mainName = "main";
|
String mainName = "main";
|
||||||
|
String out = null;
|
||||||
|
|
||||||
List<String> arguments = Arrays.asList(args);
|
List<String> arguments = Arrays.asList(args);
|
||||||
if (arguments.contains("-h") || arguments.contains("--help") || arguments.contains("?")) {
|
if (arguments.size() <= 0 || arguments.contains("-h") || arguments.contains("--help") || arguments.contains("?")) {
|
||||||
System.out.println("\nKaiser Lang Compiler");
|
System.out.println("\nKaiser Lang Compiler");
|
||||||
System.out.println("Authors: Dennis Kaiser and Marvin Kaiser");
|
System.out.println("Authors: Dennis Kaiser and Marvin Kaiser");
|
||||||
System.out.println("");
|
System.out.println("");
|
||||||
System.out.println("Pass source code via stdin");
|
System.out.println("Last argument must be file");
|
||||||
System.out.println("");
|
System.out.println("");
|
||||||
System.out.println("Arguments:");
|
System.out.println("Arguments:");
|
||||||
|
System.out.println("--out <file>:\t File to write to");
|
||||||
System.out.println("--evaluate:\t Evaluates the given source code");
|
System.out.println("--evaluate:\t Evaluates the given source code");
|
||||||
System.out.println("--pretty:\t Pretty print the given source code");
|
System.out.println("--pretty:\t Pretty print the given source code");
|
||||||
System.out.println("--no-compile:\t Do not compile the source code");
|
System.out
|
||||||
System.out.println("--no-main:\t Do not generate main function, will be generated as 'start'. Useful for testing");
|
.println("--no-main:\t Do not generate main function, will be generated as 'start'. Useful for testing");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (arguments.contains("--evaluate")) {
|
if (arguments.contains("--evaluate")) {
|
||||||
@@ -41,15 +57,19 @@ public class Klang {
|
|||||||
if (arguments.contains("--pretty")) {
|
if (arguments.contains("--pretty")) {
|
||||||
prettyPrint = true;
|
prettyPrint = true;
|
||||||
}
|
}
|
||||||
if (arguments.contains("--no-compile")) {
|
|
||||||
compile = false;
|
|
||||||
}
|
|
||||||
if (arguments.contains("--no-main")) {
|
if (arguments.contains("--no-main")) {
|
||||||
mainName = "start";
|
mainName = "start";
|
||||||
}
|
}
|
||||||
|
if (arguments.contains("-o")) {
|
||||||
|
if (arguments.size() <= 1) {
|
||||||
|
System.out.println("Must specify file name with -o");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
out = arguments.get(arguments.indexOf("-o") + 1);
|
||||||
|
}
|
||||||
|
|
||||||
// create a CharStream that reads from standard input
|
// create a CharStream that reads from standard input
|
||||||
CharStream input = CharStreams.fromStream(System.in);
|
CharStream input = CharStreams.fromFileName(arguments.get(arguments.size() - 1));
|
||||||
|
|
||||||
// create a lexer that feeds off of input CharStream
|
// create a lexer that feeds off of input CharStream
|
||||||
KlangLexer lexer = new KlangLexer(input);
|
KlangLexer lexer = new KlangLexer(input);
|
||||||
@@ -77,17 +97,8 @@ public class Klang {
|
|||||||
PrettyPrintVisitor.ExWriter ex = new PrettyPrintVisitor.ExWriter(w);
|
PrettyPrintVisitor.ExWriter ex = new PrettyPrintVisitor.ExWriter(w);
|
||||||
PrettyPrintVisitor printVisitor = new PrettyPrintVisitor(ex);
|
PrettyPrintVisitor printVisitor = new PrettyPrintVisitor(ex);
|
||||||
node.welcome(printVisitor);
|
node.welcome(printVisitor);
|
||||||
System.out.println(w.toString());
|
generateOutput(out, w.toString());
|
||||||
}
|
return;
|
||||||
|
|
||||||
if (compile) {
|
|
||||||
// Generate assembler code
|
|
||||||
// System.out.println("\nPrinting the assembler code");
|
|
||||||
StringWriter wAsm = new StringWriter();
|
|
||||||
GenASM.ExWriter exAsm = new GenASM.ExWriter(wAsm);
|
|
||||||
GenASM genasm = new GenASM(exAsm, mainName);
|
|
||||||
node.welcome(genasm);
|
|
||||||
System.out.println(wAsm.toString());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (evaluate) {
|
if (evaluate) {
|
||||||
@@ -96,10 +107,19 @@ public class Klang {
|
|||||||
EvalVisitor evalVisitor = new EvalVisitor();
|
EvalVisitor evalVisitor = new EvalVisitor();
|
||||||
Value result = node.welcome(evalVisitor);
|
Value result = node.welcome(evalVisitor);
|
||||||
if (result != null) {
|
if (result != null) {
|
||||||
System.out.println("result: " + result.asInteger());
|
generateOutput(out, "Result was: TODO");
|
||||||
} else {
|
} else {
|
||||||
System.out.println("result was null");
|
System.out.println("result was null");
|
||||||
}
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Generate assembler code
|
||||||
|
// System.out.println("\nPrinting the assembler code");
|
||||||
|
StringWriter wAsm = new StringWriter();
|
||||||
|
GenASM.ExWriter exAsm = new GenASM.ExWriter(wAsm);
|
||||||
|
GenASM genasm = new GenASM(exAsm, mainName);
|
||||||
|
node.welcome(genasm);
|
||||||
|
generateOutput(out, wAsm.toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user