func (v *VariableDecl) String() string { if v.Assignment == nil { return "(" + util.Blue("VariableDecl") + ": " + v.Variable.String() + ")" } else { return "(" + util.Blue("VariableDecl") + ": " + v.Variable.String() + " = " + v.Assignment.String() + ")" } }
func (v *Block) String() string { if len(v.Nodes) == 0 { return "(" + util.Blue("Block") + ": )" } result := "(" + util.Blue("Block") + ":\n" for _, n := range v.Nodes { result += "\t" + n.String() + "\n" } return result + ")" }
func (v *ImplDecl) String() string { var result string for _, decl := range v.Functions { result += "\t" + decl.String() + "\n" } return "(" + util.Blue("ImplDecl") + ": " + result + ")" }
func (v *EnumDecl) String() string { result := "\n" for _, val := range v.Body { result += "\t" + val.String() + "\n" } return "(" + util.Blue("EnumDecl") + ": " + result + ")" }
func (v *ArrayLiteral) String() string { res := "(" + util.Blue("ArrayLiteral") + ":" for _, mem := range v.Members { res += " " + mem.String() } return res + ")" }
func (v ArrayType) String() string { result := "(" + util.Blue("ArrayType") + ": " for _, attr := range v.attrs { result += attr.String() + " " } return result + v.TypeName() + ")" //+ util.Magenta(" <"+v.MangledName(MANGLE_ARK_UNSTABLE)+"> ") + ")" }
func (v *AccessExpr) String() string { result := "(" + util.Blue("AccessExpr") + ": " /*for _, struc := range v.StructVariables { result += struc.Name + "." } result += v.Variable.Name*/ return result + ")" }
func (v *ReturnStat) String() string { ret := "(" + util.Blue("ReturnStat") + ": " if v.Value == nil { ret += "void" } else { ret += v.Value.String() } return ret + ")" }
func (v *MatchStat) String() string { result := "(" + util.Blue("MatchStat") + ": " + v.Target.String() + ":\n" for pattern, stmt := range v.Branches { result += "\t" + pattern.String() + " -> " + stmt.String() + "\n" } return result + ")" }
func (v *SizeofExpr) String() string { ret := "(" + util.Blue("SizeofExpr") + ": " if v.Expr != nil { ret += v.Expr.String() } else { ret += v.Type.TypeName() } return ret + ")" }
func (v *BoolLiteral) String() string { res := "(" + util.Blue("BoolLiteral") + ": " if v.Value { res += util.Yellow("true") } else { res += util.Yellow("false") } return res + ")" }
func (v *CallExpr) String() string { result := "(" + util.Blue("CallExpr") + ": " + v.Function.Name for _, arg := range v.Arguments { result += " " + arg.String() } if v.GetType() != nil { result += " " + util.Green(v.GetType().TypeName()) } return result + ")" }
func (v *Variable) String() string { result := "(" + util.Blue("Variable") + ": " if v.Mutable { result += util.Green("[mutable] ") } for _, attr := range v.Attrs { result += attr.String() + " " } return result + v.Name + util.Magenta(" <"+v.MangledName(MANGLE_ARK_UNSTABLE)+"> ") + util.Green(v.Type.TypeName()) + ")" }
func (v *AssignStat) String() string { result := "(" + util.Blue("AssignStat") + ": " if v.Deref != nil { result += v.Deref.String() } else if v.Access != nil { result += v.Access.String() } return result + " = " + v.Assignment.String() + ")" }
func (v *TraitType) String() string { result := "(" + util.Blue("TraitType") + ": " for _, attr := range v.attrs { result += attr.String() + " " } result += v.Name + "\n" for _, decl := range v.Functions { result += "\t" + decl.String() + "\n" } return result + util.Magenta(" <"+v.MangledName(MANGLE_ARK_UNSTABLE)+"> ") + ")" }
func (v *IfStat) String() string { result := "(" + util.Blue("IfStat") + ": " for i, expr := range v.Exprs { result += expr.String() + " " result += v.Bodies[i].String() } if v.Else != nil { result += v.Else.String() } return result + ")" }
func (v *ModuleDecl) String() string { result := "(" + util.Blue(v.Module.Name) + " (in " + util.Green(v.Module.Path) + "): \n" // todo interfaces for this shit for _, function := range v.Module.Functions { result += "\t" + function.String() + "\n" } for _, variable := range v.Module.Variables { result += "\t" + variable.String() + "\n" } result += ")" return result }
func (v *LoopStat) String() string { result := "(" + util.Blue("LoopStat") + ": " switch v.LoopType { case LOOP_TYPE_INFINITE: case LOOP_TYPE_CONDITIONAL: result += v.Condition.String() + " " default: panic("invalid loop type") } result += v.Body.String() return result + ")" }
func (v *Function) String() string { result := "(" + util.Blue("Function") + ": " if v.Mutable { result += util.Green("[mutable] ") } for _, attr := range v.Attrs { result += attr.String() + " " } result += v.Name for _, par := range v.Parameters { result += " " + par.String() } if v.ReturnType != nil { result += ": " + util.Green(v.ReturnType.TypeName()) + " " } if v.Body != nil { result += v.Body.String() } return result + util.Magenta(" <"+v.MangledName(MANGLE_ARK_UNSTABLE)+">") + ")" }
func (v *CastExpr) String() string { return "(" + util.Blue("CastExpr") + ": " + v.Expr.String() + " " + util.Green(v.GetType().TypeName()) + ")" }
func (v *UnaryExpr) String() string { return "(" + util.Blue("UnaryExpr") + ": " + v.Op.String() + " " + v.Expr.String() + ")" }
func (v *BinaryExpr) String() string { return "(" + util.Blue("BinaryExpr") + ": " + v.Lhand.String() + " " + v.Op.String() + " " + v.Rhand.String() + ")" }
func (v *StringLiteral) String() string { return "(" + util.Blue("StringLiteral") + ": " + colorizeEscapedString((EscapeString(v.Value))) + " " + util.Green(v.GetType().TypeName()) + ")" }
func (v *DerefExpr) String() string { return "(" + util.Blue("DerefExpr") + ": " + v.Expr.String() + ")" }
func (v *AddressOfExpr) String() string { return "(" + util.Blue("AddressOfExpr") + ": " + v.Access.String() + " " + util.Green(v.GetType().TypeName()) + ")" }
func (v *RuneLiteral) String() string { return fmt.Sprintf("(" + util.Blue("RuneLiteral") + ": " + colorizeEscapedString(EscapeString(string(v.Value))) + " " + util.Green(v.GetType().TypeName()) + ")") }
func (v *BracketExpr) String() string { return "(" + util.Blue("BracketExpr") + ": " + v.Expr.String() + ")" }
func (v *IntegerLiteral) String() string { return fmt.Sprintf("("+util.Blue("IntegerLiteral")+": "+util.Yellow("%d")+" "+util.Green(v.GetType().TypeName())+")", v.Value) }
func (v *DefaultMatchBranch) String() string { return "(" + util.Blue("DefaultMatchBranch") + ")" }
func (v *FloatingLiteral) String() string { return fmt.Sprintf("("+util.Blue("FloatingLiteral")+": "+util.Yellow("%f")+" "+util.Green(v.GetType().TypeName())+")", v.Value) }