@apache-arrow/esnext-esm
Advanced tools
Comparing version 0.4.1 to 0.13.0
@@ -8,3 +8,2 @@ #! /usr/bin/env node | ||
const bignumJSONParse = require('json-bignum').parse; | ||
const pipeline = require('util').promisify(stream.pipeline); | ||
const argv = require(`command-line-args`)(cliOpts(), { partial: true }); | ||
@@ -26,7 +25,4 @@ const files = argv.help ? [] : [...(argv.file || []), ...(argv._unknown || [])].filter(Boolean); | ||
hasReaders = true; | ||
const source = reader.toNodeStream(); | ||
const xform = batchesToString(state, reader.schema); | ||
const sink = new stream.PassThrough(); | ||
sink.pipe(process.stdout, { end: false }); | ||
await pipeline(source, xform, sink).catch(() => state.closed = true); | ||
const transformToString = batchesToString(state, reader.schema); | ||
await pipeTo(reader.pipe(transformToString), process.stdout, { end: false }).catch(() => state.closed = true); // Handle EPIPE errors | ||
} | ||
@@ -45,2 +41,14 @@ if (state.closed) { | ||
}).then((code) => process.exit(code)); | ||
function pipeTo(source, sink, opts) { | ||
return new Promise((resolve, reject) => { | ||
source.on('end', onEnd).pipe(sink, opts).on('error', onErr); | ||
function onEnd() { done(undefined, resolve); } | ||
function onErr(err) { done(err, reject); } | ||
function done(e, cb) { | ||
source.removeListener('end', onEnd); | ||
sink.removeListener('error', onErr); | ||
cb(e); | ||
} | ||
}); | ||
} | ||
async function* recordBatchReaders(createSourceStream) { | ||
@@ -90,3 +98,2 @@ let json = new AsyncByteQueue(); | ||
return new stream.Transform({ | ||
transform, | ||
encoding: 'utf8', | ||
@@ -106,43 +113,43 @@ writableObjectMode: true, | ||
cb(); | ||
} | ||
}); | ||
function transform(batch, _enc, cb) { | ||
batch = !(state.schema && state.schema.length) ? batch : batch.select(...state.schema); | ||
if (state.closed) { | ||
return cb(undefined, null); | ||
} | ||
// Pass one to convert to strings and count max column widths | ||
state.maxColWidths = measureColumnWidths(rowId, batch, header.map((x, i) => Math.max(maxColWidths[i] || 0, x.length))); | ||
// If this is the first batch in a stream, print a top horizontal rule, schema metadata, and | ||
if (++batchId === 0) { | ||
this.push(`${horizontalRule(state.maxColWidths, hr, sep)}\n`); | ||
if (state.metadata && batch.schema.metadata.size > 0) { | ||
this.push(`metadata:\n${formatMetadata(batch.schema.metadata)}\n`); | ||
}, | ||
transform(batch, _enc, cb) { | ||
batch = !(state.schema && state.schema.length) ? batch : batch.select(...state.schema); | ||
if (state.closed) { | ||
return cb(undefined, null); | ||
} | ||
// Pass one to convert to strings and count max column widths | ||
state.maxColWidths = measureColumnWidths(rowId, batch, header.map((x, i) => Math.max(maxColWidths[i] || 0, x.length))); | ||
// If this is the first batch in a stream, print a top horizontal rule, schema metadata, and | ||
if (++batchId === 0) { | ||
this.push(`${horizontalRule(state.maxColWidths, hr, sep)}\n`); | ||
if (state.metadata && batch.schema.metadata.size > 0) { | ||
this.push(`metadata:\n${formatMetadata(batch.schema.metadata)}\n`); | ||
this.push(`${horizontalRule(state.maxColWidths, hr, sep)}\n`); | ||
} | ||
if (batch.length <= 0 || batch.numCols <= 0) { | ||
this.push(`${formatRow(header, maxColWidths = state.maxColWidths, sep)}\n`); | ||
} | ||
} | ||
if (batch.length <= 0 || batch.numCols <= 0) { | ||
this.push(`${formatRow(header, maxColWidths = state.maxColWidths, sep)}\n`); | ||
} | ||
} | ||
if (batch.length > 0 && batch.numCols > 0) { | ||
// If any of the column widths changed, print the header again | ||
if (rowId % 350 !== 0 && JSON.stringify(state.maxColWidths) !== JSON.stringify(maxColWidths)) { | ||
this.push(`${formatRow(header, state.maxColWidths, sep)}\n`); | ||
} | ||
maxColWidths = state.maxColWidths; | ||
for (const row of batch) { | ||
if (state.closed) { | ||
break; | ||
if (batch.length > 0 && batch.numCols > 0) { | ||
// If any of the column widths changed, print the header again | ||
if (rowId % 350 !== 0 && JSON.stringify(state.maxColWidths) !== JSON.stringify(maxColWidths)) { | ||
this.push(`${formatRow(header, state.maxColWidths, sep)}\n`); | ||
} | ||
else if (!row) { | ||
continue; | ||
maxColWidths = state.maxColWidths; | ||
for (const row of batch) { | ||
if (state.closed) { | ||
break; | ||
} | ||
else if (!row) { | ||
continue; | ||
} | ||
if (rowId++ % 350 === 0) { | ||
this.push(`${formatRow(header, maxColWidths, sep)}\n`); | ||
} | ||
this.push(`${formatRow([rowId, ...row].map(valueToString), maxColWidths, sep)}\n`); | ||
} | ||
if (rowId++ % 350 === 0) { | ||
this.push(`${formatRow(header, maxColWidths, sep)}\n`); | ||
} | ||
this.push(`${formatRow([rowId, ...row].map(valueToString), maxColWidths, sep)}\n`); | ||
} | ||
cb(); | ||
} | ||
cb(); | ||
} | ||
}); | ||
} | ||
@@ -149,0 +156,0 @@ function horizontalRule(maxColWidths, hr = '-', sep = ' |') { |
@@ -62,5 +62,5 @@ /// <reference types="node" /> | ||
}, options?: PipeOptions): ReadableStream<any>; | ||
private _DOMStream?; | ||
protected _DOMStream?: ReadableStream<T>; | ||
private _getDOMStream; | ||
private _nodeStream?; | ||
protected _nodeStream?: import('stream').Readable; | ||
private _getNodeStream; | ||
@@ -67,0 +67,0 @@ } |
@@ -58,2 +58,4 @@ // Licensed to the Apache Software Foundation (ASF) under one | ||
this._impl.reset(schema); | ||
this._DOMStream = undefined; | ||
this._nodeStream = undefined; | ||
return this; | ||
@@ -60,0 +62,0 @@ } |
{ | ||
"version": "0.4.1", | ||
"version": "0.13.0", | ||
"name": "@apache-arrow/esnext-esm", | ||
@@ -4,0 +4,0 @@ "browser": "Arrow.dom.js", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
2070276
18963