Documentation ¶
Index ¶
- type ArwenDriver
- func (driver *ArwenDriver) Close() error
- func (driver *ArwenDriver) DiagnoseWait(milliseconds uint32) error
- func (driver *ArwenDriver) GasScheduleChange(newGasSchedule map[string]map[string]uint64)
- func (driver *ArwenDriver) GetVersion() string
- func (driver *ArwenDriver) IsClosed() bool
- func (driver *ArwenDriver) IsInterfaceNil() bool
- func (driver *ArwenDriver) RestartArwenIfNecessary() error
- func (driver *ArwenDriver) RunSmartContractCall(input *vmcommon.ContractCallInput) (*vmcommon.VMOutput, error)
- func (driver *ArwenDriver) RunSmartContractCreate(input *vmcommon.ContractCreateInput) (*vmcommon.VMOutput, error)
- type Config
- type NodeMessenger
- func (messenger *NodeMessenger) ReceiveHookCallRequestOrContractResponse(timeout int) (common.MessageHandler, int, error)
- func (messenger *NodeMessenger) SendContractRequest(request common.MessageHandler) error
- func (messenger *NodeMessenger) SendHookCallResponse(response common.MessageHandler) error
- type NodePart
- type ParentLogsPart
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ArwenDriver ¶
type ArwenDriver struct {
// contains filtered or unexported fields
}
ArwenDriver manages the execution of the Arwen process
func NewArwenDriver ¶
func NewArwenDriver( blockchainHook vmcommon.BlockchainHook, arwenArguments common.ArwenArguments, config Config, ) (*ArwenDriver, error)
NewArwenDriver creates a new driver
func (*ArwenDriver) DiagnoseWait ¶
func (driver *ArwenDriver) DiagnoseWait(milliseconds uint32) error
DiagnoseWait sends a diagnose message to Arwen
func (*ArwenDriver) GasScheduleChange ¶
func (driver *ArwenDriver) GasScheduleChange(newGasSchedule map[string]map[string]uint64)
GasScheduleChange sends a "gas change" request to Arwen and waits for the output
func (*ArwenDriver) GetVersion ¶
func (driver *ArwenDriver) GetVersion() string
GetVersion gets the Arwen version
func (*ArwenDriver) IsClosed ¶
func (driver *ArwenDriver) IsClosed() bool
IsClosed checks whether the Arwen process is closed
func (*ArwenDriver) IsInterfaceNil ¶
func (driver *ArwenDriver) IsInterfaceNil() bool
IsInterfaceNil returns true if there is no value under the interface
func (*ArwenDriver) RestartArwenIfNecessary ¶
func (driver *ArwenDriver) RestartArwenIfNecessary() error
RestartArwenIfNecessary restarts Arwen if the process is closed
func (*ArwenDriver) RunSmartContractCall ¶
func (driver *ArwenDriver) RunSmartContractCall(input *vmcommon.ContractCallInput) (*vmcommon.VMOutput, error)
RunSmartContractCall sends an execution request to Arwen and waits for the output
func (*ArwenDriver) RunSmartContractCreate ¶
func (driver *ArwenDriver) RunSmartContractCreate(input *vmcommon.ContractCreateInput) (*vmcommon.VMOutput, error)
RunSmartContractCreate sends a deploy request to Arwen and waits for the output
type Config ¶
type Config struct {
MaxLoopTime int
}
Config is the configuration for the driver and for Node's part
type NodeMessenger ¶
NodeMessenger is the messenger on Node's part of the pipe
func NewNodeMessenger ¶
func NewNodeMessenger(reader *os.File, writer *os.File, marshalizer marshaling.Marshalizer) *NodeMessenger
NewNodeMessenger creates a new messenger
func (*NodeMessenger) ReceiveHookCallRequestOrContractResponse ¶
func (messenger *NodeMessenger) ReceiveHookCallRequestOrContractResponse(timeout int) (common.MessageHandler, int, error)
ReceiveHookCallRequestOrContractResponse waits for any message that could arrive from Arwen
func (*NodeMessenger) SendContractRequest ¶
func (messenger *NodeMessenger) SendContractRequest(request common.MessageHandler) error
SendContractRequest sends a request to Arwen
func (*NodeMessenger) SendHookCallResponse ¶
func (messenger *NodeMessenger) SendHookCallResponse(response common.MessageHandler) error
SendHookCallResponse sends a hook response to Arwen
type NodePart ¶
type NodePart struct { Messenger *NodeMessenger Repliers []common.MessageReplier // contains filtered or unexported fields }
NodePart is the endpoint that implements the message loop on Node's side
func NewNodePart ¶
func NewNodePart( input *os.File, output *os.File, blockchain vmcommon.BlockchainHook, config Config, marshalizer marshaling.Marshalizer, ) (*NodePart, error)
NewNodePart creates the Node part
func (*NodePart) SendStopSignal ¶
SendStopSignal sends a stop signal to Arwen Should only be used for tests!
func (*NodePart) StartLoop ¶
func (part *NodePart) StartLoop(request common.MessageHandler) (common.MessageHandler, error)
StartLoop runs the main loop