print et read presque fini !

This commit is contained in:
trochas
2025-04-28 18:14:31 +02:00
parent 79920ed4d4
commit 291bc96079
5 changed files with 17 additions and 15 deletions

View File

@@ -12,7 +12,7 @@ public class SymTable {
private PStack<PMap<String,ValueVarMap>> varMap;
private PMap<String,ValueFunMap> functionsMap;
private int[] id ; //id partagé entre toute les symTable, [0] : idVar, [1] : id Label, [2] : global
private int[] id ; //id partagé entre toute les symTable, [0] : idVar, [1] : idLabel, [2] : idGlobalVar
private ArrayList<DeclarGlobalLLVMImp> declarationsGlobal;
public SymTable(){
@@ -20,8 +20,9 @@ public class SymTable {
this.varMap= ConsPStack.singleton(HashTreePMap.empty());
this.functionsMap = HashTreePMap.empty();
this.declarationsGlobal = new ArrayList<>();
this.id[0] = 1;
this.id[1] = 1;
this.id[0] = 1; //idVar
this.id[1] = 1; //idLaber
this.id[2] = 1; //idGlobalVar
}
public SymTable(PStack<PMap<String,ValueVarMap>> varMap, PMap<String,ValueFunMap> functionsMap, int[] id,ArrayList<DeclarGlobalLLVMImp> declarationsGlobal){
this.varMap= varMap;

View File

@@ -160,8 +160,8 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
ArrayList<ValLLVM> params = new ArrayList<>();
String name = h.getGlobalDeclName();
DeclarGlobalLLVMImp globalDecl = new DeclarGlobalLLVMImp(name);
VarLLVMImp varGlobal = new VarLLVMImp(new StringLLVMImp(),name,true);
VarLLVMImp varGlobal = new VarLLVMImp(new CharLLVMImp(true),name,true);
DeclarGlobalLLVMImp globalDecl = new DeclarGlobalLLVMImp(varGlobal,new CharLLVMImp(false),0); //TODO
h.addGlobalDecl(globalDecl);
params.add(varGlobal);
@@ -180,8 +180,8 @@ public class toLLVM_Visitor implements ProgramVisitor<SymTable,ProgramLLVMImp>,
ArrayList<ValLLVM> params = new ArrayList<>();
String name = h.getGlobalDeclName();
DeclarGlobalLLVMImp globalDecl = new DeclarGlobalLLVMImp(name);
VarLLVMImp varGlobal = new VarLLVMImp(new StringLLVMImp(),name,true);
VarLLVMImp varGlobal = new VarLLVMImp(new CharLLVMImp(true),name,true);
DeclarGlobalLLVMImp globalDecl = new DeclarGlobalLLVMImp(varGlobal,new CharLLVMImp(false),0);//TODO
h.addGlobalDecl(globalDecl);
params.add(varGlobal);

View File

@@ -72,7 +72,7 @@ public interface Interface {
public S visitIntLLVM(IntLLVMImp e,H h);
public S visitVoidLLVM(VoidLLVMImp e, H h);
public S visitBooleanLLVM(BooleanLLVMImp e, H h);
public S visitStringLLVM(StringLLVMImp e, H h);
public S visitCharLLVM(CharLLVMImp e, H h);
}
}

View File

@@ -152,8 +152,8 @@ TypeLLVMVisitor<String,String>
@Override
public String visitDeclarGlobalLLVM(DeclarGlobalLLVMImp instr, String h) {
String str = "@."+instr.name() + " = global";
str += "[" + "x"+ "]";
String str = "@."+instr.var().nom() + " = global";
str += " [" + instr.type().accept(this, h)+ "x"+ instr.size()+ "] ";
str+= "c\"\"\n";
return str;
@@ -205,8 +205,9 @@ TypeLLVMVisitor<String,String>
}
@Override
public String visitStringLLVM(StringLLVMImp e, String h) {
return "i8*";
public String visitCharLLVM(CharLLVMImp e, String h) {
if(e.isString()) return "i8*";
else return "i8";
}

View File

@@ -96,7 +96,7 @@ public class ProgramLLVM {
}
}
public static record DeclarGlobalLLVMImp(String name) implements InstructionLLVM{
public static record DeclarGlobalLLVMImp(VarLLVMImp var,TypeLLVM type, int size) implements InstructionLLVM{
@Override
public <H, S> S accept(InstructionLLVMVisitor<H, S> v, H h) {
@@ -218,10 +218,10 @@ public class ProgramLLVM {
}
}
public static record StringLLVMImp() implements TypeLLVM{
public static record CharLLVMImp(Boolean isString) implements TypeLLVM{
@Override
public <H, S> S accept(TypeLLVMVisitor<H, S> v, H h) {
return v.visitStringLLVM(this, h);
return v.visitCharLLVM(this, h);
}
}
}