Merge branch 'develop' of github.com:ethereum/eth-go into feature/ethutil-refactor
This commit is contained in:
		| @@ -7,7 +7,7 @@ import ( | |||||||
| 	"github.com/ethereum/eth-go/ethtrie" | 	"github.com/ethereum/eth-go/ethtrie" | ||||||
| 	"github.com/ethereum/eth-go/ethutil" | 	"github.com/ethereum/eth-go/ethutil" | ||||||
| 	"math/big" | 	"math/big" | ||||||
| 	"strconv" | 	_ "strconv" | ||||||
| 	"time" | 	"time" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -252,6 +252,7 @@ func (self *Block) SetReceipts(receipts []*Receipt, txs []*Transaction) { | |||||||
| func (block *Block) setTransactions(txs []*Transaction) { | func (block *Block) setTransactions(txs []*Transaction) { | ||||||
| 	block.transactions = txs | 	block.transactions = txs | ||||||
|  |  | ||||||
|  | 	/* | ||||||
| 		trie := ethtrie.NewTrie(ethutil.Config.Db, "") | 		trie := ethtrie.NewTrie(ethutil.Config.Db, "") | ||||||
| 		for i, tx := range txs { | 		for i, tx := range txs { | ||||||
| 			trie.Update(strconv.Itoa(i), string(tx.RlpEncode())) | 			trie.Update(strconv.Itoa(i), string(tx.RlpEncode())) | ||||||
| @@ -265,7 +266,29 @@ func (block *Block) setTransactions(txs []*Transaction) { | |||||||
| 		default: | 		default: | ||||||
| 			panic(fmt.Sprintf("invalid root type %T", trie.Root)) | 			panic(fmt.Sprintf("invalid root type %T", trie.Root)) | ||||||
| 		} | 		} | ||||||
|  | 	*/ | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func CreateTxSha(receipts Receipts) (sha []byte) { | ||||||
|  | 	trie := ethtrie.NewTrie(ethutil.Config.Db, "") | ||||||
|  | 	for i, receipt := range receipts { | ||||||
|  | 		trie.Update(string(ethutil.NewValue(i).Encode()), string(ethutil.NewValue(receipt.RlpData()).Encode())) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	switch trie.Root.(type) { | ||||||
|  | 	case string: | ||||||
|  | 		sha = []byte(trie.Root.(string)) | ||||||
|  | 	case []byte: | ||||||
|  | 		sha = trie.Root.([]byte) | ||||||
|  | 	default: | ||||||
|  | 		panic(fmt.Sprintf("invalid root type %T", trie.Root)) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return sha | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (self *Block) SetTxHash(receipts Receipts) { | ||||||
|  | 	self.TxSha = CreateTxSha(receipts) | ||||||
| } | } | ||||||
|  |  | ||||||
| func (block *Block) Value() *ethutil.Value { | func (block *Block) Value() *ethutil.Value { | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package ethchain | package ethchain | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	"fmt" |  | ||||||
| 	"github.com/ethereum/eth-go/ethcrypto" | 	"github.com/ethereum/eth-go/ethcrypto" | ||||||
| 	"github.com/ethereum/eth-go/ethtrie" | 	"github.com/ethereum/eth-go/ethtrie" | ||||||
| 	"github.com/ethereum/eth-go/ethutil" | 	"github.com/ethereum/eth-go/ethutil" | ||||||
| @@ -27,12 +26,6 @@ func NewState(trie *ethtrie.Trie) *State { | |||||||
| 	return &State{trie: trie, stateObjects: make(map[string]*StateObject), manifest: NewManifest()} | 	return &State{trie: trie, stateObjects: make(map[string]*StateObject), manifest: NewManifest()} | ||||||
| } | } | ||||||
|  |  | ||||||
| // Iterate over each storage address and yield callback |  | ||||||
| func (s *State) EachStorage(cb ethtrie.EachCallback) { |  | ||||||
| 	it := s.trie.NewIterator() |  | ||||||
| 	it.Each(cb) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Retrieve the balance from the given address or 0 if object not found | // Retrieve the balance from the given address or 0 if object not found | ||||||
| func (self *State) GetBalance(addr []byte) *big.Int { | func (self *State) GetBalance(addr []byte) *big.Int { | ||||||
| 	stateObject := self.GetStateObject(addr) | 	stateObject := self.GetStateObject(addr) | ||||||
| @@ -214,11 +207,8 @@ func (self *State) Update() { | |||||||
|  |  | ||||||
| // Debug stuff | // Debug stuff | ||||||
| func (self *State) CreateOutputForDiff() { | func (self *State) CreateOutputForDiff() { | ||||||
| 	for addr, stateObject := range self.stateObjects { | 	for _, stateObject := range self.stateObjects { | ||||||
| 		fmt.Printf("%x %x %x %x\n", addr, stateObject.state.Root(), stateObject.Amount.Bytes(), stateObject.Nonce) | 		stateObject.CreateOutputForDiff() | ||||||
| 		stateObject.state.EachStorage(func(addr string, value *ethutil.Value) { |  | ||||||
| 			fmt.Printf("%x %x\n", addr, value.Bytes()) |  | ||||||
| 		}) |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -201,11 +201,16 @@ func (sm *StateManager) Process(block *Block, dontReact bool) (err error) { | |||||||
| 		fmt.Printf("## %x %x ##\n", block.Hash(), block.Number) | 		fmt.Printf("## %x %x ##\n", block.Hash(), block.Number) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	_, err = sm.ApplyDiff(state, parent, block) | 	receipts, err := sm.ApplyDiff(state, parent, block) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	txSha := CreateTxSha(receipts) | ||||||
|  | 	if bytes.Compare(txSha, block.TxSha) != 0 { | ||||||
|  | 		return fmt.Errorf("Error validating tx sha. Received %x, got %x", block.TxSha, txSha) | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	// Block validation | 	// Block validation | ||||||
| 	if err = sm.ValidateBlock(block); err != nil { | 	if err = sm.ValidateBlock(block); err != nil { | ||||||
| 		statelogger.Errorln("Error validating block:", err) | 		statelogger.Errorln("Error validating block:", err) | ||||||
| @@ -219,17 +224,7 @@ func (sm *StateManager) Process(block *Block, dontReact bool) (err error) { | |||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* |  | ||||||
| 		if ethutil.Config.Paranoia { |  | ||||||
| 			valid, _ := ethtrie.ParanoiaCheck(state.trie) |  | ||||||
| 			if !valid { |  | ||||||
| 				err = fmt.Errorf("PARANOIA: World state trie corruption") |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	*/ |  | ||||||
|  |  | ||||||
| 	if !block.State().Cmp(state) { | 	if !block.State().Cmp(state) { | ||||||
|  |  | ||||||
| 		err = fmt.Errorf("Invalid merkle root.\nrec: %x\nis:  %x", block.State().trie.Root, state.trie.Root) | 		err = fmt.Errorf("Invalid merkle root.\nrec: %x\nis:  %x", block.State().trie.Root, state.trie.Root) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| @@ -312,9 +307,9 @@ func (sm *StateManager) ValidateBlock(block *Block) error { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	diff := block.Time - sm.bc.CurrentBlock.Time | 	diff := block.Time - previousBlock.Time | ||||||
| 	if diff < 0 { | 	if diff < 0 { | ||||||
| 		return ValidationError("Block timestamp less then prev block %v", diff) | 		return ValidationError("Block timestamp less then prev block %v (%v - %v)", diff, block.Time, sm.bc.CurrentBlock.Time) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* XXX | 	/* XXX | ||||||
|   | |||||||
| @@ -151,6 +151,24 @@ func (self *StateObject) setStorage(k []byte, value *ethutil.Value) { | |||||||
| 	*/ | 	*/ | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Iterate over each storage address and yield callback | ||||||
|  | func (self *StateObject) EachStorage(cb ethtrie.EachCallback) { | ||||||
|  | 	// First loop over the uncommit/cached values in storage | ||||||
|  | 	for key, value := range self.storage { | ||||||
|  | 		// XXX Most iterators Fns as it stands require encoded values | ||||||
|  | 		encoded := ethutil.NewValue(value.Encode()) | ||||||
|  | 		cb(key, encoded) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	it := self.state.trie.NewIterator() | ||||||
|  | 	it.Each(func(key string, value *ethutil.Value) { | ||||||
|  | 		// If it's cached don't call the callback. | ||||||
|  | 		if self.storage[key] == nil { | ||||||
|  | 			cb(key, value) | ||||||
|  | 		} | ||||||
|  | 	}) | ||||||
|  | } | ||||||
|  |  | ||||||
| func (self *StateObject) Sync() { | func (self *StateObject) Sync() { | ||||||
| 	/* | 	/* | ||||||
| 		fmt.Println("############# BEFORE ################") | 		fmt.Println("############# BEFORE ################") | ||||||
| @@ -303,6 +321,14 @@ func (c *StateObject) Init() Code { | |||||||
| 	return c.initScript | 	return c.initScript | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // Debug stuff | ||||||
|  | func (self *StateObject) CreateOutputForDiff() { | ||||||
|  | 	fmt.Printf("%x %x %x %x\n", self.Address(), self.state.Root(), self.Amount.Bytes(), self.Nonce) | ||||||
|  | 	self.EachStorage(func(addr string, value *ethutil.Value) { | ||||||
|  | 		fmt.Printf("%x %x\n", addr, value.Bytes()) | ||||||
|  | 	}) | ||||||
|  | } | ||||||
|  |  | ||||||
| // | // | ||||||
| // Encoding | // Encoding | ||||||
| // | // | ||||||
|   | |||||||
| @@ -158,7 +158,7 @@ func (vm *Vm) RunClosure(closure *Closure) (ret []byte, err error) { | |||||||
| 			switch op { | 			switch op { | ||||||
| 			case STOP, RETURN, SUICIDE: | 			case STOP, RETURN, SUICIDE: | ||||||
| 				closure.object.Sync() | 				closure.object.Sync() | ||||||
| 				closure.object.state.EachStorage(func(key string, value *ethutil.Value) { | 				closure.object.EachStorage(func(key string, value *ethutil.Value) { | ||||||
| 					value.Decode() | 					value.Decode() | ||||||
| 					fmt.Printf("%x %x\n", new(big.Int).SetBytes([]byte(key)).Bytes(), value.Bytes()) | 					fmt.Printf("%x %x\n", new(big.Int).SetBytes([]byte(key)).Bytes(), value.Bytes()) | ||||||
| 				}) | 				}) | ||||||
|   | |||||||
| @@ -172,6 +172,7 @@ func (self *Miner) mineNewBlock() { | |||||||
| 		logger.Debugln(err) | 		logger.Debugln(err) | ||||||
| 	} | 	} | ||||||
| 	self.txs = append(txs, unhandledTxs...) | 	self.txs = append(txs, unhandledTxs...) | ||||||
|  | 	self.block.SetTxHash(receipts) | ||||||
|  |  | ||||||
| 	// Set the transactions to the block so the new SHA3 can be calculated | 	// Set the transactions to the block so the new SHA3 can be calculated | ||||||
| 	self.block.SetReceipts(receipts, txs) | 	self.block.SetReceipts(receipts, txs) | ||||||
|   | |||||||
| @@ -215,7 +215,7 @@ func (c *PStateObject) IsContract() bool { | |||||||
| } | } | ||||||
|  |  | ||||||
| func (self *PStateObject) EachStorage(cb ethtrie.EachCallback) { | func (self *PStateObject) EachStorage(cb ethtrie.EachCallback) { | ||||||
| 	self.object.State().EachStorage(cb) | 	self.object.EachStorage(cb) | ||||||
| } | } | ||||||
|  |  | ||||||
| type KeyVal struct { | type KeyVal struct { | ||||||
| @@ -226,7 +226,7 @@ type KeyVal struct { | |||||||
| func (c *PStateObject) StateKeyVal(asJson bool) interface{} { | func (c *PStateObject) StateKeyVal(asJson bool) interface{} { | ||||||
| 	var values []KeyVal | 	var values []KeyVal | ||||||
| 	if c.object != nil { | 	if c.object != nil { | ||||||
| 		c.object.State().EachStorage(func(name string, value *ethutil.Value) { | 		c.object.EachStorage(func(name string, value *ethutil.Value) { | ||||||
| 			values = append(values, KeyVal{name, ethutil.Bytes2Hex(value.Bytes())}) | 			values = append(values, KeyVal{name, ethutil.Bytes2Hex(value.Bytes())}) | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user