// 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. import { valueToString } from '../util/pretty.mjs'; import { instance as getVisitor } from '../visitor/get.mjs'; import { instance as setVisitor } from '../visitor/set.mjs'; /** @ignore */ const kParent = Symbol.for('parent'); /** @ignore */ const kRowIndex = Symbol.for('rowIndex'); export class StructRow { constructor(parent, rowIndex) { this[kParent] = parent; this[kRowIndex] = rowIndex; return new Proxy(this, new StructRowProxyHandler()); } toArray() { return Object.values(this.toJSON()); } toJSON() { const i = this[kRowIndex]; const parent = this[kParent]; const keys = parent.type.children; const json = {}; for (let j = -1, n = keys.length; ++j < n;) { json[keys[j].name] = getVisitor.visit(parent.children[j], i); } return json; } toString() { return `{${[...this].map(([key, val]) => `${valueToString(key)}: ${valueToString(val)}`).join(', ')}}`; } [Symbol.for('nodejs.util.inspect.custom')]() { return this.toString(); } [Symbol.iterator]() { return new StructRowIterator(this[kParent], this[kRowIndex]); } } class StructRowIterator { constructor(data, rowIndex) { this.childIndex = 0; this.children = data.children; this.rowIndex = rowIndex; this.childFields = data.type.children; this.numChildren = this.childFields.length; } [Symbol.iterator]() { return this; } next() { const i = this.childIndex; if (i < this.numChildren) { this.childIndex = i + 1; return { done: false, value: [ this.childFields[i].name, getVisitor.visit(this.children[i], this.rowIndex) ] }; } return { done: true, value: null }; } } Object.defineProperties(StructRow.prototype, { [Symbol.toStringTag]: { enumerable: false, configurable: false, value: 'Row' }, [kParent]: { writable: true, enumerable: false, configurable: false, value: null }, [kRowIndex]: { writable: true, enumerable: false, configurable: false, value: -1 }, }); class StructRowProxyHandler { isExtensible() { return false; } deleteProperty() { return false; } preventExtensions() { return true; } ownKeys(row) { return row[kParent].type.children.map((f) => f.name); } has(row, key) { return row[kParent].type.children.findIndex((f) => f.name === key) !== -1; } getOwnPropertyDescriptor(row, key) { if (row[kParent].type.children.findIndex((f) => f.name === key) !== -1) { return { writable: true, enumerable: true, configurable: true }; } return; } get(row, key) { // Look up key in row first if (Reflect.has(row, key)) { return row[key]; } const idx = row[kParent].type.children.findIndex((f) => f.name === key); if (idx !== -1) { const val = getVisitor.visit(row[kParent].children[idx], row[kRowIndex]); // Cache key/val lookups Reflect.set(row, key, val); return val; } } set(row, key, val) { const idx = row[kParent].type.children.findIndex((f) => f.name === key); if (idx !== -1) { setVisitor.visit(row[kParent].children[idx], row[kRowIndex], val); // Cache key/val lookups return Reflect.set(row, key, val); } else if (Reflect.has(row, key) || typeof key === 'symbol') { return Reflect.set(row, key, val); } return false; } } //# sourceMappingURL=struct.mjs.map