ssa: debug info of function/closure
This commit is contained in:
@@ -735,7 +735,7 @@ func (p *context) compileInstr(b llssa.Builder, instr ssa.Instruction) {
|
||||
return
|
||||
}
|
||||
|
||||
pos := p.goProg.Fset.Position(getPos(v))
|
||||
pos := p.goProg.Fset.Position(v.Pos())
|
||||
value := p.compileValue(b, v.X)
|
||||
fn := v.Parent()
|
||||
dbgVar := p.getLocalVariable(b, fn, variable)
|
||||
@@ -754,40 +754,6 @@ type poser interface {
|
||||
Pos() token.Pos
|
||||
}
|
||||
|
||||
func getPos(v poser) token.Pos {
|
||||
pos := v.Pos()
|
||||
if pos.IsValid() {
|
||||
return pos
|
||||
}
|
||||
panic(fmt.Errorf("getPos: invalid position - %T", v))
|
||||
|
||||
// switch v := v.(type) {
|
||||
// case *ssa.MakeInterface:
|
||||
// return getPos(v.X)
|
||||
// case *ssa.MakeClosure:
|
||||
// return v.Fn.(*ssa.Function).Pos()
|
||||
// case *ssa.Return:
|
||||
// syntax := v.Parent().Syntax()
|
||||
// if syntax != nil {
|
||||
// return syntax.End()
|
||||
// }
|
||||
// return token.NoPos
|
||||
// case *ssa.FieldAddr:
|
||||
// return getPos(v.X)
|
||||
// case *ssa.IndexAddr:
|
||||
// return getPos(v.X)
|
||||
// case *ssa.Slice:
|
||||
// return getPos(v.X)
|
||||
// case *ssa.Store:
|
||||
// return getPos(v.Addr)
|
||||
// case *ssa.Extract:
|
||||
// return getPos(v.Tuple)
|
||||
// default:
|
||||
// fmt.Printf("getPos: unknown instr - %T\n", v)
|
||||
// return token.NoPos
|
||||
// }
|
||||
}
|
||||
|
||||
func (p *context) getLocalVariable(b llssa.Builder, fn *ssa.Function, v *types.Var) llssa.DIVar {
|
||||
pos := p.fset.Position(v.Pos())
|
||||
t := b.Prog.Type(v.Type(), llssa.InGo)
|
||||
|
||||
Reference in New Issue
Block a user