@apache-arrow/es2015-esm
Advanced tools
Comparing version 0.4.1 to 0.13.0
@@ -9,3 +9,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 }); | ||
@@ -30,7 +29,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 }); | ||
yield pipeline(source, xform, sink).catch(() => state.closed = true); | ||
const transformToString = batchesToString(state, reader.schema); | ||
yield pipeTo(reader.pipe(transformToString), process.stdout, { end: false }).catch(() => state.closed = true); // Handle EPIPE errors | ||
} | ||
@@ -57,2 +53,14 @@ } | ||
}).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); | ||
} | ||
}); | ||
} | ||
function recordBatchReaders(createSourceStream) { | ||
@@ -125,3 +133,2 @@ return tslib_1.__asyncGenerator(this, arguments, function* recordBatchReaders_1() { | ||
return new stream.Transform({ | ||
transform, | ||
encoding: 'utf8', | ||
@@ -141,43 +148,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(); | ||
} | ||
}); | ||
} | ||
@@ -184,0 +191,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 @@ } |
@@ -59,2 +59,4 @@ // Licensed to the Apache Software Foundation (ASF) under one | ||
this._impl.reset(schema); | ||
this._DOMStream = undefined; | ||
this._nodeStream = undefined; | ||
return this; | ||
@@ -61,0 +63,0 @@ } |
{ | ||
"version": "0.4.1", | ||
"version": "0.13.0", | ||
"name": "@apache-arrow/es2015-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
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
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
2083485
19173