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
9b5c7153
Unverified
Commit
9b5c7153
authored
Feb 03, 2017
by
Péter Szilágyi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
event: use sync.Once for init for faster/cleaner locking
parent
d52b0c32
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
5 additions
and
11 deletions
+5
-11
feed.go
event/feed.go
+5
-11
No files found.
event/feed.go
View file @
9b5c7153
...
...
@@ -33,9 +33,8 @@ var errBadChannel = errors.New("event: Subscribe argument does not have sendable
//
// The zero value is ready to use.
type
Feed
struct
{
// sendLock has a one-element buffer and is empty when held.
// It protects sendCases.
sendLock
chan
struct
{}
once
sync
.
Once
// ensures that init only runs once
sendLock
chan
struct
{}
// sendLock has a one-element buffer and is empty when held.It protects sendCases.
removeSub
chan
interface
{}
// interrupts Send
sendCases
caseList
// the active set of select cases used by Send
...
...
@@ -60,9 +59,6 @@ func (e feedTypeError) Error() string {
}
func
(
f
*
Feed
)
init
()
{
if
f
.
sendLock
!=
nil
{
return
}
f
.
removeSub
=
make
(
chan
interface
{})
f
.
sendLock
=
make
(
chan
struct
{},
1
)
f
.
sendLock
<-
struct
{}{}
...
...
@@ -75,6 +71,8 @@ func (f *Feed) init() {
// The channel should have ample buffer space to avoid blocking other subscribers.
// Slow subscribers are not dropped.
func
(
f
*
Feed
)
Subscribe
(
channel
interface
{})
Subscription
{
f
.
once
.
Do
(
f
.
init
)
chanval
:=
reflect
.
ValueOf
(
channel
)
chantyp
:=
chanval
.
Type
()
if
chantyp
.
Kind
()
!=
reflect
.
Chan
||
chantyp
.
ChanDir
()
&
reflect
.
SendDir
==
0
{
...
...
@@ -84,7 +82,6 @@ func (f *Feed) Subscribe(channel interface{}) Subscription {
f
.
mu
.
Lock
()
defer
f
.
mu
.
Unlock
()
f
.
init
()
if
!
f
.
typecheck
(
chantyp
.
Elem
())
{
panic
(
feedTypeError
{
op
:
"Subscribe"
,
got
:
chantyp
,
want
:
reflect
.
ChanOf
(
reflect
.
SendDir
,
f
.
etype
)})
}
...
...
@@ -130,10 +127,7 @@ func (f *Feed) remove(sub *feedSub) {
// Send delivers to all subscribed channels simultaneously.
// It returns the number of subscribers that the value was sent to.
func
(
f
*
Feed
)
Send
(
value
interface
{})
(
nsent
int
)
{
f
.
mu
.
Lock
()
f
.
init
()
f
.
mu
.
Unlock
()
f
.
once
.
Do
(
f
.
init
)
<-
f
.
sendLock
// Add new cases from the inbox after taking the send lock.
...
...
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