"use strict"; // 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. Object.defineProperty(exports, "__esModule", { value: true }); exports.FileBlock = exports.Footer = void 0; const tslib_1 = require("tslib"); /* eslint-disable @typescript-eslint/naming-convention */ const block_js_1 = require("../../fb/block.js"); const footer_js_1 = require("../../fb/footer.js"); const flatbuffers = tslib_1.__importStar(require("flatbuffers")); var Long = flatbuffers.Long; var Builder = flatbuffers.Builder; var ByteBuffer = flatbuffers.ByteBuffer; const schema_js_1 = require("../../schema.js"); const enum_js_1 = require("../../enum.js"); const buffer_js_1 = require("../../util/buffer.js"); /** @ignore */ class Footer_ { constructor(schema, version = enum_js_1.MetadataVersion.V4, recordBatches, dictionaryBatches) { this.schema = schema; this.version = version; recordBatches && (this._recordBatches = recordBatches); dictionaryBatches && (this._dictionaryBatches = dictionaryBatches); } /** @nocollapse */ static decode(buf) { buf = new ByteBuffer((0, buffer_js_1.toUint8Array)(buf)); const footer = footer_js_1.Footer.getRootAsFooter(buf); const schema = schema_js_1.Schema.decode(footer.schema()); return new OffHeapFooter(schema, footer); } /** @nocollapse */ static encode(footer) { const b = new Builder(); const schemaOffset = schema_js_1.Schema.encode(b, footer.schema); footer_js_1.Footer.startRecordBatchesVector(b, footer.numRecordBatches); for (const rb of [...footer.recordBatches()].slice().reverse()) { FileBlock.encode(b, rb); } const recordBatchesOffset = b.endVector(); footer_js_1.Footer.startDictionariesVector(b, footer.numDictionaries); for (const db of [...footer.dictionaryBatches()].slice().reverse()) { FileBlock.encode(b, db); } const dictionaryBatchesOffset = b.endVector(); footer_js_1.Footer.startFooter(b); footer_js_1.Footer.addSchema(b, schemaOffset); footer_js_1.Footer.addVersion(b, enum_js_1.MetadataVersion.V4); footer_js_1.Footer.addRecordBatches(b, recordBatchesOffset); footer_js_1.Footer.addDictionaries(b, dictionaryBatchesOffset); footer_js_1.Footer.finishFooterBuffer(b, footer_js_1.Footer.endFooter(b)); return b.asUint8Array(); } get numRecordBatches() { return this._recordBatches.length; } get numDictionaries() { return this._dictionaryBatches.length; } *recordBatches() { for (let block, i = -1, n = this.numRecordBatches; ++i < n;) { if (block = this.getRecordBatch(i)) { yield block; } } } *dictionaryBatches() { for (let block, i = -1, n = this.numDictionaries; ++i < n;) { if (block = this.getDictionaryBatch(i)) { yield block; } } } getRecordBatch(index) { return index >= 0 && index < this.numRecordBatches && this._recordBatches[index] || null; } getDictionaryBatch(index) { return index >= 0 && index < this.numDictionaries && this._dictionaryBatches[index] || null; } } exports.Footer = Footer_; /** @ignore */ class OffHeapFooter extends Footer_ { constructor(schema, _footer) { super(schema, _footer.version()); this._footer = _footer; } get numRecordBatches() { return this._footer.recordBatchesLength(); } get numDictionaries() { return this._footer.dictionariesLength(); } getRecordBatch(index) { if (index >= 0 && index < this.numRecordBatches) { const fileBlock = this._footer.recordBatches(index); if (fileBlock) { return FileBlock.decode(fileBlock); } } return null; } getDictionaryBatch(index) { if (index >= 0 && index < this.numDictionaries) { const fileBlock = this._footer.dictionaries(index); if (fileBlock) { return FileBlock.decode(fileBlock); } } return null; } } /** @ignore */ class FileBlock { constructor(metaDataLength, bodyLength, offset) { this.metaDataLength = metaDataLength; this.offset = typeof offset === 'number' ? offset : offset.low; this.bodyLength = typeof bodyLength === 'number' ? bodyLength : bodyLength.low; } /** @nocollapse */ static decode(block) { return new FileBlock(block.metaDataLength(), block.bodyLength(), block.offset()); } /** @nocollapse */ static encode(b, fileBlock) { const { metaDataLength } = fileBlock; const offset = new Long(fileBlock.offset, 0); const bodyLength = new Long(fileBlock.bodyLength, 0); return block_js_1.Block.createBlock(b, offset, metaDataLength, bodyLength); } } exports.FileBlock = FileBlock; //# sourceMappingURL=file.js.map