|
45 | 45 | import wycc.util.AbstractCompilationUnit.Value; |
46 | 46 | import wyil.lang.WyilFile; |
47 | 47 | import wyil.lang.WyilFile.Decl; |
| 48 | +import wyil.lang.WyilFile.Decl.Variant; |
48 | 49 | import wyil.lang.WyilFile.Expr; |
| 50 | +import wyil.lang.WyilFile.Expr.Old; |
49 | 51 | import wyil.lang.WyilFile.LVal; |
50 | 52 | import wyil.lang.WyilFile.Modifier; |
51 | 53 | import wyil.lang.WyilFile.Stmt; |
@@ -157,6 +159,19 @@ public Term constructProperty(Decl.Property decl, List<Term> clauses) { |
157 | 159 | return new JavaScriptFile.Method(name, parameters, new Block(body)); |
158 | 160 | } |
159 | 161 |
|
| 162 | + |
| 163 | + @Override |
| 164 | + public Term constructVariant(Variant decl, List<Term> clauses) { |
| 165 | + // Determine qualified name |
| 166 | + String name = toMangledName(decl); |
| 167 | + // Translate parameters |
| 168 | + List<String> parameters = toParameterNames(decl.getParameters()); |
| 169 | + // Construct body from translated clauses |
| 170 | + Term body = new Return(and(clauses)); |
| 171 | + // Done |
| 172 | + return new JavaScriptFile.Method(name, parameters, new Block(body)); |
| 173 | + } |
| 174 | + |
160 | 175 | @Override |
161 | 176 | public Term constructFunction(Decl.Function decl, List<Term> precondition, List<Term> postcondition, Term _body) { |
162 | 177 | if (decl.getModifiers().match(Modifier.Native.class) == null) { |
@@ -751,6 +766,11 @@ public Term constructNew(Expr.New expr, Term operand) { |
751 | 766 | } |
752 | 767 | } |
753 | 768 |
|
| 769 | + @Override |
| 770 | + public Term constructOld(Old expr, Term operand) { |
| 771 | + throw new UnsupportedOperationException(); |
| 772 | + } |
| 773 | + |
754 | 774 | @Override |
755 | 775 | public Term constructNotEqual(Expr.NotEqual expr, Term lhs, Term rhs) { |
756 | 776 | Type lhsT = expr.getFirstOperand().getType(); |
|
0 commit comments