diff options
| author | jwansek <eddie.atten.ea29@gmail.com> | 2021-10-24 14:07:29 +0100 | 
|---|---|---|
| committer | jwansek <eddie.atten.ea29@gmail.com> | 2021-10-24 14:07:29 +0100 | 
| commit | 8f50e4d189bad9dbd180fd945881950769c3a989 (patch) | |
| tree | 1aae93b37a9369be67bdb1e02e1c6cb69d02e702 /code/simpleSableCCCalulator | |
| parent | e09b0bb865bbb0087c46b4acd90b759f14dfa824 (diff) | |
| download | esotericFORTRAN-8f50e4d189bad9dbd180fd945881950769c3a989.tar.gz esotericFORTRAN-8f50e4d189bad9dbd180fd945881950769c3a989.zip | |
added the start of a type system
Diffstat (limited to 'code/simpleSableCCCalulator')
8 files changed, 196 insertions, 91 deletions
| diff --git a/code/simpleSableCCCalulator/Makefile b/code/simpleSableCCCalulator/Makefile new file mode 100644 index 0000000..7c6962b --- /dev/null +++ b/code/simpleSableCCCalulator/Makefile @@ -0,0 +1,8 @@ +all:  +	javac sableCCCalculator/*.java +	javac sableCCCalculator/types/*.java + + +clean: +	rm -vf sableCCCalculator/*.class +	rm -vf sableCCCalculator/types/*class diff --git a/code/simpleSableCCCalulator/examples/maths.txt b/code/simpleSableCCCalulator/examples/maths.txt index f3b3bd9..36726f5 100644 --- a/code/simpleSableCCCalulator/examples/maths.txt +++ b/code/simpleSableCCCalulator/examples/maths.txt @@ -1 +1 @@ -(36/2 + 45) * 3
\ No newline at end of file +(36/2 + 45.2) * 3
\ No newline at end of file diff --git a/code/simpleSableCCCalulator/examples/maths4.txt b/code/simpleSableCCCalulator/examples/maths4.txt new file mode 100644 index 0000000..5b3e67d --- /dev/null +++ b/code/simpleSableCCCalulator/examples/maths4.txt @@ -0,0 +1 @@ +2 + 3.1 diff --git a/code/simpleSableCCCalulator/sableCCCalculator/ProgramStack.java b/code/simpleSableCCCalulator/sableCCCalculator/ProgramStack.java index 1875e57..c1046ee 100644 --- a/code/simpleSableCCCalulator/sableCCCalculator/ProgramStack.java +++ b/code/simpleSableCCCalulator/sableCCCalculator/ProgramStack.java @@ -1,26 +1,27 @@  package sableCCCalculator; -import sableCCCalculator.node.*; +import sableCCCalculator.types.*;  import java.util.Stack; -public class ProgramStack<T extends Token> extends Stack<T> { +public class ProgramStack<T extends Type> extends Stack<T> {      public String toString() {          String out = "Stack is now: [";          for (int i = 0; i < this.size(); i++) { -            String theStr = this.elementAt(i).toString(); -            out += String.format("%s, ", theStr.substring(0, theStr.length() - 1)); +            // String theStr = this.elementAt(i).toString(); +            // out += String.format("%s, ", theStr.substring(0, theStr.length() - 1)); +            out += String.format("%s, ", this.elementAt(i).toString());          }          return out.substring(0, out.length() - 2) + "]";      }      public static void main(String[] args) { -        ProgramStack<Token> myStack = new ProgramStack<>(); -        myStack.add(new TNumber("2")); -        myStack.add(new TNumber("4")); -        myStack.add(new TNumber("6")); -        myStack.add(new TNumber("0")); -        myStack.add(new TNumber("1")); -        myStack.add(new TDouble("24601.10642")); +        ProgramStack<Type> myStack = new ProgramStack<>(); +        myStack.add(new Int(2)); +        myStack.add(new Int(4)); +        myStack.add(new Int(6)); +        myStack.add(new Int(0)); +        myStack.add(new Int(1)); +        myStack.add(new Decimal(24601.10642));          System.out.println(myStack.pop().getText());          System.out.println(myStack); diff --git a/code/simpleSableCCCalulator/sableCCCalculator/Translation.java b/code/simpleSableCCCalulator/sableCCCalculator/Translation.java index d8fd74d..a673edb 100644 --- a/code/simpleSableCCCalulator/sableCCCalculator/Translation.java +++ b/code/simpleSableCCCalulator/sableCCCalculator/Translation.java @@ -1,22 +1,23 @@  package sableCCCalculator;  import sableCCCalculator.analysis.*; +import sableCCCalculator.types.*;  import sableCCCalculator.node.*;  class Translation extends DepthFirstAdapter  { -    private ProgramStack<Token> programStack = new ProgramStack<>(); +    private ProgramStack<Type> programStack = new ProgramStack<>();      public void caseTNumber(TNumber node)      {          System.out.println("Pushing " + Integer.parseInt(node.getText()) + " to stack"); -        programStack.push(node); +        programStack.push(new Int(node.getText()));          System.out.println(programStack);      }      public void caseTDouble(TDouble node)      {          System.out.println("Pushing a double: " + Double.parseDouble(node.getText())); -        programStack.push(node); +        programStack.push(new Decimal(node.getText()));          System.out.println(programStack);      } @@ -25,108 +26,63 @@ class Translation extends DepthFirstAdapter          Double num = Double.parseDouble(programStack.pop().getText());          System.out.println("Popped " + num);          Double out = Math.sin(Math.toRadians(num)); -        programStack.push(new TDouble(String.format("%f", out))); +        programStack.push(new Decimal(out));          System.out.println("Pushed sin(" + num + ") = " + out + " to stack");          System.out.println(programStack);      }      public void outAPlusExpr(APlusExpr node)      { -        Double num2 = Double.parseDouble(programStack.pop().getText()); -        Double num1 = Double.parseDouble(programStack.pop().getText()); -        System.out.println("Popped " + num1 + " and " + num2 + " from stack"); -        Double out = num1 + num2; -        if ((out % 1) == 0)  -        { -            // the output is an integer, change types to save memory -            programStack.push(new TNumber(String.format("%d", out.intValue()))); -        } -        else -        { -            programStack.push(new TDouble(String.format("%f", out))); -        } -         -        System.out.println("Pushed " + num1 + "+" + num2 + "=" + out + " to stack"); +        Type op2 = programStack.pop(); +        Type op1 = programStack.pop(); +        System.out.println("Popped " + op1 + " and " + op2 + " from stack"); +        Type out = op1.add(op2); +        programStack.push(out); +        System.out.println("Pushed " + op1 + "+" + op2 + "=" + out + " to stack");          System.out.println(programStack);      }      public void outAMinusExpr(AMinusExpr node)      { -        Double num2 = Double.parseDouble(programStack.pop().getText()); -        Double num1 = Double.parseDouble(programStack.pop().getText()); -        System.out.println("Popped " + num1 + " and " + num2 + " from stack"); -        Double out = num1 - num2; -        if ((out % 1) == 0)  -        { -            // the output is an integer, change types to save memory -            programStack.push(new TNumber(String.format("%d", out.intValue()))); -        } -        else -        { -            programStack.push(new TDouble(String.format("%f", out))); -        } -         -        System.out.println("Pushed " + num1 + "-" + num2 + "=" + out + " to stack"); +        Type op2 = programStack.pop(); +        Type op1 = programStack.pop(); +        System.out.println("Popped " + op1 + " and " + op2 + " from stack"); +        Type out = op1.sub(op2); +        programStack.push(out); +        System.out.println("Pushed " + op1 + "-" + op2 + "=" + out + " to stack");          System.out.println(programStack);      }      public void outAMultFactor(AMultFactor node)      { -        Double num2 = Double.parseDouble(programStack.pop().getText()); -        Double num1 = Double.parseDouble(programStack.pop().getText()); -        System.out.println("Popped " + num1 + " and " + num2 + " from stack"); -        Double out = num1 * num2; -        if ((out % 1) == 0)  -        { -            // the output is an integer, change types to save memory -            programStack.push(new TNumber(String.format("%d", out.intValue()))); -        } -        else -        { -            programStack.push(new TDouble(String.format("%f", out))); -        } -         -        System.out.println("Pushed " + num1 + "*" + num2 + "=" + out + " to stack"); +        Type op2 = programStack.pop(); +        Type op1 = programStack.pop(); +        System.out.println("Popped " + op1 + " and " + op2 + " from stack"); +        Type out = op1.mult(op2); +        programStack.push(out); +        System.out.println("Pushed " + op1 + "*" + op2 + "=" + out + " to stack");          System.out.println(programStack);      }      public void outADivFactor(ADivFactor node)      { -        Double num2 = Double.parseDouble(programStack.pop().getText()); -        Double num1 = Double.parseDouble(programStack.pop().getText()); -        System.out.println("Popped " + num1 + " and " + num2 + " from stack"); -        Double out = num1 / num2; -        if ((out % 1) == 0)  -        { -            // the output is an integer, change types to save memory -            programStack.push(new TNumber(String.format("%d", out.intValue()))); -        } -        else -        { -            programStack.push(new TDouble(String.format("%f", out))); -        } -         -        System.out.println("Pushed " + num1 + "/" + num2 + "=" + out + " to stack"); +        Type op2 = programStack.pop(); +        Type op1 = programStack.pop(); +        System.out.println("Popped " + op1 + " and " + op2 + " from stack"); +        Type out = op1.div(op2); +        programStack.push(out); +        System.out.println("Pushed " + op1 + "/" + op2 + "=" + out + " to stack");          System.out.println(programStack);      }      public void outAModFactor(AModFactor node)      { -        Double num2 = Double.parseDouble(programStack.pop().getText()); -        Double num1 = Double.parseDouble(programStack.pop().getText()); -        System.out.println("Popped " + num1 + " and " + num2 + " from stack"); -        Double out = num1 % num2; -        if ((out % 1) == 0)  -        { -            // the output is an integer, change types to save memory -            programStack.push(new TNumber(String.format("%d", out.intValue()))); -        } -        else -        { -            programStack.push(new TDouble(String.format("%f", out))); -        } -         -        System.out.println("Pushed " + num1 + "%" + num2 + "=" + out + " to stack"); +        Type op2 = programStack.pop(); +        Type op1 = programStack.pop(); +        System.out.println("Popped " + op1 + " and " + op2 + " from stack"); +        Type out = op1.mod(op2); +        programStack.push(out); +        System.out.println("Pushed " + op1 + "%" + op2 + "=" + out + " to stack");          System.out.println(programStack);      }  } diff --git a/code/simpleSableCCCalulator/sableCCCalculator/types/Decimal.java b/code/simpleSableCCCalulator/sableCCCalculator/types/Decimal.java new file mode 100644 index 0000000..5836ff1 --- /dev/null +++ b/code/simpleSableCCCalulator/sableCCCalculator/types/Decimal.java @@ -0,0 +1,57 @@ +package sableCCCalculator.types; + +public class Decimal extends Type { + +    public Decimal(Double toDecimal) { +        javaObject = (Double)toDecimal; +    } + +    public Decimal(String toDecimal) { +        javaObject = (Double)Double.parseDouble(toDecimal); +    }   + +    public Decimal add(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Decimal")) { +            return new Decimal((Double)this.javaObject + (double)toAdd.javaObject); +        } else { +            return new Decimal((Double)this.javaObject + Double.parseDouble(String.format("%d", (int)toAdd.javaObject))); +        } +    } +     +    public Decimal sub(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Decimal")) { +            return new Decimal((Double)this.javaObject - (double)toAdd.javaObject); +        } else { +            return new Decimal((Double)this.javaObject - Double.parseDouble(String.format("%d", (int)toAdd.javaObject))); +        } +    } + +    public Decimal mult(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Decimal")) { +            return new Decimal((Double)this.javaObject * (double)toAdd.javaObject); +        } else { +            return new Decimal((Double)this.javaObject * Double.parseDouble(String.format("%d", (int)toAdd.javaObject))); +        } +    } + +    public Decimal div(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Decimal")) { +            return new Decimal((Double)this.javaObject / (double)toAdd.javaObject); +        } else { +            return new Decimal((Double)this.javaObject / Double.parseDouble(String.format("%d", (int)toAdd.javaObject))); +        } +    } + +    public Decimal mod(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Decimal")) { +            return new Decimal((Double)this.javaObject % (double)toAdd.javaObject); +        } else { +            return new Decimal((Double)this.javaObject % Double.parseDouble(String.format("%d", (int)toAdd.javaObject))); +        } +    } + +    public static void main(String[] args) { +        Decimal aDec = new Decimal(3.1); +        System.out.println(aDec.sub(new Int(2))); +    } +} diff --git a/code/simpleSableCCCalulator/sableCCCalculator/types/Int.java b/code/simpleSableCCCalulator/sableCCCalculator/types/Int.java new file mode 100644 index 0000000..1ccd20e --- /dev/null +++ b/code/simpleSableCCCalulator/sableCCCalculator/types/Int.java @@ -0,0 +1,60 @@ +package sableCCCalculator.types; + +public class Int extends Type { +     +    public Int(int toInt) { +        javaObject = (Integer)toInt; +    } + +    public Int(String toInt) { +        javaObject = (Integer)Integer.parseInt(toInt); +    } + +    public Type add(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Int")) { +            return new Int((int)this.javaObject + (int)toAdd.javaObject); +        } else { +            return new Decimal(Double.parseDouble(String.format("%d", (int)this.javaObject)) + (Double)toAdd.javaObject); +        } +    } + +    public Type sub(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Int")) { +            return new Int((int)this.javaObject - (int)toAdd.javaObject); +        } else { +            return new Decimal(Double.parseDouble(String.format("%d", (int)this.javaObject)) - (Double)toAdd.javaObject); +        } +    } + +    public Type mult(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Int")) { +            return new Int((int)this.javaObject * (int)toAdd.javaObject); +        } else { +            return new Decimal(Double.parseDouble(String.format("%d", (int)this.javaObject)) * (Double)toAdd.javaObject); +        } +    } + +    public Type div(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Int")) { +            return new Int((int)this.javaObject / (int)toAdd.javaObject); +        } else { +            return new Decimal(Double.parseDouble(String.format("%d", (int)this.javaObject)) / (Double)toAdd.javaObject); +        } +    } + +    public Type mod(Type toAdd) { +        if (toAdd.getClass().getSimpleName().equals("Int")) { +            return new Int((int)this.javaObject % (int)toAdd.javaObject); +        } else { +            return new Decimal(Double.parseDouble(String.format("%d", (int)this.javaObject)) % (Double)toAdd.javaObject); +        } +    } + +    public static void main(String[] args) { +        Int int1 = new Int(3); +        System.out.println(int1.add(new Int(4))); + +        Int int2 = new Int(3); +        System.out.println(int2.mult(new Decimal(2.2))); +    } +} diff --git a/code/simpleSableCCCalulator/sableCCCalculator/types/Type.java b/code/simpleSableCCCalulator/sableCCCalculator/types/Type.java new file mode 100644 index 0000000..359f2b8 --- /dev/null +++ b/code/simpleSableCCCalulator/sableCCCalculator/types/Type.java @@ -0,0 +1,22 @@ +package sableCCCalculator.types; + +// not happy with the amount of polymorphism +// using generics would be better but idk how that'd work in this context... +public abstract class Type { + +    protected Object javaObject; + +    public abstract Type add(Type toAdd); +    public abstract Type sub(Type toSub); +    public abstract Type mult(Type toMult); +    public abstract Type div(Type toDiv); +    public abstract Type mod(Type toMod); +     +    public String toString() { +        return javaObject.toString(); +    } + +    public String getText() { +        return this.toString(); +    } +}
\ No newline at end of file | 
