|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#pragma once |
|
|
|
#include "arrow/status.h" |
|
#include "arrow/type_fwd.h" |
|
#include "arrow/util/visibility.h" |
|
|
|
namespace arrow { |
|
|
|
|
|
|
|
|
|
|
|
class ARROW_EXPORT ArrayVisitor { |
|
public: |
|
virtual ~ArrayVisitor() = default; |
|
|
|
virtual Status Visit(const NullArray& array); |
|
virtual Status Visit(const BooleanArray& array); |
|
virtual Status Visit(const Int8Array& array); |
|
virtual Status Visit(const Int16Array& array); |
|
virtual Status Visit(const Int32Array& array); |
|
virtual Status Visit(const Int64Array& array); |
|
virtual Status Visit(const UInt8Array& array); |
|
virtual Status Visit(const UInt16Array& array); |
|
virtual Status Visit(const UInt32Array& array); |
|
virtual Status Visit(const UInt64Array& array); |
|
virtual Status Visit(const HalfFloatArray& array); |
|
virtual Status Visit(const FloatArray& array); |
|
virtual Status Visit(const DoubleArray& array); |
|
virtual Status Visit(const StringArray& array); |
|
virtual Status Visit(const StringViewArray& array); |
|
virtual Status Visit(const BinaryArray& array); |
|
virtual Status Visit(const BinaryViewArray& array); |
|
virtual Status Visit(const LargeStringArray& array); |
|
virtual Status Visit(const LargeBinaryArray& array); |
|
virtual Status Visit(const FixedSizeBinaryArray& array); |
|
virtual Status Visit(const Date32Array& array); |
|
virtual Status Visit(const Date64Array& array); |
|
virtual Status Visit(const Time32Array& array); |
|
virtual Status Visit(const Time64Array& array); |
|
virtual Status Visit(const TimestampArray& array); |
|
virtual Status Visit(const DayTimeIntervalArray& array); |
|
virtual Status Visit(const MonthDayNanoIntervalArray& array); |
|
virtual Status Visit(const MonthIntervalArray& array); |
|
virtual Status Visit(const DurationArray& array); |
|
virtual Status Visit(const Decimal32Array& array); |
|
virtual Status Visit(const Decimal64Array& array); |
|
virtual Status Visit(const Decimal128Array& array); |
|
virtual Status Visit(const Decimal256Array& array); |
|
virtual Status Visit(const ListArray& array); |
|
virtual Status Visit(const LargeListArray& array); |
|
virtual Status Visit(const ListViewArray& array); |
|
virtual Status Visit(const LargeListViewArray& array); |
|
virtual Status Visit(const MapArray& array); |
|
virtual Status Visit(const FixedSizeListArray& array); |
|
virtual Status Visit(const StructArray& array); |
|
virtual Status Visit(const SparseUnionArray& array); |
|
virtual Status Visit(const DenseUnionArray& array); |
|
virtual Status Visit(const DictionaryArray& array); |
|
virtual Status Visit(const RunEndEncodedArray& array); |
|
virtual Status Visit(const ExtensionArray& array); |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
class ARROW_EXPORT TypeVisitor { |
|
public: |
|
virtual ~TypeVisitor() = default; |
|
|
|
virtual Status Visit(const NullType& type); |
|
virtual Status Visit(const BooleanType& type); |
|
virtual Status Visit(const Int8Type& type); |
|
virtual Status Visit(const Int16Type& type); |
|
virtual Status Visit(const Int32Type& type); |
|
virtual Status Visit(const Int64Type& type); |
|
virtual Status Visit(const UInt8Type& type); |
|
virtual Status Visit(const UInt16Type& type); |
|
virtual Status Visit(const UInt32Type& type); |
|
virtual Status Visit(const UInt64Type& type); |
|
virtual Status Visit(const HalfFloatType& type); |
|
virtual Status Visit(const FloatType& type); |
|
virtual Status Visit(const DoubleType& type); |
|
virtual Status Visit(const StringType& type); |
|
virtual Status Visit(const StringViewType& type); |
|
virtual Status Visit(const BinaryType& type); |
|
virtual Status Visit(const BinaryViewType& type); |
|
virtual Status Visit(const LargeStringType& type); |
|
virtual Status Visit(const LargeBinaryType& type); |
|
virtual Status Visit(const FixedSizeBinaryType& type); |
|
virtual Status Visit(const Date64Type& type); |
|
virtual Status Visit(const Date32Type& type); |
|
virtual Status Visit(const Time32Type& type); |
|
virtual Status Visit(const Time64Type& type); |
|
virtual Status Visit(const TimestampType& type); |
|
virtual Status Visit(const MonthDayNanoIntervalType& type); |
|
virtual Status Visit(const MonthIntervalType& type); |
|
virtual Status Visit(const DayTimeIntervalType& type); |
|
virtual Status Visit(const DurationType& type); |
|
virtual Status Visit(const Decimal32Type& type); |
|
virtual Status Visit(const Decimal64Type& type); |
|
virtual Status Visit(const Decimal128Type& type); |
|
virtual Status Visit(const Decimal256Type& type); |
|
virtual Status Visit(const ListType& type); |
|
virtual Status Visit(const LargeListType& type); |
|
virtual Status Visit(const ListViewType& scalar); |
|
virtual Status Visit(const LargeListViewType& scalar); |
|
virtual Status Visit(const MapType& type); |
|
virtual Status Visit(const FixedSizeListType& type); |
|
virtual Status Visit(const StructType& type); |
|
virtual Status Visit(const SparseUnionType& type); |
|
virtual Status Visit(const DenseUnionType& type); |
|
virtual Status Visit(const DictionaryType& type); |
|
virtual Status Visit(const RunEndEncodedType& type); |
|
virtual Status Visit(const ExtensionType& type); |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
class ARROW_EXPORT ScalarVisitor { |
|
public: |
|
virtual ~ScalarVisitor() = default; |
|
|
|
virtual Status Visit(const NullScalar& scalar); |
|
virtual Status Visit(const BooleanScalar& scalar); |
|
virtual Status Visit(const Int8Scalar& scalar); |
|
virtual Status Visit(const Int16Scalar& scalar); |
|
virtual Status Visit(const Int32Scalar& scalar); |
|
virtual Status Visit(const Int64Scalar& scalar); |
|
virtual Status Visit(const UInt8Scalar& scalar); |
|
virtual Status Visit(const UInt16Scalar& scalar); |
|
virtual Status Visit(const UInt32Scalar& scalar); |
|
virtual Status Visit(const UInt64Scalar& scalar); |
|
virtual Status Visit(const HalfFloatScalar& scalar); |
|
virtual Status Visit(const FloatScalar& scalar); |
|
virtual Status Visit(const DoubleScalar& scalar); |
|
virtual Status Visit(const StringScalar& scalar); |
|
virtual Status Visit(const StringViewScalar& scalar); |
|
virtual Status Visit(const BinaryScalar& scalar); |
|
virtual Status Visit(const BinaryViewScalar& scalar); |
|
virtual Status Visit(const LargeStringScalar& scalar); |
|
virtual Status Visit(const LargeBinaryScalar& scalar); |
|
virtual Status Visit(const FixedSizeBinaryScalar& scalar); |
|
virtual Status Visit(const Date64Scalar& scalar); |
|
virtual Status Visit(const Date32Scalar& scalar); |
|
virtual Status Visit(const Time32Scalar& scalar); |
|
virtual Status Visit(const Time64Scalar& scalar); |
|
virtual Status Visit(const TimestampScalar& scalar); |
|
virtual Status Visit(const DayTimeIntervalScalar& scalar); |
|
virtual Status Visit(const MonthDayNanoIntervalScalar& type); |
|
virtual Status Visit(const MonthIntervalScalar& scalar); |
|
virtual Status Visit(const DurationScalar& scalar); |
|
virtual Status Visit(const Decimal32Scalar& scalar); |
|
virtual Status Visit(const Decimal64Scalar& scalar); |
|
virtual Status Visit(const Decimal128Scalar& scalar); |
|
virtual Status Visit(const Decimal256Scalar& scalar); |
|
virtual Status Visit(const ListScalar& scalar); |
|
virtual Status Visit(const LargeListScalar& scalar); |
|
virtual Status Visit(const ListViewScalar& scalar); |
|
virtual Status Visit(const LargeListViewScalar& scalar); |
|
virtual Status Visit(const MapScalar& scalar); |
|
virtual Status Visit(const FixedSizeListScalar& scalar); |
|
virtual Status Visit(const StructScalar& scalar); |
|
virtual Status Visit(const DictionaryScalar& scalar); |
|
virtual Status Visit(const SparseUnionScalar& scalar); |
|
virtual Status Visit(const DenseUnionScalar& scalar); |
|
virtual Status Visit(const RunEndEncodedScalar& scalar); |
|
virtual Status Visit(const ExtensionScalar& scalar); |
|
}; |
|
|
|
} |
|
|