Merge branch 'release/poc5-rc10'
This commit is contained in:
commit
818cbcbdd4
|
@ -72,7 +72,7 @@ func (c *Closure) Address() []byte {
|
||||||
return c.object.Address()
|
return c.object.Address()
|
||||||
}
|
}
|
||||||
|
|
||||||
type DebugHook func(step int, op OpCode, mem *Memory, stack *Stack)
|
type DebugHook func(step int, op OpCode, mem *Memory, stack *Stack, stateObject *StateObject) bool
|
||||||
|
|
||||||
func (c *Closure) Call(vm *Vm, args []byte, hook DebugHook) ([]byte, error) {
|
func (c *Closure) Call(vm *Vm, args []byte, hook DebugHook) ([]byte, error) {
|
||||||
c.Args = args
|
c.Args = args
|
||||||
|
|
|
@ -49,6 +49,11 @@ func (s *State) Purge() int {
|
||||||
return s.trie.NewIterator().Purge()
|
return s.trie.NewIterator().Purge()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *State) EachStorage(cb ethutil.EachCallback) {
|
||||||
|
it := s.trie.NewIterator()
|
||||||
|
it.Each(cb)
|
||||||
|
}
|
||||||
|
|
||||||
func (s *State) GetStateObject(addr []byte) *StateObject {
|
func (s *State) GetStateObject(addr []byte) *StateObject {
|
||||||
data := s.trie.Get(string(addr))
|
data := s.trie.Get(string(addr))
|
||||||
if data == "" {
|
if data == "" {
|
||||||
|
|
|
@ -543,7 +543,9 @@ func (vm *Vm) RunClosure(closure *Closure, hook DebugHook) (ret []byte, err erro
|
||||||
pc.Add(pc, ethutil.Big1)
|
pc.Add(pc, ethutil.Big1)
|
||||||
|
|
||||||
if hook != nil {
|
if hook != nil {
|
||||||
hook(step-1, op, mem, stack)
|
if !hook(step-1, op, mem, stack, closure.Object()) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,16 +2,20 @@ package ethpub
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/hex"
|
"encoding/hex"
|
||||||
|
"encoding/json"
|
||||||
"github.com/ethereum/eth-go/ethchain"
|
"github.com/ethereum/eth-go/ethchain"
|
||||||
"github.com/ethereum/eth-go/ethutil"
|
"github.com/ethereum/eth-go/ethutil"
|
||||||
|
_ "log"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Block interface exposed to QML
|
// Block interface exposed to QML
|
||||||
type PBlock struct {
|
type PBlock struct {
|
||||||
ref *ethchain.Block
|
ref *ethchain.Block
|
||||||
Number int `json:"number"`
|
Number int `json:"number"`
|
||||||
Hash string `json:"hash"`
|
Hash string `json:"hash"`
|
||||||
|
Transactions string `json:"transactions"`
|
||||||
|
Time int64 `json:"time"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// Creates a new QML Block from a chain block
|
// Creates a new QML Block from a chain block
|
||||||
|
@ -20,7 +24,17 @@ func NewPBlock(block *ethchain.Block) *PBlock {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
return &PBlock{ref: block, Number: int(block.Number.Uint64()), Hash: ethutil.Hex(block.Hash())}
|
var ptxs []PTx
|
||||||
|
for _, tx := range block.Transactions() {
|
||||||
|
ptxs = append(ptxs, *NewPTx(tx))
|
||||||
|
}
|
||||||
|
|
||||||
|
txJson, err := json.Marshal(ptxs)
|
||||||
|
if err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return &PBlock{ref: block, Number: int(block.Number.Uint64()), Hash: ethutil.Hex(block.Hash()), Transactions: string(txJson), Time: block.Time}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *PBlock) ToString() string {
|
func (self *PBlock) ToString() string {
|
||||||
|
@ -43,16 +57,25 @@ func (self *PBlock) GetTransaction(hash string) *PTx {
|
||||||
type PTx struct {
|
type PTx struct {
|
||||||
ref *ethchain.Transaction
|
ref *ethchain.Transaction
|
||||||
|
|
||||||
Value, Hash, Address string
|
Value string `json:"value"`
|
||||||
Contract bool
|
Gas string `json:"gas"`
|
||||||
|
GasPrice string `json:"gasPrice"`
|
||||||
|
Hash string `json:"hash"`
|
||||||
|
Address string `json:"address"`
|
||||||
|
Sender string `json:"sender"`
|
||||||
|
Data string `json:"data"`
|
||||||
|
Contract bool `json:"isContract"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPTx(tx *ethchain.Transaction) *PTx {
|
func NewPTx(tx *ethchain.Transaction) *PTx {
|
||||||
hash := hex.EncodeToString(tx.Hash())
|
hash := hex.EncodeToString(tx.Hash())
|
||||||
sender := hex.EncodeToString(tx.Recipient)
|
receiver := hex.EncodeToString(tx.Recipient)
|
||||||
|
sender := hex.EncodeToString(tx.Sender())
|
||||||
|
data := strings.Join(ethchain.Disassemble(tx.Data), "\n")
|
||||||
|
|
||||||
isContract := len(tx.Data) > 0
|
isContract := len(tx.Data) > 0
|
||||||
|
|
||||||
return &PTx{ref: tx, Hash: hash, Value: ethutil.CurrencyToString(tx.Value), Address: sender, Contract: isContract}
|
return &PTx{ref: tx, Hash: hash, Value: ethutil.CurrencyToString(tx.Value), Address: receiver, Contract: isContract, Gas: tx.Gas.String(), GasPrice: tx.GasPrice.String(), Data: data, Sender: sender}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (self *PTx) ToString() string {
|
func (self *PTx) ToString() string {
|
||||||
|
|
|
@ -43,7 +43,7 @@ func ReadConfig(base string, logTypes LoggerType, id string) *config {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Config = &config{ExecPath: path, Debug: true, Ver: "0.5.0 RC9"}
|
Config = &config{ExecPath: path, Debug: true, Ver: "0.5.0 RC10"}
|
||||||
Config.Identifier = id
|
Config.Identifier = id
|
||||||
Config.Log = NewLogger(logTypes, LogLevelDebug)
|
Config.Log = NewLogger(logTypes, LogLevelDebug)
|
||||||
Config.SetClientString("/Ethereum(G)")
|
Config.SetClientString("/Ethereum(G)")
|
||||||
|
|
|
@ -59,3 +59,18 @@ func CompactHexDecode(str string) []int {
|
||||||
|
|
||||||
return hexSlice
|
return hexSlice
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func DecodeCompact(key []int) string {
|
||||||
|
base := "0123456789abcdef"
|
||||||
|
var str string
|
||||||
|
|
||||||
|
for _, v := range key {
|
||||||
|
if v < 16 {
|
||||||
|
str += string(base[v])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
res, _ := hex.DecodeString(str)
|
||||||
|
|
||||||
|
return string(res)
|
||||||
|
}
|
||||||
|
|
|
@ -442,6 +442,8 @@ type TrieIterator struct {
|
||||||
|
|
||||||
shas [][]byte
|
shas [][]byte
|
||||||
values []string
|
values []string
|
||||||
|
|
||||||
|
lastNode []byte
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Trie) NewIterator() *TrieIterator {
|
func (t *Trie) NewIterator() *TrieIterator {
|
||||||
|
@ -513,3 +515,47 @@ func (it *TrieIterator) Key() string {
|
||||||
func (it *TrieIterator) Value() string {
|
func (it *TrieIterator) Value() string {
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type EachCallback func(key string, node *Value)
|
||||||
|
|
||||||
|
func (it *TrieIterator) Each(cb EachCallback) {
|
||||||
|
it.fetchNode(nil, NewValue(it.trie.Root).Bytes(), cb)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (it *TrieIterator) fetchNode(key []int, node []byte, cb EachCallback) {
|
||||||
|
it.iterateNode(key, it.trie.cache.Get(node), cb)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (it *TrieIterator) iterateNode(key []int, currentNode *Value, cb EachCallback) {
|
||||||
|
if currentNode.Len() == 2 {
|
||||||
|
k := CompactDecode(currentNode.Get(0).Str())
|
||||||
|
|
||||||
|
if currentNode.Get(1).Str() == "" {
|
||||||
|
it.iterateNode(key, currentNode.Get(1), cb)
|
||||||
|
} else {
|
||||||
|
pk := append(key, k...)
|
||||||
|
|
||||||
|
if k[len(k)-1] == 16 {
|
||||||
|
cb(DecodeCompact(pk), currentNode.Get(1))
|
||||||
|
} else {
|
||||||
|
it.fetchNode(pk, currentNode.Get(1).Bytes(), cb)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for i := 0; i < currentNode.Len(); i++ {
|
||||||
|
pk := append(key, i)
|
||||||
|
if i == 16 && currentNode.Get(i).Len() != 0 {
|
||||||
|
cb(DecodeCompact(pk), currentNode.Get(i))
|
||||||
|
} else {
|
||||||
|
if currentNode.Get(i).Str() == "" {
|
||||||
|
it.iterateNode(pk, currentNode.Get(i), cb)
|
||||||
|
} else {
|
||||||
|
val := currentNode.Get(i).Str()
|
||||||
|
if val != "" {
|
||||||
|
it.fetchNode(pk, []byte(val), cb)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -154,7 +154,7 @@ func TestTrieDeleteWithValue(t *testing.T) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTrieIterator(t *testing.T) {
|
func TestTriePurge(t *testing.T) {
|
||||||
_, trie := New()
|
_, trie := New()
|
||||||
trie.Update("c", LONG_WORD)
|
trie.Update("c", LONG_WORD)
|
||||||
trie.Update("ca", LONG_WORD)
|
trie.Update("ca", LONG_WORD)
|
||||||
|
@ -171,16 +171,14 @@ func TestTrieIterator(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestHashes(t *testing.T) {
|
func TestTrieIt(t *testing.T) {
|
||||||
_, trie := New()
|
_, trie := New()
|
||||||
trie.Update("cat", "dog")
|
trie.Update("c", LONG_WORD)
|
||||||
trie.Update("ca", "dude")
|
trie.Update("ca", LONG_WORD)
|
||||||
trie.Update("doge", "1234567890abcdefghijklmnopqrstuvwxxzABCEFGHIJKLMNOPQRSTUVWXYZ")
|
trie.Update("cat", LONG_WORD)
|
||||||
trie.Update("dog", "test")
|
|
||||||
trie.Update("test", "1234567890abcdefghijklmnopqrstuvwxxzABCEFGHIJKLMNOPQRSTUVWXYZ")
|
it := trie.NewIterator()
|
||||||
fmt.Printf("%x\n", trie.Root)
|
it.Each(func(key string, node *Value) {
|
||||||
trie.Delete("dog")
|
fmt.Println(key, ":", node.Str())
|
||||||
fmt.Printf("%x\n", trie.Root)
|
})
|
||||||
trie.Delete("test")
|
|
||||||
fmt.Printf("%x\n", trie.Root)
|
|
||||||
}
|
}
|
||||||
|
|
13
peer.go
13
peer.go
|
@ -531,13 +531,16 @@ func (p *Peer) Stop() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Peer) pushHandshake() error {
|
func (p *Peer) pushHandshake() error {
|
||||||
pubkey := ethutil.GetKeyRing().Get(0).PublicKey
|
keyRing := ethutil.GetKeyRing().Get(0)
|
||||||
|
if keyRing != nil {
|
||||||
|
pubkey := keyRing.PublicKey
|
||||||
|
|
||||||
msg := ethwire.NewMessage(ethwire.MsgHandshakeTy, []interface{}{
|
msg := ethwire.NewMessage(ethwire.MsgHandshakeTy, []interface{}{
|
||||||
uint32(ProtocolVersion), uint32(0), p.Version, byte(p.caps), p.port, pubkey[1:],
|
uint32(ProtocolVersion), uint32(0), p.Version, byte(p.caps), p.port, pubkey[1:],
|
||||||
})
|
})
|
||||||
|
|
||||||
p.QueueMessage(msg)
|
p.QueueMessage(msg)
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue