Documentation ¶
Overview ¶
Package sync provides interfaces for managing externally synchronized APIs.
The methods allow queries to be performed on an API to allow the determination of where blocking operations between threads of execution happen. These methods allow us to reason about execution in a non-linear way.
Index ¶
- func MutateWithSubcommands(ctx context.Context, c *path.Capture, cmds []api.Cmd, ...) error
- func MutationCmdsFor(ctx context.Context, c *path.Capture, data *Data, cmds []api.Cmd, id api.CmdID, ...) ([]api.Cmd, error)
- type Data
- type ExecutionRanges
- type SubcommandReference
- type SynchronizationIndices
- type SynchronizedAPI
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func MutateWithSubcommands ¶
func MutateWithSubcommands(ctx context.Context, c *path.Capture, cmds []api.Cmd, postCmdCb func(*api.GlobalState, api.SubCmdIdx, api.Cmd), preSubCmdCb func(*api.GlobalState, api.SubCmdIdx, api.Cmd), postSubCmdCb func(*api.GlobalState, api.SubCmdIdx, api.Cmd)) error
MutateWithSubcommands mutates a list of commands. And after mutating each Cmd, the given post-Cmd callback will be called. And the given pre-subcommand callback and the post-subcommand callback will be called before and after calling each subcommand callback function.
func MutationCmdsFor ¶
func MutationCmdsFor(ctx context.Context, c *path.Capture, data *Data, cmds []api.Cmd, id api.CmdID, subindex api.SubCmdIdx, initialCall bool) ([]api.Cmd, error)
MutationCmdsFor returns a list of command that represent the correct mutations to have the state for all commands before and including the given index.
Types ¶
type Data ¶
type Data struct { // CommandRanges contains commands that will be blocked from completion, // and what subcommands will be made available by future commands. CommandRanges map[api.CmdID]ExecutionRanges // SubcommandReferences contains the information about every subcommand // run by a particular command. SubcommandReferences map[api.CmdID][]SubcommandReference // SubcommandGroups represents the last Subcommand in every command buffer. SubcommandGroups map[api.CmdID][]api.SubCmdIdx // Hidden contains all the commands that should be hidden from the regular // command tree as they exist as a subcommand of another command. Hidden api.CmdIDSet // SubCommandMarkerGroups contains all the marker groups in the subcommands, // indexed by the immediate parent of the subcommands in the group. // e.g.: group: [73, 1, 4, 5~6] should be indexed by [73, 1, 4] SubCommandMarkerGroups *subCommandMarkerGroupTrie }
Data contains a map of synchronization pairs.
func (Data) SortedKeys ¶
func (s Data) SortedKeys() SynchronizationIndices
SortedKeys returns the keys of 's' in sorted order
type ExecutionRanges ¶
type ExecutionRanges struct { // LastIndex is the final subcommand that exists within this command. LastIndex api.SubCmdIdx // Ranges defines which future command will unblock the command in question, and // which subcommand is the last that will be run at that point. Ranges map[api.CmdID]api.SubCmdIdx }
ExecutionRanges contains the information about a blocked command.
func (ExecutionRanges) SortedKeys ¶
func (e ExecutionRanges) SortedKeys() SynchronizationIndices
SortedKeys returns the keys of 'e' in sorted order
type SubcommandReference ¶ added in v0.5.0
type SubcommandReference struct { Index api.SubCmdIdx GeneratingCmd api.CmdID // IsCalledGroup is true if the reference is to a nested call, otherwise // the reference belongs to a command-list. IsCallerGroup bool }
SubcommandReference contains a subcommand index as well as an api.CmdID that references the command that generated this subcommand.
type SynchronizationIndices ¶
SynchronizationIndices is a list of command identifiers, defining the location of a one side synchronization dependency.
func (SynchronizationIndices) Len ¶
func (s SynchronizationIndices) Len() int
Len returns the length of subcommand indices
func (SynchronizationIndices) Less ¶
func (s SynchronizationIndices) Less(i, j int) bool
Less returns true if s[i] < s[j]
func (SynchronizationIndices) Swap ¶
func (s SynchronizationIndices) Swap(i, j int)
Swap swaps the 2 subcommands in the given slice
type SynchronizedAPI ¶
type SynchronizedAPI interface { // GetTerminator returns a transform that will allow the given capture to be terminated // after a command. GetTerminator(ctx context.Context, c *path.Capture) (transform.Terminator, error) // ResolveSynchronization resolve all of the synchronization information for // the given API. ResolveSynchronization(ctx context.Context, d *Data, c *path.Capture) error // MutateSubcommands mutates the given Cmd and calls callbacks for subcommands // attached to that Cmd. preSubCmdCallback and postSubCmdCallback will be // called before and after executing each subcommand callback. MutateSubcommands(ctx context.Context, id api.CmdID, cmd api.Cmd, s *api.GlobalState, preSubCmdCallback func(*api.GlobalState, api.SubCmdIdx, api.Cmd), postSubCmdCallback func(*api.GlobalState, api.SubCmdIdx, api.Cmd)) error // FlattenSubcommandIdx returns the flatten command id for the subcommand // specified by the given SubCmdIdx. If flattening succeeded, the flatten // command id and true will be returned, otherwise, zero and false will be // returned. FlattenSubcommandIdx(idx api.SubCmdIdx, d *Data, initialCall bool) (api.CmdID, bool) }
SynchronizedAPI defines an API that explicitly has multiple threads of execution. This means that replays are not necessarily linear in terms of commands.