33 lines
845 B
Go
33 lines
845 B
Go
|
package functions
|
||
|
|
||
|
import (
|
||
|
"honnef.co/go/tools/ir"
|
||
|
)
|
||
|
|
||
|
// IsStub reports whether a function is a stub. A function is
|
||
|
// considered a stub if it has no instructions or if all it does is
|
||
|
// return a constant value.
|
||
|
func IsStub(fn *ir.Function) bool {
|
||
|
for _, b := range fn.Blocks {
|
||
|
for _, instr := range b.Instrs {
|
||
|
switch instr.(type) {
|
||
|
case *ir.Const:
|
||
|
// const naturally has no side-effects
|
||
|
case *ir.Panic:
|
||
|
// panic is a stub if it only uses constants
|
||
|
case *ir.Return:
|
||
|
// return is a stub if it only uses constants
|
||
|
case *ir.DebugRef:
|
||
|
case *ir.Jump:
|
||
|
// if there are no disallowed instructions, then we're
|
||
|
// only jumping to the exit block (or possibly
|
||
|
// somewhere else that's stubby?)
|
||
|
default:
|
||
|
// all other instructions are assumed to do actual work
|
||
|
return false
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
return true
|
||
|
}
|