29#include <unordered_map>
32#include "iceberg/iceberg_export.h"
33#include "iceberg/result.h"
46 virtual Result<std::vector<ManifestEntry>>
Entries() = 0;
65 std::shared_ptr<class PartitionSet> partition_set) = 0;
83 static bool ShouldDropStats(
const std::vector<std::string>& columns);
91 static Result<std::unique_ptr<ManifestReader>> Make(
92 const ManifestFile& manifest, std::shared_ptr<FileIO> file_io,
93 std::shared_ptr<Schema> schema, std::shared_ptr<PartitionSpec> spec);
104 static Result<std::unique_ptr<ManifestReader>> Make(
105 std::string_view manifest_location, std::optional<int64_t> manifest_length,
106 std::shared_ptr<FileIO> file_io, std::shared_ptr<Schema> schema,
107 std::shared_ptr<PartitionSpec> spec,
108 std::unique_ptr<InheritableMetadata> inheritable_metadata,
109 std::optional<int64_t> first_row_id = std::nullopt);
112 static std::vector<std::string> WithStatsColumns(
113 const std::vector<std::string>& columns);
122 virtual Result<std::vector<ManifestFile>>
Files()
const = 0;
125 virtual Result<std::unordered_map<std::string, std::string>>
Metadata()
const = 0;
131 static Result<std::unique_ptr<ManifestListReader>> Make(
132 std::string_view manifest_list_location, std::shared_ptr<FileIO> file_io);
Read manifest files from a manifest list file.
Definition manifest_reader.h:117
virtual Result< std::unordered_map< std::string, std::string > > Metadata() const =0
Get the metadata of the manifest list file.
virtual Result< std::vector< ManifestFile > > Files() const =0
Read all manifest files in the manifest list file.
Read manifest entries from a manifest file.
Definition manifest_reader.h:39
virtual Result< std::vector< ManifestEntry > > Entries()=0
Read all manifest entries in the manifest file.
virtual ManifestReader & FilterRows(std::shared_ptr< Expression > expr)=0
Filter manifest entries by row-level filter.
virtual ManifestReader & Select(const std::vector< std::string > &columns)=0
Select specific columns of data file to read from the manifest entries.
virtual ManifestReader & FilterPartitions(std::shared_ptr< Expression > expr)=0
Filter manifest entries by partition filter.
virtual ManifestReader & FilterPartitions(std::shared_ptr< class PartitionSet > partition_set)=0
Filter manifest entries to a specific set of partitions.
virtual ManifestReader & CaseSensitive(bool case_sensitive)=0
Set case sensitivity for column name matching.
virtual ManifestReader & TryDropStats()=0
Try to drop stats from returned DataFile objects.
virtual Result< std::vector< ManifestEntry > > LiveEntries()=0
Read only live (non-deleted) manifest entries.
Entry in a manifest list.
Definition manifest_list.h:85