"use strict"; var __extends = (this && this.__extends) || (function () { var extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); var Processor_1 = require("./Processor"); var bluebird_1 = __importDefault(require("bluebird")); var dataClean_1 = require("./dataClean"); var getEol_1 = __importDefault(require("./getEol")); var fileline_1 = require("./fileline"); var util_1 = require("./util"); var rowSplit_1 = require("./rowSplit"); var lineToJson_1 = __importDefault(require("./lineToJson")); var CSVError_1 = __importDefault(require("./CSVError")); var ProcessorLocal = /** @class */ (function (_super) { __extends(ProcessorLocal, _super); function ProcessorLocal() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.rowSplit = new rowSplit_1.RowSplit(_this.converter); _this.eolEmitted = false; _this._needEmitEol = undefined; _this.headEmitted = false; _this._needEmitHead = undefined; return _this; } ProcessorLocal.prototype.flush = function () { var _this = this; if (this.runtime.csvLineBuffer && this.runtime.csvLineBuffer.length > 0) { var buf = this.runtime.csvLineBuffer; this.runtime.csvLineBuffer = undefined; return this.process(buf, true) .then(function (res) { if (_this.runtime.csvLineBuffer && _this.runtime.csvLineBuffer.length > 0) { return bluebird_1.default.reject(CSVError_1.default.unclosed_quote(_this.runtime.parsedLineNumber, _this.runtime.csvLineBuffer.toString())); } else { return bluebird_1.default.resolve(res); } }); } else { return bluebird_1.default.resolve([]); } }; ProcessorLocal.prototype.destroy = function () { return bluebird_1.default.resolve(); }; Object.defineProperty(ProcessorLocal.prototype, "needEmitEol", { get: function () { if (this._needEmitEol === undefined) { this._needEmitEol = this.converter.listeners("eol").length > 0; } return this._needEmitEol; }, enumerable: true, configurable: true }); Object.defineProperty(ProcessorLocal.prototype, "needEmitHead", { get: function () { if (this._needEmitHead === undefined) { this._needEmitHead = this.converter.listeners("header").length > 0; } return this._needEmitHead; }, enumerable: true, configurable: true }); ProcessorLocal.prototype.process = function (chunk, finalChunk) { var _this = this; if (finalChunk === void 0) { finalChunk = false; } var csvString; if (finalChunk) { csvString = chunk.toString(); } else { csvString = dataClean_1.prepareData(chunk, this.converter.parseRuntime); } return bluebird_1.default.resolve() .then(function () { if (_this.runtime.preRawDataHook) { return _this.runtime.preRawDataHook(csvString); } else { return csvString; } }) .then(function (csv) { if (csv && csv.length > 0) { return _this.processCSV(csv, finalChunk); } else { return bluebird_1.default.resolve([]); } }); }; ProcessorLocal.prototype.processCSV = function (csv, finalChunk) { var _this = this; var params = this.params; var runtime = this.runtime; if (!runtime.eol) { getEol_1.default(csv, runtime); } if (this.needEmitEol && !this.eolEmitted && runtime.eol) { this.converter.emit("eol", runtime.eol); this.eolEmitted = true; } // trim csv file has initial blank lines. if (params.ignoreEmpty && !runtime.started) { csv = util_1.trimLeft(csv); } var stringToLineResult = fileline_1.stringToLines(csv, runtime); if (!finalChunk) { this.prependLeftBuf(util_1.bufFromString(stringToLineResult.partial)); } else { stringToLineResult.lines.push(stringToLineResult.partial); stringToLineResult.partial = ""; } if (stringToLineResult.lines.length > 0) { var prom = void 0; if (runtime.preFileLineHook) { prom = this.runPreLineHook(stringToLineResult.lines); } else { prom = bluebird_1.default.resolve(stringToLineResult.lines); } return prom.then(function (lines) { if (!runtime.started && !_this.runtime.headers) { return _this.processDataWithHead(lines); } else { return _this.processCSVBody(lines); } }); } else { return bluebird_1.default.resolve([]); } }; ProcessorLocal.prototype.processDataWithHead = function (lines) { if (this.params.noheader) { if (this.params.headers) { this.runtime.headers = this.params.headers; } else { this.runtime.headers = []; } } else { var left = ""; var headerRow = []; while (lines.length) { var line = left + lines.shift(); var row = this.rowSplit.parse(line); if (row.closed) { headerRow = row.cells; left = ""; break; } else { left = line + getEol_1.default(line, this.runtime); } } this.prependLeftBuf(util_1.bufFromString(left)); if (headerRow.length === 0) { return []; } if (this.params.headers) { this.runtime.headers = this.params.headers; } else { this.runtime.headers = headerRow; } } if (this.runtime.needProcessIgnoreColumn || this.runtime.needProcessIncludeColumn) { this.filterHeader(); } if (this.needEmitHead && !this.headEmitted) { this.converter.emit("header", this.runtime.headers); this.headEmitted = true; } return this.processCSVBody(lines); }; ProcessorLocal.prototype.filterHeader = function () { this.runtime.selectedColumns = []; if (this.runtime.headers) { var headers = this.runtime.headers; for (var i = 0; i < headers.length; i++) { if (this.params.ignoreColumns) { if (this.params.ignoreColumns.test(headers[i])) { if (this.params.includeColumns && this.params.includeColumns.test(headers[i])) { this.runtime.selectedColumns.push(i); } else { continue; } } else { this.runtime.selectedColumns.push(i); } } else if (this.params.includeColumns) { if (this.params.includeColumns.test(headers[i])) { this.runtime.selectedColumns.push(i); } } else { this.runtime.selectedColumns.push(i); } // if (this.params.includeColumns && this.params.includeColumns.test(headers[i])){ // this.runtime.selectedColumns.push(i); // }else{ // if (this.params.ignoreColumns && this.params.ignoreColumns.test(headers[i])){ // continue; // }else{ // if (this.params.ignoreColumns && !this.params.includeColumns){ // this.runtime.selectedColumns.push(i); // } // } // } } this.runtime.headers = util_1.filterArray(this.runtime.headers, this.runtime.selectedColumns); } }; ProcessorLocal.prototype.processCSVBody = function (lines) { if (this.params.output === "line") { return lines; } else { var result = this.rowSplit.parseMultiLines(lines); this.prependLeftBuf(util_1.bufFromString(result.partial)); if (this.params.output === "csv") { return result.rowsCells; } else { return lineToJson_1.default(result.rowsCells, this.converter); } } // var jsonArr = linesToJson(lines.lines, params, this.recordNum); // this.processResult(jsonArr); // this.lastIndex += jsonArr.length; // this.recordNum += jsonArr.length; }; ProcessorLocal.prototype.prependLeftBuf = function (buf) { if (buf) { if (this.runtime.csvLineBuffer) { this.runtime.csvLineBuffer = Buffer.concat([buf, this.runtime.csvLineBuffer]); } else { this.runtime.csvLineBuffer = buf; } } }; ProcessorLocal.prototype.runPreLineHook = function (lines) { var _this = this; return new bluebird_1.default(function (resolve, reject) { processLineHook(lines, _this.runtime, 0, function (err) { if (err) { reject(err); } else { resolve(lines); } }); }); }; return ProcessorLocal; }(Processor_1.Processor)); exports.ProcessorLocal = ProcessorLocal; function processLineHook(lines, runtime, offset, cb) { if (offset >= lines.length) { cb(); } else { if (runtime.preFileLineHook) { var line = lines[offset]; var res = runtime.preFileLineHook(line, runtime.parsedLineNumber + offset); offset++; if (res && res.then) { res.then(function (value) { lines[offset - 1] = value; processLineHook(lines, runtime, offset, cb); }); } else { lines[offset - 1] = res; while (offset < lines.length) { lines[offset] = runtime.preFileLineHook(lines[offset], runtime.parsedLineNumber + offset); offset++; } cb(); } } else { cb(); } } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/src/ProcessorLocal.ts","sources":["/Users/kxiang/work/projects/csv2json/src/ProcessorLocal.ts"],"names":[],"mappings":"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","sourcesContent":["import { Processor, ProcessLineResult } from \"./Processor\";\nimport P from \"bluebird\";\nimport { prepareData } from \"./dataClean\";\nimport getEol from \"./getEol\";\nimport { stringToLines } from \"./fileline\";\nimport { bufFromString, filterArray,trimLeft } from \"./util\";\nimport { RowSplit } from \"./rowSplit\";\nimport lineToJson from \"./lineToJson\";\nimport { ParseRuntime } from \"./ParseRuntime\";\nimport CSVError from \"./CSVError\";\n\n\n\nexport class ProcessorLocal extends Processor {\n  flush(): P<ProcessLineResult[]> {\n    if (this.runtime.csvLineBuffer && this.runtime.csvLineBuffer.length > 0) {\n      const buf = this.runtime.csvLineBuffer;\n      this.runtime.csvLineBuffer = undefined;\n      return this.process(buf, true)\n        .then((res) => {\n          if (this.runtime.csvLineBuffer && this.runtime.csvLineBuffer.length > 0) {\n            return P.reject(CSVError.unclosed_quote(this.runtime.parsedLineNumber, this.runtime.csvLineBuffer.toString()))\n          } else {\n            return P.resolve(res);\n          }\n        })\n    } else {\n      return P.resolve([]);\n    }\n  }\n  destroy(): P<void> {\n    return P.resolve();\n  }\n  private rowSplit: RowSplit = new RowSplit(this.converter);\n  private eolEmitted = false;\n  private _needEmitEol?: boolean = undefined;\n  private get needEmitEol() {\n    if (this._needEmitEol === undefined) {\n      this._needEmitEol = this.converter.listeners(\"eol\").length > 0;\n    }\n    return this._needEmitEol;\n  }\n  private headEmitted = false;\n  private _needEmitHead?: boolean = undefined;\n  private get needEmitHead() {\n    if (this._needEmitHead === undefined) {\n      this._needEmitHead = this.converter.listeners(\"header\").length > 0;\n    }\n    return this._needEmitHead;\n\n  }\n  process(chunk: Buffer, finalChunk = false): P<ProcessLineResult[]> {\n    let csvString: string;\n    if (finalChunk) {\n      csvString = chunk.toString();\n    } else {\n      csvString = prepareData(chunk, this.converter.parseRuntime);\n\n    }\n    return P.resolve()\n      .then(() => {\n        if (this.runtime.preRawDataHook) {\n          return this.runtime.preRawDataHook(csvString);\n        } else {\n          return csvString;\n        }\n      })\n      .then((csv) => {\n        if (csv && csv.length > 0) {\n          return this.processCSV(csv, finalChunk);\n        } else {\n          return P.resolve([]);\n        }\n      })\n  }\n  private processCSV(csv: string, finalChunk: boolean): P<ProcessLineResult[]> {\n    const params = this.params;\n    const runtime = this.runtime;\n    if (!runtime.eol) {\n      getEol(csv, runtime);\n    }\n    if (this.needEmitEol && !this.eolEmitted && runtime.eol) {\n      this.converter.emit(\"eol\", runtime.eol);\n      this.eolEmitted = true;\n    }\n    // trim csv file has initial blank lines.\n    if (params.ignoreEmpty && !runtime.started) {\n      csv = trimLeft(csv);\n    }\n    const stringToLineResult = stringToLines(csv, runtime);\n    if (!finalChunk) {\n      this.prependLeftBuf(bufFromString(stringToLineResult.partial));\n    } else {\n      stringToLineResult.lines.push(stringToLineResult.partial);\n      stringToLineResult.partial = \"\";\n    }\n    if (stringToLineResult.lines.length > 0) {\n      let prom: P<string[]>;\n      if (runtime.preFileLineHook) {\n        prom = this.runPreLineHook(stringToLineResult.lines);\n      } else {\n        prom = P.resolve(stringToLineResult.lines);\n      }\n      return prom.then((lines) => {\n        if (!runtime.started\n          && !this.runtime.headers\n        ) {\n          return this.processDataWithHead(lines);\n        } else {\n          return this.processCSVBody(lines);\n        }\n\n      })\n\n    } else {\n\n      return P.resolve([]);\n    }\n\n  }\n  private processDataWithHead(lines: string[]): ProcessLineResult[] {\n    if (this.params.noheader) {\n      if (this.params.headers) {\n        this.runtime.headers = this.params.headers;\n      } else {\n        this.runtime.headers = [];\n      }\n    } else {\n      let left = \"\";\n      let headerRow: string[] = [];\n      while (lines.length) {\n        const line = left + lines.shift();\n        const row = this.rowSplit.parse(line);\n        if (row.closed) {\n          headerRow = row.cells;\n          left = \"\";\n          break;\n        } else {\n          left = line + getEol(line, this.runtime);\n        }\n      }\n      this.prependLeftBuf(bufFromString(left));\n\n      if (headerRow.length === 0) {\n        return [];\n      }\n      if (this.params.headers) {\n        this.runtime.headers = this.params.headers;\n      } else {\n        this.runtime.headers = headerRow;\n      }\n    }\n    if (this.runtime.needProcessIgnoreColumn || this.runtime.needProcessIncludeColumn) {\n      this.filterHeader();\n    }\n    if (this.needEmitHead && !this.headEmitted) {\n      this.converter.emit(\"header\", this.runtime.headers);\n      this.headEmitted = true;\n    }\n    return this.processCSVBody(lines);\n  }\n  private filterHeader() {\n    this.runtime.selectedColumns = [];\n    if (this.runtime.headers) {\n      const headers = this.runtime.headers;\n      for (let i = 0; i < headers.length; i++) {\n        if (this.params.ignoreColumns) {\n          if (this.params.ignoreColumns.test(headers[i])) {\n            if (this.params.includeColumns && this.params.includeColumns.test(headers[i])) {\n              this.runtime.selectedColumns.push(i);\n            } else {\n              continue;\n            }\n          } else {\n            this.runtime.selectedColumns.push(i);\n          }\n        } else if (this.params.includeColumns) {\n          if (this.params.includeColumns.test(headers[i])) {\n            this.runtime.selectedColumns.push(i);\n          }\n        } else {\n          this.runtime.selectedColumns.push(i);\n        }\n        // if (this.params.includeColumns && this.params.includeColumns.test(headers[i])){\n        //   this.runtime.selectedColumns.push(i);\n        // }else{\n        //   if (this.params.ignoreColumns && this.params.ignoreColumns.test(headers[i])){\n        //     continue;\n        //   }else{\n        //     if (this.params.ignoreColumns && !this.params.includeColumns){\n        //       this.runtime.selectedColumns.push(i);\n        //     }\n\n        //   }\n        // }\n      }\n      this.runtime.headers = filterArray(this.runtime.headers, this.runtime.selectedColumns);\n    }\n\n  }\n  private processCSVBody(lines: string[]): ProcessLineResult[] {\n    if (this.params.output === \"line\") {\n      return lines;\n    } else {\n      const result = this.rowSplit.parseMultiLines(lines);\n      this.prependLeftBuf(bufFromString(result.partial));\n      if (this.params.output === \"csv\") {\n        return result.rowsCells;\n      } else {\n        return lineToJson(result.rowsCells, this.converter);\n      }\n    }\n\n    // var jsonArr = linesToJson(lines.lines, params, this.recordNum);\n    // this.processResult(jsonArr);\n    // this.lastIndex += jsonArr.length;\n    // this.recordNum += jsonArr.length;\n  }\n\n  private prependLeftBuf(buf: Buffer) {\n    if (buf) {\n      if (this.runtime.csvLineBuffer) {\n        this.runtime.csvLineBuffer = Buffer.concat([buf, this.runtime.csvLineBuffer]);\n      } else {\n        this.runtime.csvLineBuffer = buf;\n      }\n    }\n\n  }\n  private runPreLineHook(lines: string[]): P<string[]> {\n    return new P((resolve, reject) => {\n      processLineHook(lines, this.runtime, 0, (err) => {\n        if (err) {\n          reject(err);\n        } else {\n          resolve(lines);\n        }\n      })\n    });\n  }\n}\n\nfunction processLineHook(lines: string[], runtime: ParseRuntime, offset: number,\n  cb: (err?) => void\n) {\n  if (offset >= lines.length) {\n    cb();\n  } else {\n    if (runtime.preFileLineHook) {\n      const line = lines[offset];\n      const res = runtime.preFileLineHook(line, runtime.parsedLineNumber + offset);\n      offset++;\n      if (res && (res as PromiseLike<string>).then) {\n        (res as PromiseLike<string>).then((value) => {\n          lines[offset - 1] = value;\n          processLineHook(lines, runtime, offset, cb);\n        });\n      } else {\n        lines[offset - 1] = res as string;\n        while (offset < lines.length) {\n          lines[offset] = runtime.preFileLineHook(lines[offset], runtime.parsedLineNumber + offset) as string;\n          offset++;\n        }\n        cb();\n      }\n    } else {\n      cb();\n    }\n  }\n}"]}