gitweb on Svarog
projekti pod git sistemom za održavanje verzija -- projects under the git version control systemdiff --git a/src/mjc2wsl.java b/src/mjc2wsl.java
--- a/src/mjc2wsl.java
+++ b/src/mjc2wsl.java
* @author Doni Pracner, http://perun.dmi.rs/pracner http://quemaster.com
*/
public class mjc2wsl{
- public static String versionN = "0.1.5";
+ public static String versionN = "0.1.6";
private TransMessages messages = new TransMessages();
private boolean genPauseAfterEachAddress=false,
genPrintForEachAddress = false,
genPrintEStackOnChange = false;
+
+ private boolean genPopPush=false;
/** Constant used for marking a regular comment from the original file */
public static final char C_REG = ' ';
public static String createComment(String str, char type) {
return "C:\"" + type + str.replace("\"", "''") + "\";";
}
+
+ // generalised stack operations
+
+ private String createToStack(String stack, String var){
+ if (genPopPush)
+ return "PUSH("+stack+"," + var + ");";
+ else
+ return stack + " := <" + var + " > ++ " + stack +";";
+ }
- //Expression stack
+ private String createFromStack(String stack, String var){
+ if (genPopPush)
+ return "POP("+ var + ", "+stack+");";
+ else
+ return var + ":= HEAD("+stack+"); "+stack+" := TAIL("+stack+");";
+ }
+//Expression stack
private String createToEStack(int i) {
- String res = "mjvm_estack := <" + i + " > ++ mjvm_estack;";
- if (genPrintEStackOnChange)
- res += "PRINT(\"eStack\",mjvm_estack);";
- return res;
+ return createToEStack(i+"");
}
private String createToEStack(String i) {
- String res = "mjvm_estack := <" + i + " > ++ mjvm_estack;";
+ String res = createToStack("mjvm_estack", i);
if (genPrintEStackOnChange)
res += "PRINT(\"eStack\",mjvm_estack);";
return res;
}
private String createFromEStack(String st) {
- String res = st
- + " := HEAD(mjvm_estack); mjvm_estack := TAIL(mjvm_estack);";
+ String res = createFromStack("mjvm_estack",st);
if (genPrintEStackOnChange)
res += "PRINT(\"eStack\",mjvm_estack);";
return res;
//Method stack
private String createToMStack(int i) {
- return "mjvm_mstack := <" + i + " > ++ mjvm_mstack;";
+ return createToMStack(i+"");
}
private String createToMStack(String i) {
- return "mjvm_mstack := <" + i + " > ++ mjvm_mstack;";
+ return createToStack("mjvm_mstack", i);
}
private String createFromMStack(String st) {
- return st + " := HEAD(mjvm_mstack); mjvm_mstack := TAIL(mjvm_mstack);";
+ return createFromStack("mjvm_mstack", st);
}
private String getRelationFor(int opcode) throws Exception {
case load_1:
case load_2:
case load_3: {
- prl(createToEStack(createLocal(op - load_0)));
+ prl(createStartVar("tempa"));
+ prl("tempa :="+createLocal(op - load_0)+";");
+ prl(createToEStack("tempa"));
+ prl(createEndVar());
break;
}
case store: {
case store_1:
case store_2:
case store_3: {
- prl(createFromEStack(createLocal(op - store_0)));
+ prl(createStartVar("tempa"));
+ prl(createFromEStack("tempa"));
+ prl(createLocal(op - store_0)+" := tempa;");
+ prl(createEndVar());
break;
}
System.out.println();
printHelpOutput();
System.out.println();
+ printHelpDirectives();
+ System.out.println();
printHelpGenerating();
System.out.println();
printHelpHelp();
System.out.println(" --genAll short for applying all code generation");
}
+ public void printHelpDirectives(){
+ System.out.println("Alternatives for code generation:");
+ System.out.println(" --genPopPush generate POP/PUSH instead of TAIL/HEAD");
+ }
+
public void printHelpHelp() {
System.out.println("Help and info options");
System.out.println(" -h basic help");
genPrintEStackOnChange = true;
genPrintForEachAddress = true;
genPauseAfterEachAddress = true;
+ } else if (args[i].compareToIgnoreCase("--genPopPush") == 0) {
+ genPopPush = true;
}
i++;
}