add ret void pour func void
This commit is contained in:
@@ -218,6 +218,10 @@ td_expression returns [Expression out]:
|
||||
;
|
||||
|
||||
lit returns [Expression out]:
|
||||
MINUS n=lit {
|
||||
$out = new BinopExpressionImp(Op.MINUS, new ConstImp(0), $n.out);
|
||||
}
|
||||
|
|
||||
NUMBER {
|
||||
$out = new ConstImp($NUMBER.int);
|
||||
}
|
||||
|
||||
@@ -78,8 +78,8 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
|
||||
if(!(instrLLVM.getLast() instanceof ReturnLLVMImp || instrLLVM.getLast() instanceof BrLLVMImp)){
|
||||
instrLLVM.add(new ReturnLLVMImp(type, new ValLLVMImp(type,0)));
|
||||
}
|
||||
}else {
|
||||
//TODO
|
||||
}else if(type instanceof VoidLLVMImp){
|
||||
instrLLVM.add(new ReturnLLVMImp(type,null));
|
||||
}
|
||||
DefineLLVMImp define = new DefineLLVMImp(fun.nom(), type, paramsLLVM, instrLLVM);
|
||||
return define;
|
||||
@@ -138,14 +138,18 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
|
||||
|
||||
@Override
|
||||
public ArrayList<InstructionLLVM> visitReturn(Return_instrImp instr, SymTable h) {
|
||||
InstrAndVal res = instr.e().accept(this,h);
|
||||
ValLLVM var = res.val;
|
||||
|
||||
InstructionLLVM r = new ReturnLLVMImp(var.getType(),var);
|
||||
ArrayList<InstructionLLVM> result = new ArrayList<>();
|
||||
result.addAll(res.instrs);
|
||||
result.add(r);
|
||||
//ret void
|
||||
if (instr.e() == null) {
|
||||
result.add(new ReturnLLVMImp(new VoidLLVMImp(), null));
|
||||
}else{
|
||||
InstrAndVal res = instr.e().accept(this,h);
|
||||
ValLLVM var = res.val;
|
||||
|
||||
InstructionLLVM r = new ReturnLLVMImp(var.getType(),var);
|
||||
result.addAll(res.instrs);
|
||||
result.add(r);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
|
||||
@@ -62,7 +62,11 @@ TypeLLVMVisitor<String,String>
|
||||
|
||||
@Override
|
||||
public String visitReturnLLVM(ReturnLLVMImp instr, String h) {
|
||||
return INDENT+"ret " + instr.type().accept(this, h) + " " + instr.e().accept(this, h);
|
||||
if (instr.e() == null) {
|
||||
return INDENT + "ret " + instr.type().accept(this, h);
|
||||
} else {
|
||||
return INDENT + "ret " + instr.type().accept(this, h) + " " + instr.e().accept(this, h);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -128,31 +132,32 @@ TypeLLVMVisitor<String,String>
|
||||
|
||||
@Override
|
||||
public String visitCallLLVM(CallLLVMImp instr, String h) {
|
||||
String str = "call " + instr.str() + instr.f().type().accept(this, h) + " @"+instr.f().name() + "(";
|
||||
for(int i = 0; i<instr.params().size(); i++){
|
||||
str += instr.params().get(i).getType().accept(this, h) + " " + instr.params().get(i).accept(this,h);
|
||||
if(i<instr.params().size()-1) str += ", ";
|
||||
String str = "call " + instr.f().type().accept(this, h) + " (" + instr.str() + ") @" + instr.f().name() + "(";
|
||||
|
||||
for (int i = 0; i < instr.params().size(); i++) {
|
||||
str += instr.params().get(i).getType().accept(this, h) + " " + instr.params().get(i).accept(this, h);
|
||||
if (i < instr.params().size() - 1) str += ", ";
|
||||
}
|
||||
return str + ")";
|
||||
return str + ")";
|
||||
}
|
||||
|
||||
@Override
|
||||
public String visitPrintLLVM(PrintLLVMImp instr, String h) { //TODO
|
||||
DefineLLVMImp printLLVM = new DefineLLVMImp("printf", new IntLLVMImp(), new ArrayList<>(), new ArrayList<>());
|
||||
CallLLVMImp callPrint = new CallLLVMImp(printLLVM, instr.l(),"(i8*,...) ");
|
||||
CallLLVMImp callPrint = new CallLLVMImp(printLLVM, instr.l(),"i8*, ...");
|
||||
return callPrint.accept(this, h);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String visitScanLLVM(ScanLLVMImp instr, String h) { //TODO
|
||||
DefineLLVMImp readLLVM = new DefineLLVMImp("scanf", new IntLLVMImp(), new ArrayList<>(), new ArrayList<>());
|
||||
CallLLVMImp callRead = new CallLLVMImp(readLLVM, instr.l(),"(i8*,...) ");
|
||||
CallLLVMImp callRead = new CallLLVMImp(readLLVM, instr.l(),"i8*, ...");
|
||||
return callRead.accept(this, h);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String visitDeclarGlobalLLVM(DeclarGlobalLLVMImp instr, String h) {
|
||||
String str = "@."+instr.var().nom() + " = global";
|
||||
String str = "@"+instr.var().nom() + " = global";
|
||||
str += " [" + instr.size() + " x "+ instr.type().accept(this, h) + "] ";
|
||||
str+= "c\""+ instr.str()+"\"\n";
|
||||
|
||||
|
||||
@@ -1,23 +1 @@
|
||||
FUNC INT test1(a,b){
|
||||
a := a+b
|
||||
}
|
||||
|
||||
FUNC INT test2(a,b){
|
||||
IF a
|
||||
THEN
|
||||
RETURN a
|
||||
FI
|
||||
}
|
||||
|
||||
FUNC INT test3(a,b){
|
||||
IF a
|
||||
THEN
|
||||
RETURN a
|
||||
ELSE
|
||||
RETURN b
|
||||
FI
|
||||
}
|
||||
|
||||
FUNC INT main(x,y) {
|
||||
x := test1(x,y)
|
||||
}
|
||||
FUNC VOID main() PRINT 1
|
||||
|
||||
BIN
tests/fragment1/hello_world
Executable file
BIN
tests/fragment1/hello_world
Executable file
Binary file not shown.
BIN
tests/fragment1/print1
Executable file
BIN
tests/fragment1/print1
Executable file
Binary file not shown.
BIN
tests/fragment1/print2
Executable file
BIN
tests/fragment1/print2
Executable file
Binary file not shown.
BIN
tests/fragment1/print3
Executable file
BIN
tests/fragment1/print3
Executable file
Binary file not shown.
BIN
tests/fragment1/print4
Executable file
BIN
tests/fragment1/print4
Executable file
Binary file not shown.
BIN
tests/fragment1/sequence
Executable file
BIN
tests/fragment1/sequence
Executable file
Binary file not shown.
BIN
tests/fragment2/call
Executable file
BIN
tests/fragment2/call
Executable file
Binary file not shown.
Reference in New Issue
Block a user