// Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache License, Version 2.0 (the // "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, // software distributed under the License is distributed on an // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY // KIND, either express or implied. See the License for the // specific language governing permissions and limitations // under the License. #include "contrib/libs/apache/arrow_next/cpp/src/arrow/util/compression_internal.h" #include #include #include #include #include "contrib/libs/apache/arrow_next/cpp/src/arrow/result.h" #include "contrib/libs/apache/arrow_next/cpp/src/arrow/status.h" #include "contrib/libs/apache/arrow_next/cpp/src/arrow/util/logging.h" #include "contrib/libs/apache/arrow_next/cpp/src/arrow/util/macros.h" using std::size_t; namespace arrow20 { namespace util { namespace internal { namespace { // ---------------------------------------------------------------------- // Snappy implementation class SnappyCodec : public Codec { public: Result Decompress(int64_t input_len, const uint8_t* input, int64_t output_buffer_len, uint8_t* output_buffer) override { size_t decompressed_size; if (!snappy::GetUncompressedLength(reinterpret_cast(input), static_cast(input_len), &decompressed_size)) { return Status::IOError("Corrupt snappy compressed data."); } if (output_buffer_len < static_cast(decompressed_size)) { return Status::Invalid("Output buffer size (", output_buffer_len, ") must be ", decompressed_size, " or larger."); } if (!snappy::RawUncompress(reinterpret_cast(input), static_cast(input_len), reinterpret_cast(output_buffer))) { return Status::IOError("Corrupt snappy compressed data."); } return static_cast(decompressed_size); } int64_t MaxCompressedLen(int64_t input_len, const uint8_t* ARROW_ARG_UNUSED(input)) override { DCHECK_GE(input_len, 0); return snappy::MaxCompressedLength(static_cast(input_len)); } Result Compress(int64_t input_len, const uint8_t* input, int64_t ARROW_ARG_UNUSED(output_buffer_len), uint8_t* output_buffer) override { size_t output_size; snappy::RawCompress(reinterpret_cast(input), static_cast(input_len), reinterpret_cast(output_buffer), &output_size); return static_cast(output_size); } Result> MakeCompressor() override { return Status::NotImplemented("Streaming compression unsupported with Snappy"); } Result> MakeDecompressor() override { return Status::NotImplemented("Streaming decompression unsupported with Snappy"); } Compression::type compression_type() const override { return Compression::SNAPPY; } int minimum_compression_level() const override { return kUseDefaultCompressionLevel; } int maximum_compression_level() const override { return kUseDefaultCompressionLevel; } int default_compression_level() const override { return kUseDefaultCompressionLevel; } }; } // namespace std::unique_ptr MakeSnappyCodec() { return std::make_unique(); } } // namespace internal } // namespace util } // namespace arrow20