File indexing completed on 2025-08-28 08:26:58
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018 #pragma once
0019
0020 #include "arrow/extension_type.h"
0021 #include "arrow/type.h"
0022
0023 namespace arrow::extension {
0024
0025
0026
0027 class ARROW_EXPORT OpaqueType : public ExtensionType {
0028 public:
0029
0030
0031
0032
0033
0034
0035 explicit OpaqueType(std::shared_ptr<DataType> storage_type, std::string type_name,
0036 std::string vendor_name)
0037 : ExtensionType(std::move(storage_type)),
0038 type_name_(std::move(type_name)),
0039 vendor_name_(std::move(vendor_name)) {}
0040
0041 std::string extension_name() const override { return "arrow.opaque"; }
0042 std::string ToString(bool show_metadata) const override;
0043 bool ExtensionEquals(const ExtensionType& other) const override;
0044 std::string Serialize() const override;
0045 Result<std::shared_ptr<DataType>> Deserialize(
0046 std::shared_ptr<DataType> storage_type,
0047 const std::string& serialized_data) const override;
0048
0049 std::shared_ptr<Array> MakeArray(std::shared_ptr<ArrayData> data) const override;
0050
0051 std::string_view type_name() const { return type_name_; }
0052 std::string_view vendor_name() const { return vendor_name_; }
0053
0054 private:
0055 std::string type_name_;
0056 std::string vendor_name_;
0057 };
0058
0059
0060
0061 class ARROW_EXPORT OpaqueArray : public ExtensionArray {
0062 public:
0063 using ExtensionArray::ExtensionArray;
0064 };
0065
0066
0067 ARROW_EXPORT std::shared_ptr<DataType> opaque(std::shared_ptr<DataType> storage_type,
0068 std::string type_name,
0069 std::string vendor_name);
0070
0071 }