ClickHouse/dbms/src/Functions/GatherUtils/IArraySource.h

29 lines
739 B
C++
Raw Normal View History

#pragma once
#include <Columns/ColumnArray.h>
#include <Functions/GatherUtils/ArraySourceVisitor.h>
namespace DB::GatherUtils
{
struct IArraySource
{
virtual ~IArraySource() = default;
virtual size_t getSizeForReserve() const = 0;
virtual const typename ColumnArray::Offsets & getOffsets() const = 0;
virtual size_t getColumnSize() const = 0;
virtual bool isConst() const { return false; }
virtual bool isNullable() const { return false; }
virtual void accept(ArraySourceVisitor &)
{
throw Exception("Accept not implemented for " + demangle(typeid(*this).name()));
}
};
template <typename Derived>
class ArraySourceImpl : public Visitable<Derived, IArraySource, ArraySourceVisitor> {};
}