Commit 93fde86d authored by Brian Tiger Chow's avatar Brian Tiger Chow Committed by Juan Batiz-Benet

refactor: taskKey := p.Key() + block.Key()

for clarity and to avoid errors, define a function

License: MIT
Signed-off-by: default avatarBrian Tiger Chow <brian@perfmode.com>
parent 46096783
...@@ -17,7 +17,6 @@ var log = u.Logger("strategy") ...@@ -17,7 +17,6 @@ var log = u.Logger("strategy")
// LedgerMap lists Ledgers by their Partner key. // LedgerMap lists Ledgers by their Partner key.
type ledgerMap map[peerKey]*ledger type ledgerMap map[peerKey]*ledger
// FIXME share this externally
type peerKey u.Key type peerKey u.Key
type Envelope struct { type Envelope struct {
......
...@@ -10,12 +10,12 @@ import ( ...@@ -10,12 +10,12 @@ import (
// tasks (on getnext). For now, we are assuming a dumb/nice strategy. // tasks (on getnext). For now, we are assuming a dumb/nice strategy.
type TaskList struct { type TaskList struct {
tasks []*Task tasks []*Task
taskmap map[u.Key]*Task taskmap map[string]*Task
} }
func NewTaskList() *TaskList { func NewTaskList() *TaskList {
return &TaskList{ return &TaskList{
taskmap: make(map[u.Key]*Task), taskmap: make(map[string]*Task),
} }
} }
...@@ -28,7 +28,7 @@ type Task struct { ...@@ -28,7 +28,7 @@ type Task struct {
// Push currently adds a new task to the end of the list // Push currently adds a new task to the end of the list
// TODO: make this into a priority queue // TODO: make this into a priority queue
func (tl *TaskList) Push(block u.Key, priority int, to peer.Peer) { func (tl *TaskList) Push(block u.Key, priority int, to peer.Peer) {
if task, ok := tl.taskmap[to.Key()+block]; ok { if task, ok := tl.taskmap[taskKey(to, block)]; ok {
// TODO: when priority queue is implemented, // TODO: when priority queue is implemented,
// rearrange this Task // rearrange this Task
task.theirPriority = priority task.theirPriority = priority
...@@ -40,7 +40,7 @@ func (tl *TaskList) Push(block u.Key, priority int, to peer.Peer) { ...@@ -40,7 +40,7 @@ func (tl *TaskList) Push(block u.Key, priority int, to peer.Peer) {
theirPriority: priority, theirPriority: priority,
} }
tl.tasks = append(tl.tasks, task) tl.tasks = append(tl.tasks, task)
tl.taskmap[to.Key()+block] = task tl.taskmap[taskKey(to, block)] = task
} }
// Pop 'pops' the next task to be performed. Returns nil no task exists. // Pop 'pops' the next task to be performed. Returns nil no task exists.
...@@ -52,7 +52,7 @@ func (tl *TaskList) Pop() *Task { ...@@ -52,7 +52,7 @@ func (tl *TaskList) Pop() *Task {
// the same block from multiple peers // the same block from multiple peers
out = tl.tasks[0] out = tl.tasks[0]
tl.tasks = tl.tasks[1:] tl.tasks = tl.tasks[1:]
delete(tl.taskmap, out.Target.Key()+out.Key) delete(tl.taskmap, taskKey(out.Target, out.Key))
// Filter out blocks that have been cancelled // Filter out blocks that have been cancelled
if out.theirPriority >= 0 { if out.theirPriority >= 0 {
break break
...@@ -64,8 +64,13 @@ func (tl *TaskList) Pop() *Task { ...@@ -64,8 +64,13 @@ func (tl *TaskList) Pop() *Task {
// Cancel lazily cancels the sending of a block to a given peer // Cancel lazily cancels the sending of a block to a given peer
func (tl *TaskList) Cancel(k u.Key, p peer.Peer) { func (tl *TaskList) Cancel(k u.Key, p peer.Peer) {
t, ok := tl.taskmap[p.Key()+k] t, ok := tl.taskmap[taskKey(p, k)]
if ok { if ok {
t.theirPriority = -1 t.theirPriority = -1
} }
} }
// taskKey returns a key that uniquely identifies a task.
func taskKey(p peer.Peer, k u.Key) string {
return string(p.Key() + k)
}
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment