mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-14 02:12:21 +00:00
0e2156c776
* Fix possible deadlock in calculating backup entries' checksums. * Fix data type used to store checksums. * Allow ReadBufferFromMemory::seek() to go to the end of the buffer (seek(0, SEEK_SET) must be allowed for an empty buffer) * Add tests. --------- Co-authored-by: Nikita Mikhaylov <mikhaylovnikitka@gmail.com>
48 lines
1.7 KiB
C++
48 lines
1.7 KiB
C++
#include "ReadBufferFromMemory.h"
|
|
|
|
namespace DB
|
|
{
|
|
namespace ErrorCodes
|
|
{
|
|
extern const int CANNOT_SEEK_THROUGH_FILE;
|
|
extern const int SEEK_POSITION_OUT_OF_BOUND;
|
|
}
|
|
|
|
off_t ReadBufferFromMemory::seek(off_t offset, int whence)
|
|
{
|
|
if (whence == SEEK_SET)
|
|
{
|
|
if (offset >= 0 && internal_buffer.begin() + offset <= internal_buffer.end())
|
|
{
|
|
pos = internal_buffer.begin() + offset;
|
|
working_buffer = internal_buffer; /// We need to restore `working_buffer` in case the position was at EOF before this seek().
|
|
return static_cast<size_t>(pos - internal_buffer.begin());
|
|
}
|
|
else
|
|
throw Exception(ErrorCodes::SEEK_POSITION_OUT_OF_BOUND, "Seek position is out of bounds. Offset: {}, Max: {}",
|
|
offset, std::to_string(static_cast<size_t>(internal_buffer.end() - internal_buffer.begin())));
|
|
}
|
|
else if (whence == SEEK_CUR)
|
|
{
|
|
Position new_pos = pos + offset;
|
|
if (new_pos >= internal_buffer.begin() && new_pos <= internal_buffer.end())
|
|
{
|
|
pos = new_pos;
|
|
working_buffer = internal_buffer; /// We need to restore `working_buffer` in case the position was at EOF before this seek().
|
|
return static_cast<size_t>(pos - internal_buffer.begin());
|
|
}
|
|
else
|
|
throw Exception(ErrorCodes::SEEK_POSITION_OUT_OF_BOUND, "Seek position is out of bounds. Offset: {}, Max: {}",
|
|
offset, std::to_string(static_cast<size_t>(internal_buffer.end() - internal_buffer.begin())));
|
|
}
|
|
else
|
|
throw Exception(ErrorCodes::CANNOT_SEEK_THROUGH_FILE, "Only SEEK_SET and SEEK_CUR seek modes allowed.");
|
|
}
|
|
|
|
off_t ReadBufferFromMemory::getPosition()
|
|
{
|
|
return pos - internal_buffer.begin();
|
|
}
|
|
|
|
}
|