-- Licensed to the Apache Software Foundation (ASF) under one -- or more contributor license agreements. See the NOTICE file -- distributed with this work for additional information -- regarding copyright ownership. The ASF licenses this file -- to you under the Apache License, Version 2.0 (the -- "License"); you may not use this file except in compliance -- with the License. You may obtain a copy of the License at -- -- http://www.apache.org/licenses/LICENSE-2.0 -- -- Unless required by applicable law or agreed to in writing, -- software distributed under the License is distributed on an -- "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY -- KIND, either express or implied. See the License for the -- specific language governing permissions and limitations -- under the License. local lgi = require 'lgi' local Arrow = lgi.Arrow local input_path = arg[1] or "/tmp/stream.arrow"; local input = Arrow.MemoryMappedInputStream.new(input_path) local reader = Arrow.RecordBatchStreamReader.new(input) local i = 0 while true do local record_batch = reader:read_next() if not record_batch then break end print(string.rep("=", 40)) print("record-batch["..i.."]:") for j = 0, record_batch:get_n_columns() - 1 do local column_name = record_batch:get_column_name(j) local column_data = record_batch:get_column_data(j) io.write(" "..column_name..": [") for k = 0, record_batch:get_n_rows() - 1 do if k > 0 then io.write(", ") end io.write(column_data:get_value(k)) end print("]") end i = i + 1 end input:close()