|
@ -110,8 +110,10 @@ func (v *ChunkCacheVolume) GetNeedle(key types.NeedleId) ([]byte, error) { |
|
|
} |
|
|
} |
|
|
data := make([]byte, nv.Size) |
|
|
data := make([]byte, nv.Size) |
|
|
if readSize, readErr := v.DataBackend.ReadAt(data, nv.Offset.ToActualOffset()); readErr != nil { |
|
|
if readSize, readErr := v.DataBackend.ReadAt(data, nv.Offset.ToActualOffset()); readErr != nil { |
|
|
|
|
|
if readSize != int(nv.Size) { |
|
|
return nil, fmt.Errorf("read %s.dat [%d,%d): %v", |
|
|
return nil, fmt.Errorf("read %s.dat [%d,%d): %v", |
|
|
v.fileName, nv.Offset.ToActualOffset(), nv.Offset.ToActualOffset()+int64(nv.Size), readErr) |
|
|
v.fileName, nv.Offset.ToActualOffset(), nv.Offset.ToActualOffset()+int64(nv.Size), readErr) |
|
|
|
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
if readSize != int(nv.Size) { |
|
|
if readSize != int(nv.Size) { |
|
|
return nil, fmt.Errorf("read %d, expected %d", readSize, nv.Size) |
|
|
return nil, fmt.Errorf("read %d, expected %d", readSize, nv.Size) |
|
@ -133,8 +135,10 @@ func (v *ChunkCacheVolume) getNeedleSlice(key types.NeedleId, offset, length uin |
|
|
} |
|
|
} |
|
|
data := make([]byte, wanted) |
|
|
data := make([]byte, wanted) |
|
|
if readSize, readErr := v.DataBackend.ReadAt(data, nv.Offset.ToActualOffset()+int64(offset)); readErr != nil { |
|
|
if readSize, readErr := v.DataBackend.ReadAt(data, nv.Offset.ToActualOffset()+int64(offset)); readErr != nil { |
|
|
|
|
|
if readSize != wanted { |
|
|
return nil, fmt.Errorf("read %s.dat [%d,%d): %v", |
|
|
return nil, fmt.Errorf("read %s.dat [%d,%d): %v", |
|
|
v.fileName, nv.Offset.ToActualOffset()+int64(offset), int(nv.Offset.ToActualOffset())+int(offset)+wanted, readErr) |
|
|
v.fileName, nv.Offset.ToActualOffset()+int64(offset), int(nv.Offset.ToActualOffset())+int(offset)+wanted, readErr) |
|
|
|
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
if readSize != wanted { |
|
|
if readSize != wanted { |
|
|
return nil, fmt.Errorf("read %d, expected %d", readSize, wanted) |
|
|
return nil, fmt.Errorf("read %d, expected %d", readSize, wanted) |
|
@ -155,8 +159,10 @@ func (v *ChunkCacheVolume) readNeedleSliceAt(data []byte, key types.NeedleId, of |
|
|
return 0, ErrorOutOfBounds |
|
|
return 0, ErrorOutOfBounds |
|
|
} |
|
|
} |
|
|
if n, err = v.DataBackend.ReadAt(data, nv.Offset.ToActualOffset()+int64(offset)); err != nil { |
|
|
if n, err = v.DataBackend.ReadAt(data, nv.Offset.ToActualOffset()+int64(offset)); err != nil { |
|
|
|
|
|
if n != wanted { |
|
|
return n, fmt.Errorf("read %s.dat [%d,%d): %v", |
|
|
return n, fmt.Errorf("read %s.dat [%d,%d): %v", |
|
|
v.fileName, nv.Offset.ToActualOffset()+int64(offset), int(nv.Offset.ToActualOffset())+int(offset)+wanted, err) |
|
|
v.fileName, nv.Offset.ToActualOffset()+int64(offset), int(nv.Offset.ToActualOffset())+int(offset)+wanted, err) |
|
|
|
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
if n != wanted { |
|
|
if n != wanted { |
|
|
return n, fmt.Errorf("read %d, expected %d", n, wanted) |
|
|
return n, fmt.Errorf("read %d, expected %d", n, wanted) |
|
|