aboutsummaryrefslogtreecommitdiffstats
path: root/xeth/state.go
diff options
context:
space:
mode:
authorzelig <viktor.tron@gmail.com>2015-03-03 03:13:41 +0800
committerzelig <viktor.tron@gmail.com>2015-03-03 03:13:41 +0800
commitaf6971f823431e091142dc81f1b252f681d086cf (patch)
tree2b34e0f42adaeebcf28c955249934f7dc5270792 /xeth/state.go
parenta60a18b080197cad836f18f9d093bba3bcb6cef8 (diff)
parent65cad14f9b27db396d036f47814d4843d947ac43 (diff)
downloaddexon-af6971f823431e091142dc81f1b252f681d086cf.tar
dexon-af6971f823431e091142dc81f1b252f681d086cf.tar.gz
dexon-af6971f823431e091142dc81f1b252f681d086cf.tar.bz2
dexon-af6971f823431e091142dc81f1b252f681d086cf.tar.lz
dexon-af6971f823431e091142dc81f1b252f681d086cf.tar.xz
dexon-af6971f823431e091142dc81f1b252f681d086cf.tar.zst
dexon-af6971f823431e091142dc81f1b252f681d086cf.zip
Merge remote-tracking branch 'upstream/develop' into blockpool2
Diffstat (limited to 'xeth/state.go')
-rw-r--r--xeth/state.go33
1 files changed, 33 insertions, 0 deletions
diff --git a/xeth/state.go b/xeth/state.go
new file mode 100644
index 000000000..e2562613c
--- /dev/null
+++ b/xeth/state.go
@@ -0,0 +1,33 @@
+package xeth
+
+import "github.com/ethereum/go-ethereum/state"
+
+type State struct {
+ xeth *XEth
+ state *state.StateDB
+}
+
+func NewState(xeth *XEth, statedb *state.StateDB) *State {
+ return &State{xeth, statedb}
+}
+
+func (self *State) State() *state.StateDB {
+ return self.state
+}
+
+func (self *State) Get(addr string) *Object {
+ return &Object{self.state.GetStateObject(fromHex(addr))}
+}
+
+func (self *State) SafeGet(addr string) *Object {
+ return &Object{self.safeGet(addr)}
+}
+
+func (self *State) safeGet(addr string) *state.StateObject {
+ object := self.state.GetStateObject(fromHex(addr))
+ if object == nil {
+ object = state.NewStateObject(fromHex(addr), self.xeth.eth.Db())
+ }
+
+ return object
+}