Documentation ¶
Overview ¶
Package explore provides a high-performance table-based implementation of the ExploreService defined in kythe/proto/explore.proto.
Table format:
<parent ticket> -> epb.Relatives <ticket> -> epb.Relatives
Index ¶
- type Tables
- func (t *Tables) Callees(ctx context.Context, req *epb.CalleesRequest) (*epb.CalleesReply, error)
- func (t *Tables) Callers(ctx context.Context, req *epb.CallersRequest) (*epb.CallersReply, error)
- func (t *Tables) Children(ctx context.Context, req *epb.ChildrenRequest) (*epb.ChildrenReply, error)
- func (t *Tables) Parameters(ctx context.Context, req *epb.ParametersRequest) (*epb.ParametersReply, error)
- func (t *Tables) Parents(ctx context.Context, req *epb.ParentsRequest) (*epb.ParentsReply, error)
- func (t *Tables) TypeHierarchy(ctx context.Context, req *epb.TypeHierarchyRequest) (*epb.TypeHierarchyReply, error)
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Tables ¶
type Tables struct { // ParentToChildren is a table of srvpb.Relatives keyed by parent ticket. ParentToChildren table.Proto // ChildToParents is a table of srvpb.Relatives keyed by child ticket. ChildToParents table.Proto }
Tables implements the explore.Service interface using separate static lookup tables for each API component.
func (*Tables) Callees ¶
func (t *Tables) Callees(ctx context.Context, req *epb.CalleesRequest) (*epb.CalleesReply, error)
Callees returns the (recursive) callees of a specified function (that is, what functions this function calls), as a directed graph. TODO: not yet implemented
func (*Tables) Callers ¶
func (t *Tables) Callers(ctx context.Context, req *epb.CallersRequest) (*epb.CallersReply, error)
Callers returns the (recursive) callers of a specified function, as a directed graph. TODO: not yet implemented
func (*Tables) Children ¶
func (t *Tables) Children(ctx context.Context, req *epb.ChildrenRequest) (*epb.ChildrenReply, error)
Children returns the children of a specified node (for example, the classes contained in a file, or the functions contained in a class). TODO: populate NodeData appropriately
func (*Tables) Parameters ¶
func (t *Tables) Parameters(ctx context.Context, req *epb.ParametersRequest) (*epb.ParametersReply, error)
Parameters returns the parameters of a specified function. TODO: not yet implemented
func (*Tables) Parents ¶
func (t *Tables) Parents(ctx context.Context, req *epb.ParentsRequest) (*epb.ParentsReply, error)
Parents returns the parents of a specified node (for example, the file for a class, or the class for a function). Note: in some cases a node may have more than one parent. TODO: populate NodeData appropriately
func (*Tables) TypeHierarchy ¶
func (t *Tables) TypeHierarchy(ctx context.Context, req *epb.TypeHierarchyRequest) (*epb.TypeHierarchyReply, error)
TypeHierarchy returns the hierarchy (supertypes and subtypes, including implementations) of a specified type, as a directed acyclic graph. TODO: not yet implemented