mirror of
https://github.com/jech/galene.git
synced 2024-11-22 08:35:57 +01:00
Implement packetcache.GetLast.
This commit is contained in:
parent
da97560cb3
commit
0f96f94417
2 changed files with 19 additions and 0 deletions
|
@ -135,6 +135,21 @@ func (cache *Cache) Get(seqno uint16, result []byte) uint16 {
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (cache *Cache) GetLast(result []byte) uint16 {
|
||||||
|
cache.mu.Lock()
|
||||||
|
defer cache.mu.Unlock()
|
||||||
|
|
||||||
|
i := cache.tail - 1
|
||||||
|
if i >= uint16(len(cache.entries)) {
|
||||||
|
i = 0
|
||||||
|
}
|
||||||
|
|
||||||
|
return uint16(copy(
|
||||||
|
result[:cache.entries[i].length],
|
||||||
|
cache.entries[i].buf[:]),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
func (cache *Cache) GetAt(seqno uint16, index uint16, result []byte) uint16 {
|
func (cache *Cache) GetAt(seqno uint16, index uint16, result []byte) uint16 {
|
||||||
cache.mu.Lock()
|
cache.mu.Lock()
|
||||||
defer cache.mu.Unlock()
|
defer cache.mu.Unlock()
|
||||||
|
|
|
@ -33,6 +33,10 @@ func TestCache(t *testing.T) {
|
||||||
if !bytes.Equal(buf[:l], buf1) {
|
if !bytes.Equal(buf[:l], buf1) {
|
||||||
t.Errorf("Couldn't get 13 at %v", i1)
|
t.Errorf("Couldn't get 13 at %v", i1)
|
||||||
}
|
}
|
||||||
|
l = cache.GetLast(buf)
|
||||||
|
if !bytes.Equal(buf[:l], buf2) {
|
||||||
|
t.Errorf("Couldn't get last")
|
||||||
|
}
|
||||||
|
|
||||||
l = cache.Get(17, buf)
|
l = cache.Get(17, buf)
|
||||||
if !bytes.Equal(buf[:l], buf2) {
|
if !bytes.Equal(buf[:l], buf2) {
|
||||||
|
|
Loading…
Reference in a new issue