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
3db6a8e9
Commit
3db6a8e9
authored
Oct 10, 2014
by
Jeffrey Wilcke
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #57 from fjl/feature/raceless-ethereum-filters
Fix filter map race
parents
6fec5bd3
e83a9990
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
10 deletions
+23
-10
ethereum.go
ethereum.go
+23
-10
No files found.
ethereum.go
View file @
3db6a8e9
...
...
@@ -95,7 +95,9 @@ type Ethereum struct {
isUpToDate
bool
filters
map
[
int
]
*
ethchain
.
Filter
filterMu
sync
.
RWMutex
filterId
int
filters
map
[
int
]
*
ethchain
.
Filter
}
func
New
(
db
ethutil
.
Database
,
clientIdentity
ethwire
.
ClientIdentity
,
keyManager
*
ethcrypto
.
KeyManager
,
caps
Caps
,
usePnp
bool
)
(
*
Ethereum
,
error
)
{
...
...
@@ -594,22 +596,29 @@ out:
}
}
var
filterId
=
0
func
(
self
*
Ethereum
)
InstallFilter
(
object
map
[
string
]
interface
{})
(
*
ethchain
.
Filter
,
int
)
{
defer
func
()
{
filterId
++
}()
filter
:=
ethchain
.
NewFilterFromMap
(
object
,
self
)
self
.
filters
[
filterId
]
=
filter
return
filter
,
filterId
// InstallFilter adds filter for blockchain events.
// The filter's callbacks will run for matching blocks and messages.
// The filter should not be modified after it has been installed.
func
(
self
*
Ethereum
)
InstallFilter
(
filter
*
ethchain
.
Filter
)
(
id
int
)
{
self
.
filterMu
.
Lock
()
id
=
self
.
filterId
self
.
filters
[
id
]
=
filter
self
.
filterId
++
self
.
filterMu
.
Unlock
()
return
id
}
func
(
self
*
Ethereum
)
UninstallFilter
(
id
int
)
{
self
.
filterMu
.
Lock
()
delete
(
self
.
filters
,
id
)
self
.
filterMu
.
Unlock
()
}
// GetFilter retrieves a filter installed using InstallFilter.
// The filter may not be modified.
func
(
self
*
Ethereum
)
GetFilter
(
id
int
)
*
ethchain
.
Filter
{
self
.
filterMu
.
RLock
()
defer
self
.
filterMu
.
RUnlock
()
return
self
.
filters
[
id
]
}
...
...
@@ -627,14 +636,17 @@ out:
break
out
case
block
:=
<-
blockChan
:
if
block
,
ok
:=
block
.
Resource
.
(
*
ethchain
.
Block
);
ok
{
self
.
filterMu
.
RLock
()
for
_
,
filter
:=
range
self
.
filters
{
if
filter
.
BlockCallback
!=
nil
{
filter
.
BlockCallback
(
block
)
}
}
self
.
filterMu
.
RUnlock
()
}
case
msg
:=
<-
messageChan
:
if
messages
,
ok
:=
msg
.
Resource
.
(
ethstate
.
Messages
);
ok
{
self
.
filterMu
.
RLock
()
for
_
,
filter
:=
range
self
.
filters
{
if
filter
.
MessageCallback
!=
nil
{
msgs
:=
filter
.
FilterMessages
(
messages
)
...
...
@@ -643,6 +655,7 @@ out:
}
}
}
self
.
filterMu
.
RUnlock
()
}
}
}
...
...
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