Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
584d1c61
Commit
584d1c61
authored
10 years ago
by
zelig
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
use ethreact.Event and ethreact.ReactorEngine
parent
af272641
master
v1.10.12
v1.10.12-modified
No related merge requests found
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
19 additions
and
12 deletions
+19
-12
dagger.go
ethchain/dagger.go
+3
-2
state_manager.go
ethchain/state_manager.go
+2
-1
ethereum.go
ethereum.go
+8
-3
miner.go
ethminer/miner.go
+6
-6
No files found.
ethchain/dagger.go
View file @
584d1c61
...
...
@@ -3,6 +3,7 @@ package ethchain
import
(
"github.com/ethereum/eth-go/ethcrypto"
"github.com/ethereum/eth-go/ethlog"
"github.com/ethereum/eth-go/ethreact"
"github.com/ethereum/eth-go/ethutil"
"github.com/obscuren/sha3"
"hash"
...
...
@@ -14,7 +15,7 @@ import (
var
powlogger
=
ethlog
.
NewLogger
(
"POW"
)
type
PoW
interface
{
Search
(
block
*
Block
,
reactChan
chan
eth
util
.
Reac
t
)
[]
byte
Search
(
block
*
Block
,
reactChan
chan
eth
react
.
Even
t
)
[]
byte
Verify
(
hash
[]
byte
,
diff
*
big
.
Int
,
nonce
[]
byte
)
bool
}
...
...
@@ -22,7 +23,7 @@ type EasyPow struct {
hash
*
big
.
Int
}
func
(
pow
*
EasyPow
)
Search
(
block
*
Block
,
reactChan
chan
eth
util
.
Reac
t
)
[]
byte
{
func
(
pow
*
EasyPow
)
Search
(
block
*
Block
,
reactChan
chan
eth
react
.
Even
t
)
[]
byte
{
r
:=
rand
.
New
(
rand
.
NewSource
(
time
.
Now
()
.
UnixNano
()))
hash
:=
block
.
HashNoNonce
()
diff
:=
block
.
Difficulty
...
...
This diff is collapsed.
Click to expand it.
ethchain/state_manager.go
View file @
584d1c61
...
...
@@ -6,6 +6,7 @@ import (
"fmt"
"github.com/ethereum/eth-go/ethcrypto"
"github.com/ethereum/eth-go/ethlog"
"github.com/ethereum/eth-go/ethreact"
"github.com/ethereum/eth-go/ethtrie"
"github.com/ethereum/eth-go/ethutil"
"github.com/ethereum/eth-go/ethwire"
...
...
@@ -36,7 +37,7 @@ type EthManager interface {
BlockChain
()
*
BlockChain
TxPool
()
*
TxPool
Broadcast
(
msgType
ethwire
.
MsgType
,
data
[]
interface
{})
Reactor
()
*
eth
util
.
ReactorEngine
Reactor
()
*
eth
react
.
ReactorEngine
PeerCount
()
int
IsMining
()
bool
IsListening
()
bool
...
...
This diff is collapsed.
Click to expand it.
ethereum.go
View file @
584d1c61
...
...
@@ -6,6 +6,7 @@ import (
"github.com/ethereum/eth-go/ethchain"
"github.com/ethereum/eth-go/ethcrypto"
"github.com/ethereum/eth-go/ethlog"
"github.com/ethereum/eth-go/ethreact"
"github.com/ethereum/eth-go/ethrpc"
"github.com/ethereum/eth-go/ethutil"
"github.com/ethereum/eth-go/ethwire"
...
...
@@ -71,7 +72,7 @@ type Ethereum struct {
listening
bool
reactor
*
eth
util
.
ReactorEngine
reactor
*
eth
react
.
ReactorEngine
RpcServer
*
ethrpc
.
JsonRpcServer
...
...
@@ -106,7 +107,7 @@ func New(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager
keyManager
:
keyManager
,
clientIdentity
:
clientIdentity
,
}
ethereum
.
reactor
=
eth
util
.
NewReactorEngine
()
ethereum
.
reactor
=
eth
react
.
New
()
ethereum
.
txPool
=
ethchain
.
NewTxPool
(
ethereum
)
ethereum
.
blockChain
=
ethchain
.
NewBlockChain
(
ethereum
)
...
...
@@ -118,7 +119,7 @@ func New(db ethutil.Database, clientIdentity ethwire.ClientIdentity, keyManager
return
ethereum
,
nil
}
func
(
s
*
Ethereum
)
Reactor
()
*
eth
util
.
ReactorEngine
{
func
(
s
*
Ethereum
)
Reactor
()
*
eth
react
.
ReactorEngine
{
return
s
.
reactor
}
...
...
@@ -350,6 +351,7 @@ func (s *Ethereum) ReapDeadPeerHandler() {
// Start the ethereum
func
(
s
*
Ethereum
)
Start
(
seed
bool
)
{
s
.
reactor
.
Start
()
// Bind to addr and port
ln
,
err
:=
net
.
Listen
(
"tcp"
,
":"
+
s
.
Port
)
if
err
!=
nil
{
...
...
@@ -461,6 +463,9 @@ func (s *Ethereum) Stop() {
s
.
txPool
.
Stop
()
s
.
stateManager
.
Stop
()
s
.
reactor
.
Flush
()
s
.
reactor
.
Stop
()
ethlogger
.
Infoln
(
"Server stopped"
)
close
(
s
.
shutdownChan
)
}
...
...
This diff is collapsed.
Click to expand it.
ethminer/miner.go
View file @
584d1c61
...
...
@@ -4,7 +4,7 @@ import (
"bytes"
"github.com/ethereum/eth-go/ethchain"
"github.com/ethereum/eth-go/ethlog"
"github.com/ethereum/eth-go/eth
util
"
"github.com/ethereum/eth-go/eth
react
"
"github.com/ethereum/eth-go/ethwire"
"sort"
)
...
...
@@ -15,19 +15,19 @@ type Miner struct {
pow
ethchain
.
PoW
ethereum
ethchain
.
EthManager
coinbase
[]
byte
reactChan
chan
eth
util
.
Reac
t
reactChan
chan
eth
react
.
Even
t
txs
ethchain
.
Transactions
uncles
[]
*
ethchain
.
Block
block
*
ethchain
.
Block
powChan
chan
[]
byte
powQuitChan
chan
eth
util
.
Reac
t
powQuitChan
chan
eth
react
.
Even
t
quitChan
chan
bool
}
func
NewDefaultMiner
(
coinbase
[]
byte
,
ethereum
ethchain
.
EthManager
)
Miner
{
reactChan
:=
make
(
chan
eth
util
.
Reac
t
,
1
)
// This is the channel that receives 'updates' when ever a new transaction or block comes in
powChan
:=
make
(
chan
[]
byte
,
1
)
// This is the channel that receives valid sha hases for a given block
powQuitChan
:=
make
(
chan
eth
util
.
Reac
t
,
1
)
// This is the channel that can exit the miner thread
reactChan
:=
make
(
chan
eth
react
.
Even
t
,
1
)
// This is the channel that receives 'updates' when ever a new transaction or block comes in
powChan
:=
make
(
chan
[]
byte
,
1
)
// This is the channel that receives valid sha hases for a given block
powQuitChan
:=
make
(
chan
eth
react
.
Even
t
,
1
)
// This is the channel that can exit the miner thread
quitChan
:=
make
(
chan
bool
,
1
)
ethereum
.
Reactor
()
.
Subscribe
(
"newBlock"
,
reactChan
)
...
...
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment