Thanks Alan for such informative and prompt reply ! I will work on what you suggested, it seems the right way.
On Sunday, December 11, 2016 at 11:53:11 PM UTC+5:30, Alan Donovan wrote: > > On 11 December 2016 at 12:21, <akshans...@gmail.com <javascript:>> wrote: > >> I am not sure how to get any starting node of type BasicBlock ( >> ssa#BasicBlock <https://godoc.org/golang.org/x/tools/go/ssa#BasicBlock>), so >> that I can traverse the Graph using Preds/Succs relation. >> > > An ssa.Program is a essentially collection of packages. Use one of its > methods (Package or ImportedPackage) to get the ssa.Package you want. > Then, use the (*Package).Func method to get the function you want. If you > want a method, you can use (*Program).LookupMethod, giving it the receiver > type and the method name. > > Once you have an *ssa.Function f, its control flow graph is rooted at > r.Blocks[0], which is the entry block. To enumerate blocks in arbitrary > order, range over the Blocks slice. For graph order, traverse depth-first > over the Succs slice; Preds is its inverse. To visit nodes in dominator > tree preorder, use the Dominees method. > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.