28#include <unordered_map>
29#include <unordered_set>
32#include "iceberg/iceberg_export.h"
33#include "iceberg/result.h"
43 std::unordered_set<std::string>
names;
53using MappedFieldConstRef = std::reference_wrapper<const MappedField>;
61 static std::unique_ptr<MappedFields> Make(std::vector<MappedField> fields);
66 std::optional<MappedFieldConstRef> Field(int32_t
id)
const;
71 std::optional<int32_t> Id(std::string_view name)
const;
77 std::span<const MappedField> fields()
const;
84 const std::unordered_map<std::string_view, int32_t>& LazyNameToId()
const;
85 const std::unordered_map<int32_t, MappedFieldConstRef>& LazyIdToField()
const;
88 std::vector<MappedField> fields_;
91 mutable std::unordered_map<std::string_view, int32_t> name_to_id_;
92 mutable std::unordered_map<int32_t, MappedFieldConstRef> id_to_field_;
99 static std::unique_ptr<NameMapping> Make(std::unique_ptr<MappedFields> fields);
102 static std::unique_ptr<NameMapping> Make(std::vector<MappedField> fields);
105 static std::unique_ptr<NameMapping> MakeEmpty();
108 std::optional<MappedFieldConstRef> Find(int32_t
id)
const;
111 std::optional<MappedFieldConstRef> Find(std::span<const std::string> names)
const;
114 std::optional<MappedFieldConstRef> Find(
const std::string& name)
const;
122 explicit NameMapping(std::unique_ptr<MappedFields> mapping);
124 const std::unordered_map<int32_t, MappedFieldConstRef>& LazyFieldsById()
const;
125 const std::unordered_map<std::string, MappedFieldConstRef>& LazyFieldsByName()
const;
128 std::unique_ptr<MappedFields> mapping_;
131 mutable std::unordered_map<int32_t, MappedFieldConstRef> fields_by_id_;
132 mutable std::unordered_map<std::string, MappedFieldConstRef> fields_by_name_;
135ICEBERG_EXPORT std::string ToString(
const MappedField& field);
136ICEBERG_EXPORT std::string ToString(
const MappedFields& fields);
137ICEBERG_EXPORT std::string ToString(
const NameMapping& mapping);
145ICEBERG_EXPORT Result<std::unique_ptr<NameMapping>> CreateMapping(
const Schema& schema);
153ICEBERG_EXPORT Result<std::unique_ptr<NameMapping>> UpdateMapping(
155 const std::unordered_map<int32_t, std::shared_ptr<SchemaField>>& updates,
156 const std::multimap<int32_t, int32_t>& adds);
A list of field mappings for child field of structs, maps, and lists.
Definition name_mapping.h:56
Represents a mapping from external schema names to Iceberg type IDs.
Definition name_mapping.h:96
A schema for a Table.
Definition schema.h:49
An immutable mapping between a field ID and a set of names.
Definition name_mapping.h:41
std::shared_ptr< class MappedFields > nested_mapping
An optional list of field mappings for child field of structs, maps, and lists.
Definition name_mapping.h:48
std::optional< int32_t > field_id
An optional Iceberg field ID used when a field's name is present in names.
Definition name_mapping.h:45
std::unordered_set< std::string > names
A required list of 0 or more names for a field.
Definition name_mapping.h:43