2016-06-25 19:35:18 +00:00
|
|
|
package kcp
|
|
|
|
|
|
|
|
type ReceivingWindow struct {
|
|
|
|
start uint32
|
|
|
|
size uint32
|
|
|
|
list []*Segment
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewReceivingWindow(size uint32) *ReceivingWindow {
|
|
|
|
return &ReceivingWindow{
|
|
|
|
start: 0,
|
|
|
|
size: size,
|
|
|
|
list: make([]*Segment, size),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ReceivingWindow) Size() uint32 {
|
|
|
|
return this.size
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ReceivingWindow) Position(idx uint32) uint32 {
|
|
|
|
return (idx + this.start) % this.size
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ReceivingWindow) Set(idx uint32, value *Segment) bool {
|
|
|
|
pos := this.Position(idx)
|
|
|
|
if this.list[pos] != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
this.list[pos] = value
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ReceivingWindow) Remove(idx uint32) *Segment {
|
|
|
|
pos := this.Position(idx)
|
|
|
|
e := this.list[pos]
|
|
|
|
this.list[pos] = nil
|
|
|
|
return e
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ReceivingWindow) RemoveFirst() *Segment {
|
|
|
|
return this.Remove(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ReceivingWindow) Advance() {
|
|
|
|
this.start++
|
|
|
|
if this.start == this.size {
|
|
|
|
this.start = 0
|
|
|
|
}
|
|
|
|
}
|
2016-06-27 20:34:46 +00:00
|
|
|
|
|
|
|
type ACKList struct {
|
|
|
|
timestamps []uint32
|
|
|
|
numbers []uint32
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ACKList) Add(number uint32, timestamp uint32) {
|
|
|
|
this.timestamps = append(this.timestamps, timestamp)
|
|
|
|
this.numbers = append(this.numbers, number)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ACKList) Clear(una uint32) {
|
|
|
|
count := 0
|
|
|
|
for i := 0; i < len(this.numbers); i++ {
|
|
|
|
if this.numbers[i] >= una {
|
|
|
|
if i != count {
|
|
|
|
this.numbers[count] = this.numbers[i]
|
|
|
|
this.timestamps[count] = this.timestamps[i]
|
|
|
|
}
|
|
|
|
count++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.numbers = this.numbers[:count]
|
|
|
|
this.timestamps = this.timestamps[:count]
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ACKList) AsSegment() *ACKSegment {
|
|
|
|
count := len(this.numbers)
|
|
|
|
if count > 16 {
|
|
|
|
count = 16
|
|
|
|
}
|
|
|
|
return &ACKSegment{
|
|
|
|
Count: byte(count),
|
|
|
|
NumberList: this.numbers[:count],
|
|
|
|
TimestampList: this.timestamps[:count],
|
|
|
|
}
|
|
|
|
}
|