From 99af2842e4b0deffbe785b745f6eab4e2b5c37d6 Mon Sep 17 00:00:00 2001 From: Pawel Czarnecki Date: Mon, 19 Aug 2024 14:04:28 +0200 Subject: [PATCH] modules/zstd/frame_header_test: Fix absl::Span handling Internal-tag: [#64294] Signed-off-by: Pawel Czarnecki --- xls/modules/zstd/frame_header_test.cc | 33 ++++++++++++++++++++------- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/xls/modules/zstd/frame_header_test.cc b/xls/modules/zstd/frame_header_test.cc index 791789eb1d..0eb8d5dbb8 100644 --- a/xls/modules/zstd/frame_header_test.cc +++ b/xls/modules/zstd/frame_header_test.cc @@ -57,10 +57,22 @@ enum FrameHeaderStatus : uint8_t { UNSUPPORTED_WINDOW_SIZE }; -struct ZstdFrameHeader { - absl::Span kBuffer; - ZSTD_frameHeader kHeader; - size_t kResult; +class ZstdFrameHeader { + public: + absl::Span buffer() const { + return absl::MakeConstSpan(buffer_); + } + + ZSTD_frameHeader header() const { return header_; } + + size_t result() const { return result_; } + + ZstdFrameHeader(absl::Span buffer, ZSTD_frameHeader h, + size_t r) + : header_(std::move(h)), result_(r) { + std::vector v(buffer.begin(), buffer.end()); + buffer_ = v; + } // Parse a frame header from an arbitrary buffer with the ZSTD library. static absl::StatusOr Parse( absl::Span buffer) { @@ -69,8 +81,13 @@ struct ZstdFrameHeader { ZSTD_frameHeader zstd_fh; size_t result = ZSTD_getFrameHeader_advanced( &zstd_fh, buffer.data(), buffer.size(), ZSTD_f_zstd1_magicless); - return ZstdFrameHeader(buffer, zstd_fh, result); + return ZstdFrameHeader(buffer, std::move(zstd_fh), result); } + + private: + std::vector buffer_; + ZSTD_frameHeader header_; + size_t result_; }; class FrameHeaderTest : public xls::IrTestBase { @@ -113,7 +130,7 @@ class FrameHeaderTest : public xls::IrTestBase { // expected values. void RunAndExpectFrameHeader(const ZstdFrameHeader& zstd_frame_header) { // Extend buffer contents to 128 bits if necessary. - const absl::Span& buffer = zstd_frame_header.kBuffer; + const absl::Span buffer = zstd_frame_header.buffer(); std::vector buffer_extended(kDslxBufferSizeBytes, 0); absl::Span input_buffer; if (buffer.size() < kDslxBufferSizeBytes) { @@ -124,8 +141,8 @@ class FrameHeaderTest : public xls::IrTestBase { } // Decide on the expected status - ZSTD_frameHeader zstd_fh = zstd_frame_header.kHeader; - size_t result = zstd_frame_header.kResult; + ZSTD_frameHeader zstd_fh = zstd_frame_header.header(); + size_t result = zstd_frame_header.result(); FrameHeaderStatus expected_status = FrameHeaderStatus::OK; if (result != 0) { if (ZSTD_isError(result)) {