miner

package
v2.1.100+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 23, 2018 License: GPL-3.0 Imports: 18 Imported by: 8

Documentation

Overview

Package miner implements Ethereum block creation and mining.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Agent added in v0.8.5

type Agent interface {
	Work() chan<- *Work
	SetReturnCh(chan<- *Result)
	Stop()
	Start()
}

Agent can register themself with the worker

type Backend

type Backend interface {
	AccountManager() *accounts.Manager
	BlockChain() *core.BlockChain
	TxPool() *core.TxPool
	ChainDb() common.Database
}

Backend wraps all methods required for mining.

type CpuAgent added in v0.9.20

type CpuAgent struct {
	// contains filtered or unexported fields
}

func NewCpuAgent added in v0.9.20

func NewCpuAgent(chain consensus.ChainReader, engine consensus.Engine) *CpuAgent

func (*CpuAgent) SetReturnCh added in v0.9.20

func (self *CpuAgent) SetReturnCh(ch chan<- *Result)

func (*CpuAgent) Start added in v0.9.20

func (self *CpuAgent) Start()

func (*CpuAgent) Stop added in v0.9.20

func (self *CpuAgent) Stop()

func (*CpuAgent) Work added in v0.9.20

func (self *CpuAgent) Work() chan<- *Work

type Miner

type Miner struct {
	// contains filtered or unexported fields
}

Miner creates blocks and searches for proof-of-work values.

func New

func New(eth Backend, config *params.ChainConfig, mux *event.TypeMux, engine consensus.Engine) *Miner

func (*Miner) Mining

func (self *Miner) Mining() bool

func (*Miner) Pending

func (self *Miner) Pending(ctx context.Context) (*types.Block, *state.StateDB)

Pending returns the currently pending block and associated state.

func (*Miner) PendingBlock added in v0.9.20

func (self *Miner) PendingBlock(ctx context.Context) *types.Block

PendingBlock returns the currently pending block.

Note, to access both the pending block and the pending state simultaneously, please use Pending(), as the pending state can change between multiple method calls

func (*Miner) PendingQuery

func (self *Miner) PendingQuery(fn func(*state.StateDB) error) error

PendingQuery calls fn with the pending (ready-only) state.

func (*Miner) Register added in v0.9.20

func (self *Miner) Register(agent Agent)

func (*Miner) SetEtherbase added in v0.9.36

func (self *Miner) SetEtherbase(addr common.Address)

func (*Miner) SetExtra added in v0.9.20

func (self *Miner) SetExtra(extra []byte) error

func (*Miner) Start

func (self *Miner) Start(coinbase common.Address)

func (*Miner) Stop

func (self *Miner) Stop()

func (*Miner) Unregister

func (self *Miner) Unregister(agent Agent)

type RemoteAgent added in v0.9.20

type RemoteAgent struct {
	// contains filtered or unexported fields
}

func NewRemoteAgent added in v0.9.20

func NewRemoteAgent(chain consensus.ChainReader, engine consensus.Engine) *RemoteAgent

func (*RemoteAgent) SetReturnCh added in v0.9.20

func (a *RemoteAgent) SetReturnCh(returnCh chan<- *Result)

func (*RemoteAgent) Start added in v0.9.20

func (a *RemoteAgent) Start()

func (*RemoteAgent) Stop added in v0.9.20

func (a *RemoteAgent) Stop()

func (*RemoteAgent) Work added in v0.9.20

func (a *RemoteAgent) Work() chan<- *Work

type Result added in v0.9.39

type Result struct {
	Work  *Work
	Block *types.Block
}

type Work added in v0.8.5

type Work struct {
	Block *types.Block // the new block
	// contains filtered or unexported fields
}

Work is the workers current environment and holds all of the current state information

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL