2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
5/// @author Nils Krumnack
8#include <ColumnarCore/ColumnAccessorDataArray.h>
12 // the external mode specialization for native types
13 template<ContainerIdConcept CI,typename CT,ColumnAccessMode CAM,ColumnarArrayMode CM>
14 requires (CI::regularColumnAccessorArray && ColumnTypeTraits<CT,CM>::isNativeType)
15 class AccessorTemplate<CI,CT,CAM,CM> final
17 /// Common Public Members
18 /// =====================
21 static_assert (!std::is_const_v<CT>, "CT must not be const");
23 using ColumnType = typename ColumnAccessModeTraits<CAM>::template ColumnType<typename ColumnTypeTraits<CT,CM>::ColumnType>;
25 AccessorTemplate () noexcept = default;
27 AccessorTemplate (ColumnarTool<CM>& columnBase,
28 const std::string& name, ColumnInfo&& info = {})
30 ColumnTypeTraits<CT,CM>::updateColumnInfo (columnBase, info);
31 info.offsetName = CI::idName;
32 m_accessorData = std::make_unique<ColumnAccessorDataArray> (&m_dataIndex, &m_accessorData, &typeid (typename ColumnTypeTraits<CT,CM>::ColumnType), CAM);
33 columnBase.addColumn (std::string(CI::idName) + "." + name, m_accessorData.get(), std::move (info));
36 AccessorTemplate (AccessorTemplate&& that)
38 moveAccessor (m_dataIndex, m_accessorData, that.m_dataIndex, that.m_accessorData);
41 AccessorTemplate& operator = (AccessorTemplate&& that)
44 moveAccessor (m_dataIndex, m_accessorData, that.m_dataIndex, that.m_accessorData);
48 AccessorTemplate (const AccessorTemplate&) = delete;
49 AccessorTemplate& operator = (const AccessorTemplate&) = delete;
51 void reset (ColumnarTool<CM>& columnBase, const std::string& name, ColumnInfo&& info = {})
53 *this = AccessorTemplate (columnBase, name, std::move (info));
56 [[nodiscard]] ColumnType& operator () (ObjectId<CI,CM> id) const noexcept
58 auto *data = static_cast<ColumnType*>(id.getData()[m_dataIndex]);
59 return data[id.getIndex()];
62 [[nodiscard]] std::span<ColumnType> operator () (ObjectRange<CI,CM> range) const noexcept
64 auto *data = static_cast<ColumnType*>(range.getData()[m_dataIndex]);
65 return std::span<ColumnType> (data+range.beginIndex(), range.endIndex()-range.beginIndex());
68 [[nodiscard]] bool isAvailable (ObjectId<CI,CM> id) const noexcept
70 auto *data = static_cast<ColumnType*>(id.getData()[m_dataIndex]);
71 return data != nullptr;
74 [[nodiscard]] bool isAvailable (const ObjectRange<CI,CM>& range) const noexcept
76 auto *data = static_cast<ColumnType*>(range.getData()[m_dataIndex]);
77 return data != nullptr;
80 [[nodiscard]] std::optional<ColumnType> getOptional (ObjectId<CI,CM> id) const
82 auto *data = static_cast<ColumnType*>(id.getData()[m_dataIndex]);
84 return data[id.getIndex()];
93 unsigned m_dataIndex = 0u;
94 std::unique_ptr<ColumnAccessorDataArray> m_accessorData;