iceberg-cpp
Loading...
Searching...
No Matches
avro_writer.h
1/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
19
20#pragma once
21
22#include "iceberg/file_writer.h"
23#include "iceberg/iceberg_bundle_export.h"
24
25namespace iceberg::avro {
26
28class ICEBERG_BUNDLE_EXPORT AvroWriter : public Writer {
29 public:
30 AvroWriter() = default;
31
32 ~AvroWriter() override;
33
34 Status Open(const WriterOptions& options) final;
35
36 Status Close() final;
37
38 Status Write(ArrowArray* data) final;
39
40 Result<Metrics> metrics() final;
41
42 Result<int64_t> length() final;
43
44 std::vector<int64_t> split_offsets() final;
45
46 private:
47 class Impl;
48 std::unique_ptr<Impl> impl_;
49};
50
51} // namespace iceberg::avro
Base writer class to write data from different file formats.
Definition file_writer.h:85
Definition avro_writer.cc:179
A writer for serializing ArrowArray to Avro files.
Definition avro_writer.h:28
Definition arrow_c_data.h:57
Options for creating a writer.
Definition file_writer.h:71