aboutsummaryrefslogtreecommitdiffstats
path: root/dev_console.go
diff options
context:
space:
mode:
Diffstat (limited to 'dev_console.go')
-rw-r--r--dev_console.go32
1 files changed, 32 insertions, 0 deletions
diff --git a/dev_console.go b/dev_console.go
index b515b3e5c..252860fc8 100644
--- a/dev_console.go
+++ b/dev_console.go
@@ -9,6 +9,8 @@ import (
"github.com/ethereum/ethchain-go"
"github.com/ethereum/ethdb-go"
"github.com/ethereum/ethutil-go"
+ "github.com/ethereum/ethwire-go"
+ "math/big"
"os"
"strings"
)
@@ -49,6 +51,9 @@ func (i *Console) ValidateInput(action string, argumentLength int) error {
case action == "tx" && argumentLength != 2:
err = true
expArgCount = 2
+ case action == "getaddr" && argumentLength != 1:
+ err = true
+ expArgCount = 1
}
if err {
@@ -109,8 +114,35 @@ func (i *Console) ParseInput(input string) bool {
case "decode":
d, _ := ethutil.Decode([]byte(tokens[1]), 0)
fmt.Printf("%q\n", d)
+ case "getaddr":
+ encoded, _ := hex.DecodeString(tokens[1])
+ d := i.ethereum.BlockManager.BlockChain().LastBlock.State().Get(string(encoded))
+ if d != "" {
+ decoder := ethutil.NewRlpDecoder([]byte(d))
+ fmt.Println(decoder)
+ } else {
+ fmt.Println("getaddr: address unknown")
+ }
case "encode":
fmt.Printf("%q\n", ethutil.Encode(tokens[1]))
+ case "newblk":
+ block := ethchain.CreateBlock(
+ i.ethereum.BlockManager.BlockChain().LastBlock.State().Root,
+ i.ethereum.BlockManager.LastBlockHash,
+ "123",
+ big.NewInt(1),
+ big.NewInt(1),
+ "",
+ i.ethereum.TxPool.Flush(),
+ )
+ i.ethereum.Broadcast(ethwire.MsgBlockTy, block.RlpData())
+ //fmt.Println(ethutil.NewRlpValue(block.RlpData()).Get(0))
+ //err := i.ethereum.BlockManager.ProcessBlock(block)
+ //if err != nil {
+ // fmt.Println(err)
+ //} else {
+
+ // }
case "tx":
tx := ethchain.NewTransaction(tokens[1], ethutil.Big(tokens[2]), []string{""})