call réparé

This commit is contained in:
trochas
2025-04-28 14:40:59 +02:00
parent a421811002
commit f2c2dfedfc
4 changed files with 31 additions and 5 deletions

View File

@@ -205,7 +205,7 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
System.err.println("Fonction n'est pas un void"); System.err.println("Fonction n'est pas un void");
} }
l.add(new CallLLVMImp(fun.define,paramsLLVM,"")); l.add(new CallVoidLLVMImp(fun.define,paramsLLVM,""));
return l; return l;
} }
@@ -356,6 +356,7 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
} }
public InstrAndVal visitAppeal(AppealImp instr,SymTable h){ public InstrAndVal visitAppeal(AppealImp instr,SymTable h){
SymTable prevSymTable = h;
ArrayList<InstructionLLVM> l = new ArrayList<>(); ArrayList<InstructionLLVM> l = new ArrayList<>();
ArrayList<ValLLVM> paramsLLVM = new ArrayList<>(); ArrayList<ValLLVM> paramsLLVM = new ArrayList<>();
for(Expression param : instr.params()){ for(Expression param : instr.params()){
@@ -374,7 +375,8 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
h = res.symTable; h = res.symTable;
VarLLVMImp var = new VarLLVMImp(fLLVM.define.type(), res.var); VarLLVMImp var = new VarLLVMImp(fLLVM.define.type(), res.var);
l.add(new CallLLVMImp(fLLVM.define,paramsLLVM,"")); l.add(new AssignLLVMImp(var, new CallLLVMImp(fLLVM.define,paramsLLVM,"")));
prevSymTable.updateId(h);
return new InstrAndVal(l, var); return new InstrAndVal(l, var);
} }

View File

@@ -34,7 +34,7 @@ public interface Interface {
public S visitLabelLLVM(LabelLLVMImp instr, H h); public S visitLabelLLVM(LabelLLVMImp instr, H h);
public S visitBrLLVM(BrLLVMImp instr, H h); public S visitBrLLVM(BrLLVMImp instr, H h);
public S visitBrCondLLVM(BrCondLLVMImp instr, H h); public S visitBrCondLLVM(BrCondLLVMImp instr, H h);
public S visitCallLLVM(CallLLVMImp instr, H h); public S visitCallVoidLLVM(CallVoidLLVMImp instr, H h);
} }
//////////ExpressionLLVM (expression) //////////ExpressionLLVM (expression)
@@ -53,6 +53,7 @@ public interface Interface {
public S visitValLLVM(ValLLVMImp e,H h); public S visitValLLVM(ValLLVMImp e,H h);
public S visitVarLLVM(VarLLVMImp e,H h); public S visitVarLLVM(VarLLVMImp e,H h);
public S visitIcmpLLVM(IcmpLLVMImp e, H h); public S visitIcmpLLVM(IcmpLLVMImp e, H h);
public S visitCallLLVM(CallLLVMImp e, H h);
} }
/*public interface IdentifierLLVM{ //globaux @ et local % /*public interface IdentifierLLVM{ //globaux @ et local %

View File

@@ -69,6 +69,16 @@ TypeLLVMVisitor<String,String>
return INDENT+instr.var().accept(this, h) + " = " + instr.e().accept(this, h); return INDENT+instr.var().accept(this, h) + " = " + instr.e().accept(this, h);
} }
@Override
public String visitCallVoidLLVM(CallVoidLLVMImp instr, String h) {
String str = INDENT+ "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 += ", ";
}
return str + ")";
}
@Override @Override
public String visitBinOpLLVM(BinOpLLVMImp e, String h) { public String visitBinOpLLVM(BinOpLLVMImp e, String h) {
String str = ""; String str = "";
@@ -187,4 +197,5 @@ TypeLLVMVisitor<String,String>
return "i8*"; return "i8*";
} }
} }

View File

@@ -74,10 +74,10 @@ public class ProgramLLVM {
} }
} }
public static record CallLLVMImp(DefineLLVMImp f, ArrayList<ValLLVM> params, String str) implements InstructionLLVM{ //une expression ? public static record CallVoidLLVMImp(DefineLLVMImp f, ArrayList<ValLLVM> params, String str) implements InstructionLLVM{
@Override @Override
public <H, S> S accept(InstructionLLVMVisitor<H, S> v, H h) { public <H, S> S accept(InstructionLLVMVisitor<H, S> v, H h) {
return v.visitCallLLVM(this, h); return v.visitCallVoidLLVM(this, h);
} }
} }
@@ -148,6 +148,18 @@ public class ProgramLLVM {
} }
public static record CallLLVMImp(DefineLLVMImp f, ArrayList<ValLLVM> params, String str) implements ExpressionLLVM{
@Override
public <H, S> S accept(ExpressionLLVMVisitor<H, S> v, H h) {
return v.visitCallLLVM(this, h);
}
@Override
public TypeLLVM getType() {
return f.type();
}
}
//Val //Val
public static record ValLLVMImp(TypeLLVM type, int val) implements ValLLVM{ public static record ValLLVMImp(TypeLLVM type, int val) implements ValLLVM{