diff options
author | obscuren <obscuren@obscura.com> | 2014-01-03 07:43:49 +0800 |
---|---|---|
committer | obscuren <obscuren@obscura.com> | 2014-01-03 07:43:49 +0800 |
commit | 7cd41ac45aed7ee22ef02f8abedf83a2914c4807 (patch) | |
tree | 7a4c3daee8a04dc9604098407f019bb5db9ea3d4 /block.go | |
parent | 9df4c745119b3ed10a7ad17887e8dd9cac249af7 (diff) | |
download | go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.tar go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.tar.gz go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.tar.bz2 go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.tar.lz go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.tar.xz go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.tar.zst go-tangerine-7cd41ac45aed7ee22ef02f8abedf83a2914c4807.zip |
Wip VM. Created contracts
Diffstat (limited to 'block.go')
-rw-r--r-- | block.go | 26 |
1 files changed, 25 insertions, 1 deletions
@@ -4,6 +4,7 @@ import ( _"fmt" "time" _"bytes" + _"encoding/hex" ) type Block struct { @@ -63,13 +64,36 @@ func CreateBlock(root string, num int, prevHash string, base string, difficulty extra: extra, } block.state = NewTrie(Db, root) + for _, tx := range txes { - block.state.Update(tx.recipient, string(tx.MarshalRlp())) + // Create contract if there's no recipient + if tx.recipient == "" { + addr := tx.Hash() + + contract := NewContract(tx.value, []byte("")) + block.state.Update(string(addr), string(contract.MarshalRlp())) + for i, val := range tx.data { + contract.state.Update(string(Encode(i)), val) + } + block.UpdateContract(addr, contract) + } } return block } +func (block *Block) GetContract(addr []byte) *Contract { + data := block.state.Get(string(addr)) + contract := &Contract{} + contract.UnmarshalRlp([]byte(data)) + + return contract +} + +func (block *Block) UpdateContract(addr []byte, contract *Contract) { + block.state.Update(string(addr), string(contract.MarshalRlp())) +} + func (block *Block) Update() { } |