diff options
| author | obscuren <geffobscura@gmail.com> | 2014-11-04 17:57:02 +0800 | 
|---|---|---|
| committer | obscuren <geffobscura@gmail.com> | 2014-11-04 17:57:02 +0800 | 
| commit | f59a3b67f69b26f969084e0de165435e80bd8e12 (patch) | |
| tree | f92098fa0252484fcdccdaf6075c2842713a2fc9 /chain | |
| parent | 1025d097fd4e5171dadb2c1a8eeb43b7730b13b6 (diff) | |
| download | go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.tar go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.tar.gz go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.tar.bz2 go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.tar.lz go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.tar.xz go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.tar.zst go-tangerine-f59a3b67f69b26f969084e0de165435e80bd8e12.zip | |
StateManager => BlockManager
Diffstat (limited to 'chain')
| -rw-r--r-- | chain/block_manager.go (renamed from chain/state_manager.go) | 52 | ||||
| -rw-r--r-- | chain/bloom9_test.go | 6 | ||||
| -rw-r--r-- | chain/filter.go | 2 | ||||
| -rw-r--r-- | chain/transaction_pool.go | 4 | 
4 files changed, 24 insertions, 40 deletions
| diff --git a/chain/state_manager.go b/chain/block_manager.go index 31b77c574..998b1705d 100644 --- a/chain/state_manager.go +++ b/chain/block_manager.go @@ -32,7 +32,7 @@ type Peer interface {  }  type EthManager interface { -	StateManager() *StateManager +	BlockManager() *BlockManager  	ChainManager() *ChainManager  	TxPool() *TxPool  	Broadcast(msgType wire.MsgType, data []interface{}) @@ -46,7 +46,7 @@ type EthManager interface {  	EventMux() *event.TypeMux  } -type StateManager struct { +type BlockManager struct {  	// Mutex for locking the block processor. Blocks can only be handled one at a time  	mutex sync.Mutex  	// Canonical block chain @@ -74,8 +74,8 @@ type StateManager struct {  	events event.Subscription  } -func NewStateManager(ethereum EthManager) *StateManager { -	sm := &StateManager{ +func NewBlockManager(ethereum EthManager) *BlockManager { +	sm := &BlockManager{  		mem: make(map[string]*big.Int),  		Pow: &EasyPow{},  		eth: ethereum, @@ -87,18 +87,18 @@ func NewStateManager(ethereum EthManager) *StateManager {  	return sm  } -func (self *StateManager) Start() { +func (self *BlockManager) Start() {  	statelogger.Debugln("Starting state manager")  	self.events = self.eth.EventMux().Subscribe(Blocks(nil))  	go self.updateThread()  } -func (self *StateManager) Stop() { +func (self *BlockManager) Stop() {  	statelogger.Debugln("Stopping state manager")  	self.events.Unsubscribe()  } -func (self *StateManager) updateThread() { +func (self *BlockManager) updateThread() {  	for ev := range self.events.Chan() {  		for _, block := range ev.(Blocks) {  			err := self.Process(block) @@ -112,29 +112,29 @@ func (self *StateManager) updateThread() {  	}  } -func (sm *StateManager) CurrentState() *state.State { +func (sm *BlockManager) CurrentState() *state.State {  	return sm.eth.ChainManager().CurrentBlock.State()  } -func (sm *StateManager) TransState() *state.State { +func (sm *BlockManager) TransState() *state.State {  	return sm.transState  } -func (sm *StateManager) MiningState() *state.State { +func (sm *BlockManager) MiningState() *state.State {  	return sm.miningState  } -func (sm *StateManager) NewMiningState() *state.State { +func (sm *BlockManager) NewMiningState() *state.State {  	sm.miningState = sm.eth.ChainManager().CurrentBlock.State().Copy()  	return sm.miningState  } -func (sm *StateManager) ChainManager() *ChainManager { +func (sm *BlockManager) ChainManager() *ChainManager {  	return sm.bc  } -func (self *StateManager) ProcessTransactions(coinbase *state.StateObject, state *state.State, block, parent *Block, txs Transactions) (Receipts, Transactions, Transactions, Transactions, error) { +func (self *BlockManager) ProcessTransactions(coinbase *state.StateObject, state *state.State, block, parent *Block, txs Transactions) (Receipts, Transactions, Transactions, Transactions, error) {  	var (  		receipts           Receipts  		handled, unhandled Transactions @@ -209,7 +209,7 @@ done:  	return receipts, handled, unhandled, erroneous, err  } -func (sm *StateManager) Process(block *Block) (err error) { +func (sm *BlockManager) Process(block *Block) (err error) {  	// Processing a blocks may never happen simultaneously  	sm.mutex.Lock()  	defer sm.mutex.Unlock() @@ -298,7 +298,7 @@ func (sm *StateManager) Process(block *Block) (err error) {  	return nil  } -func (sm *StateManager) ApplyDiff(state *state.State, parent, block *Block) (receipts Receipts, err error) { +func (sm *BlockManager) ApplyDiff(state *state.State, parent, block *Block) (receipts Receipts, err error) {  	coinbase := state.GetOrNewStateObject(block.Coinbase)  	coinbase.SetGasPool(block.CalcGasLimit(parent)) @@ -311,7 +311,7 @@ func (sm *StateManager) ApplyDiff(state *state.State, parent, block *Block) (rec  	return receipts, nil  } -func (sm *StateManager) CalculateTD(block *Block) bool { +func (sm *BlockManager) CalculateTD(block *Block) bool {  	uncleDiff := new(big.Int)  	for _, uncle := range block.Uncles {  		uncleDiff = uncleDiff.Add(uncleDiff, uncle.Difficulty) @@ -337,7 +337,7 @@ func (sm *StateManager) CalculateTD(block *Block) bool {  // Validates the current block. Returns an error if the block was invalid,  // an uncle or anything that isn't on the current block chain.  // Validation validates easy over difficult (dagger takes longer time = difficult) -func (sm *StateManager) ValidateBlock(block *Block) error { +func (sm *BlockManager) ValidateBlock(block *Block) error {  	// Check each uncle's previous hash. In order for it to be valid  	// is if it has the same block hash as the current  	parent := sm.bc.GetBlock(block.PrevHash) @@ -374,7 +374,7 @@ func (sm *StateManager) ValidateBlock(block *Block) error {  	return nil  } -func (sm *StateManager) AccumelateRewards(state *state.State, block, parent *Block) error { +func (sm *BlockManager) AccumelateRewards(state *state.State, block, parent *Block) error {  	reward := new(big.Int).Set(BlockReward)  	knownUncles := ethutil.Set(parent.Uncles) @@ -417,21 +417,7 @@ func (sm *StateManager) AccumelateRewards(state *state.State, block, parent *Blo  	return nil  } -// Manifest will handle both creating notifications and generating bloom bin data -func (sm *StateManager) createBloomFilter(state *state.State) *BloomFilter { -	bloomf := NewBloomFilter(nil) - -	for _, msg := range state.Manifest().Messages { -		bloomf.Set(msg.To) -		bloomf.Set(msg.From) -	} - -	sm.eth.EventMux().Post(state.Manifest().Messages) - -	return bloomf -} - -func (sm *StateManager) GetMessages(block *Block) (messages []*state.Message, err error) { +func (sm *BlockManager) GetMessages(block *Block) (messages []*state.Message, err error) {  	if !sm.bc.HasBlock(block.PrevHash) {  		return nil, ParentError(block.PrevHash)  	} diff --git a/chain/bloom9_test.go b/chain/bloom9_test.go index 8d8822030..8b1b962cb 100644 --- a/chain/bloom9_test.go +++ b/chain/bloom9_test.go @@ -1,12 +1,8 @@  package chain  import ( -	"fmt"  	"testing" - -	"github.com/ethereum/go-ethereum/crypto"  	"github.com/ethereum/go-ethereum/state" -	"github.com/ethgo.old/ethutil"  )  func TestBloom9(t *testing.T) { @@ -21,6 +17,7 @@ func TestBloom9(t *testing.T) {  	}  } +/*  func TestAddress(t *testing.T) {  	block := &Block{}  	block.Coinbase = ethutil.Hex2Bytes("22341ae42d6dd7384bc8584e50419ea3ac75b83f") @@ -29,3 +26,4 @@ func TestAddress(t *testing.T) {  	bin := CreateBloom(block)  	fmt.Printf("bin = %x\n", ethutil.LeftPadBytes(bin, 64))  } +*/ diff --git a/chain/filter.go b/chain/filter.go index 0265a60fa..3494e4dcc 100644 --- a/chain/filter.go +++ b/chain/filter.go @@ -100,7 +100,7 @@ func (self *Filter) Find() []*state.Message {  		// current parameters  		if self.bloomFilter(block) {  			// Get the messages of the block -			msgs, err := self.eth.StateManager().GetMessages(block) +			msgs, err := self.eth.BlockManager().GetMessages(block)  			if err != nil {  				chainlogger.Warnln("err: filter get messages ", err) diff --git a/chain/transaction_pool.go b/chain/transaction_pool.go index a7c85e802..ff75089d6 100644 --- a/chain/transaction_pool.go +++ b/chain/transaction_pool.go @@ -114,8 +114,8 @@ func (pool *TxPool) ValidateTransaction(tx *Transaction) error {  	}  	// Get the sender -	//sender := pool.Ethereum.StateManager().procState.GetAccount(tx.Sender()) -	sender := pool.Ethereum.StateManager().CurrentState().GetAccount(tx.Sender()) +	//sender := pool.Ethereum.BlockManager().procState.GetAccount(tx.Sender()) +	sender := pool.Ethereum.BlockManager().CurrentState().GetAccount(tx.Sender())  	totAmount := new(big.Int).Set(tx.Value)  	// Make sure there's enough in the sender's account. Having insufficient | 
