WME/aufgabe5/node_modules/csvtojson/.ts-node/46be5da2105bfdf13e8db086405c89f751746b6e7f1dbb5a5600bad96af1b73b/994c8b0ade8061fb63db45ab25baaf68e9e74f24d69965986f1dfd58764d8f18.js

223 lines
No EOL
27 KiB
JavaScript

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
var getEol_1 = __importDefault(require("./getEol"));
var util_1 = require("./util");
var defaulDelimiters = [",", "|", "\t", ";", ":"];
var RowSplit = /** @class */ (function () {
function RowSplit(conv) {
this.conv = conv;
this.cachedRegExp = {};
this.delimiterEmitted = false;
this._needEmitDelimiter = undefined;
this.quote = conv.parseParam.quote;
this.trim = conv.parseParam.trim;
this.escape = conv.parseParam.escape;
}
Object.defineProperty(RowSplit.prototype, "needEmitDelimiter", {
get: function () {
if (this._needEmitDelimiter === undefined) {
this._needEmitDelimiter = this.conv.listeners("delimiter").length > 0;
}
return this._needEmitDelimiter;
},
enumerable: true,
configurable: true
});
RowSplit.prototype.parse = function (fileline) {
if (fileline.length === 0 || (this.conv.parseParam.ignoreEmpty && fileline.trim().length === 0)) {
return { cells: [], closed: true };
}
var quote = this.quote;
var trim = this.trim;
var escape = this.escape;
if (this.conv.parseRuntime.delimiter instanceof Array || this.conv.parseRuntime.delimiter.toLowerCase() === "auto") {
this.conv.parseRuntime.delimiter = this.getDelimiter(fileline);
}
if (this.needEmitDelimiter && !this.delimiterEmitted) {
this.conv.emit("delimiter", this.conv.parseRuntime.delimiter);
this.delimiterEmitted = true;
}
var delimiter = this.conv.parseRuntime.delimiter;
var rowArr = fileline.split(delimiter);
if (quote === "off") {
if (trim) {
for (var i = 0; i < rowArr.length; i++) {
rowArr[i] = rowArr[i].trim();
}
}
return { cells: rowArr, closed: true };
}
else {
return this.toCSVRow(rowArr, trim, quote, delimiter);
}
};
RowSplit.prototype.toCSVRow = function (rowArr, trim, quote, delimiter) {
var row = [];
var inquote = false;
var quoteBuff = '';
for (var i = 0, rowLen = rowArr.length; i < rowLen; i++) {
var e = rowArr[i];
if (!inquote && trim) {
e = util_1.trimLeft(e);
}
var len = e.length;
if (!inquote) {
if (len === 2 && e === this.quote + this.quote) {
row.push("");
continue;
}
else if (this.isQuoteOpen(e)) { //quote open
e = e.substr(1);
if (this.isQuoteClose(e)) { //quote close
e = e.substring(0, e.lastIndexOf(quote));
e = this.escapeQuote(e);
row.push(e);
continue;
}
else if (e.indexOf(quote) !== -1) {
var count = 0;
for (var _i = 0, e_1 = e; _i < e_1.length; _i++) {
var c = e_1[_i];
if (c === quote) {
count++;
}
}
if (count % 2 === 1) {
if (trim) {
e = util_1.trimRight(e);
}
row.push(quote + e);
continue;
}
else {
inquote = true;
quoteBuff += e;
continue;
}
}
else {
inquote = true;
quoteBuff += e;
continue;
}
}
else {
if (trim) {
e = util_1.trimRight(e);
}
row.push(e);
continue;
}
}
else { //previous quote not closed
if (this.isQuoteClose(e)) { //close double quote
inquote = false;
e = e.substr(0, len - 1);
quoteBuff += delimiter + e;
quoteBuff = this.escapeQuote(quoteBuff);
if (trim) {
quoteBuff = util_1.trimRight(quoteBuff);
}
row.push(quoteBuff);
quoteBuff = "";
}
else {
quoteBuff += delimiter + e;
}
}
}
// if (!inquote && param._needFilterRow) {
// row = filterRow(row, param);
// }
return { cells: row, closed: !inquote };
};
RowSplit.prototype.getDelimiter = function (fileline) {
var checker;
if (this.conv.parseParam.delimiter === "auto") {
checker = defaulDelimiters;
}
else if (this.conv.parseParam.delimiter instanceof Array) {
checker = this.conv.parseParam.delimiter;
}
else {
return this.conv.parseParam.delimiter;
}
var count = 0;
var rtn = ",";
checker.forEach(function (delim) {
var delimCount = fileline.split(delim).length;
if (delimCount > count) {
rtn = delim;
count = delimCount;
}
});
return rtn;
};
RowSplit.prototype.isQuoteOpen = function (str) {
var quote = this.quote;
var escape = this.escape;
return str[0] === quote && (str[1] !== quote ||
str[1] === escape && (str[2] === quote || str.length === 2));
};
RowSplit.prototype.isQuoteClose = function (str) {
var quote = this.quote;
var escape = this.escape;
if (this.conv.parseParam.trim) {
str = util_1.trimRight(str);
}
var count = 0;
var idx = str.length - 1;
while (str[idx] === quote || str[idx] === escape) {
idx--;
count++;
}
return count % 2 !== 0;
};
// private twoDoubleQuote(str: string): string {
// var twoQuote = this.quote + this.quote;
// var curIndex = -1;
// while ((curIndex = str.indexOf(twoQuote, curIndex)) > -1) {
// str = str.substring(0, curIndex) + str.substring(++curIndex);
// }
// return str;
// }
RowSplit.prototype.escapeQuote = function (segment) {
var key = "es|" + this.quote + "|" + this.escape;
if (this.cachedRegExp[key] === undefined) {
this.cachedRegExp[key] = new RegExp('\\' + this.escape + '\\' + this.quote, 'g');
}
var regExp = this.cachedRegExp[key];
// console.log(regExp,segment);
return segment.replace(regExp, this.quote);
};
RowSplit.prototype.parseMultiLines = function (lines) {
var csvLines = [];
var left = "";
while (lines.length) {
var line = left + lines.shift();
var row = this.parse(line);
if (row.cells.length === 0 && this.conv.parseParam.ignoreEmpty) {
continue;
}
if (row.closed || this.conv.parseParam.alwaysSplitAtEOL) {
if (this.conv.parseRuntime.selectedColumns) {
csvLines.push(util_1.filterArray(row.cells, this.conv.parseRuntime.selectedColumns));
}
else {
csvLines.push(row.cells);
}
left = "";
}
else {
left = line + (getEol_1.default(line, this.conv.parseRuntime) || "\n");
}
}
return { rowsCells: csvLines, partial: left };
};
return RowSplit;
}());
exports.RowSplit = RowSplit;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/src/rowSplit.ts","sources":["/Users/kxiang/work/projects/csv2json/src/rowSplit.ts"],"names":[],"mappings":"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","sourcesContent":["import { CSVParseParam } from \"./Parameters\";\nimport { Converter } from \"./Converter\";\nimport { Fileline } from \"./fileline\";\nimport getEol from \"./getEol\";\nimport { filterArray, trimLeft, trimRight } from \"./util\";\n\nconst defaulDelimiters = [\",\", \"|\", \"\\t\", \";\", \":\"];\nexport class RowSplit {\n  private quote: string;\n  private trim: boolean;\n  private escape: string;\n  private cachedRegExp: { [key: string]: RegExp } = {};\n  private delimiterEmitted = false;\n  private _needEmitDelimiter?: boolean = undefined;\n  private get needEmitDelimiter() {\n    if (this._needEmitDelimiter === undefined) {\n      this._needEmitDelimiter = this.conv.listeners(\"delimiter\").length > 0;\n    }\n    return this._needEmitDelimiter;\n  }\n  constructor(private conv: Converter) {\n    this.quote = conv.parseParam.quote;\n    this.trim = conv.parseParam.trim;\n    this.escape = conv.parseParam.escape;\n  }\n  parse(fileline: Fileline): RowSplitResult {\n    if (fileline.length === 0 || (this.conv.parseParam.ignoreEmpty && fileline.trim().length === 0)) {\n      return { cells: [], closed: true };\n    }\n    const quote = this.quote;\n    const trim = this.trim;\n    const escape = this.escape;\n    if (this.conv.parseRuntime.delimiter instanceof Array || this.conv.parseRuntime.delimiter.toLowerCase() === \"auto\") {\n      this.conv.parseRuntime.delimiter = this.getDelimiter(fileline);\n\n    }\n    if (this.needEmitDelimiter && !this.delimiterEmitted) {\n      this.conv.emit(\"delimiter\", this.conv.parseRuntime.delimiter);\n      this.delimiterEmitted = true;\n    }\n    const delimiter = this.conv.parseRuntime.delimiter;\n    const rowArr = fileline.split(delimiter);\n    if (quote === \"off\") {\n      if (trim) {\n        for (let i = 0; i < rowArr.length; i++) {\n          rowArr[i] = rowArr[i].trim();\n        }\n      }\n      return { cells: rowArr, closed: true };\n    } else {\n      return this.toCSVRow(rowArr, trim, quote, delimiter);\n    }\n\n  }\n  private toCSVRow(rowArr: string[], trim: boolean, quote: string, delimiter: string): RowSplitResult {\n    const row: string[] = [];\n    let inquote = false;\n    let quoteBuff = '';\n    for (let i = 0, rowLen = rowArr.length; i < rowLen; i++) {\n      let e = rowArr[i];\n      if (!inquote && trim) {\n        e = trimLeft(e);\n      }\n      const len = e.length;\n      if (!inquote) {\n        if (len === 2 && e === this.quote + this.quote) {\n          row.push(\"\");\n          continue;\n        } else if (this.isQuoteOpen(e)) { //quote open\n          e = e.substr(1);\n          if (this.isQuoteClose(e)) { //quote close\n            e = e.substring(0, e.lastIndexOf(quote));\n            e = this.escapeQuote(e);\n            row.push(e);\n            continue;\n          } else if (e.indexOf(quote) !== -1) {\n            let count = 0;\n            for (const c of e) {\n              if (c === quote) {\n                count++;\n              }\n            }\n            if (count % 2 === 1) {\n              if (trim) {\n                e = trimRight(e);\n              }\n              row.push(quote + e);\n              continue;\n            }else{\n              inquote = true;\n              quoteBuff += e;\n              continue;  \n            }\n          }\n          else {\n            inquote = true;\n            quoteBuff += e;\n            continue;\n          }\n        } else {\n          if (trim) {\n            e = trimRight(e);\n          }\n          row.push(e);\n          continue;\n        }\n      } else { //previous quote not closed\n        if (this.isQuoteClose(e)) { //close double quote\n          inquote = false;\n          e = e.substr(0, len - 1);\n          quoteBuff += delimiter + e;\n          quoteBuff = this.escapeQuote(quoteBuff);\n          if (trim) {\n            quoteBuff = trimRight(quoteBuff);\n          }\n          row.push(quoteBuff);\n          quoteBuff = \"\";\n        } else {\n          quoteBuff += delimiter + e;\n        }\n      }\n    }\n\n    // if (!inquote && param._needFilterRow) {\n    //   row = filterRow(row, param);\n    // }\n\n    return { cells: row, closed: !inquote };\n  }\n  private getDelimiter(fileline: Fileline): string {\n    let checker;\n    if (this.conv.parseParam.delimiter === \"auto\") {\n      checker = defaulDelimiters;\n    } else if (this.conv.parseParam.delimiter instanceof Array) {\n      checker = this.conv.parseParam.delimiter;\n    } else {\n      return this.conv.parseParam.delimiter;\n    }\n    let count = 0;\n    let rtn = \",\";\n    checker.forEach(function (delim) {\n      const delimCount = fileline.split(delim).length;\n      if (delimCount > count) {\n        rtn = delim;\n        count = delimCount;\n      }\n    });\n    return rtn;\n  }\n  private isQuoteOpen(str: string): boolean {\n    const quote = this.quote;\n    const escape = this.escape;\n    return str[0] === quote && (\n      str[1] !== quote ||\n      str[1] === escape && (str[2] === quote || str.length === 2));\n  }\n  private isQuoteClose(str: string): boolean {\n    const quote = this.quote;\n    const escape = this.escape;\n    if (this.conv.parseParam.trim) {\n      str = trimRight(str);\n    }\n    let count = 0;\n    let idx = str.length - 1;\n    while (str[idx] === quote || str[idx] === escape) {\n      idx--;\n      count++;\n    }\n    return count % 2 !== 0;\n  }\n\n  // private twoDoubleQuote(str: string): string {\n  //   var twoQuote = this.quote + this.quote;\n  //   var curIndex = -1;\n  //   while ((curIndex = str.indexOf(twoQuote, curIndex)) > -1) {\n  //     str = str.substring(0, curIndex) + str.substring(++curIndex);\n  //   }\n  //   return str;\n  // }\n\n\n  private escapeQuote(segment: string): string {\n    const key = \"es|\" + this.quote + \"|\" + this.escape;\n    if (this.cachedRegExp[key] === undefined) {\n      this.cachedRegExp[key] = new RegExp('\\\\' + this.escape + '\\\\' + this.quote, 'g');\n    }\n    const regExp = this.cachedRegExp[key];\n    // console.log(regExp,segment);\n    return segment.replace(regExp, this.quote);\n  }\n  parseMultiLines(lines: Fileline[]): MultipleRowResult {\n    const csvLines: string[][] = [];\n    let left = \"\";\n    while (lines.length) {\n      const line = left + lines.shift();\n      const row = this.parse(line);\n      if (row.cells.length === 0 && this.conv.parseParam.ignoreEmpty) {\n        continue;\n      }\n      if (row.closed || this.conv.parseParam.alwaysSplitAtEOL) {\n        if (this.conv.parseRuntime.selectedColumns) {\n          csvLines.push(filterArray(row.cells, this.conv.parseRuntime.selectedColumns));\n        } else {\n          csvLines.push(row.cells);\n        }\n\n        left = \"\";\n      } else {\n        left = line + (getEol(line, this.conv.parseRuntime) || \"\\n\");\n      }\n    }\n    return { rowsCells: csvLines, partial: left };\n  }\n}\nexport interface MultipleRowResult {\n  rowsCells: string[][];\n  partial: string;\n}\nexport interface RowSplitResult {\n  /**\n   * csv row array. [\"a\",\"b\",\"c\"]\n   */\n  cells: string[],\n  /**\n   * if the passed fileline is a complete row\n   */\n  closed: boolean\n}\n\n"]}