@forzalabs/remora 0.1.5-nasco.3 → 0.1.6-nasco.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/Constants.js
CHANGED
|
@@ -34,6 +34,7 @@ const DriverFactory_1 = __importDefault(require("../../drivers/DriverFactory"));
|
|
|
34
34
|
const Helper_1 = __importDefault(require("../../helper/Helper"));
|
|
35
35
|
const Algo_1 = __importDefault(require("../../core/Algo"));
|
|
36
36
|
const Environment_1 = __importDefault(require("../Environment"));
|
|
37
|
+
const Logger_1 = __importDefault(require("../../helper/Logger"));
|
|
37
38
|
class Dataset {
|
|
38
39
|
constructor(name, file, batchSize, executionId) {
|
|
39
40
|
var _a;
|
|
@@ -171,7 +172,8 @@ class Dataset {
|
|
|
171
172
|
}
|
|
172
173
|
}
|
|
173
174
|
catch (error) {
|
|
174
|
-
|
|
175
|
+
Logger_1.default.log(`Error parsing line ${line}\n${lineCount}: ${error}`);
|
|
176
|
+
lineCount++;
|
|
175
177
|
}
|
|
176
178
|
}
|
|
177
179
|
}
|
|
@@ -306,7 +308,7 @@ class Dataset {
|
|
|
306
308
|
}
|
|
307
309
|
}
|
|
308
310
|
catch (error) {
|
|
309
|
-
|
|
311
|
+
Logger_1.default.log(`Error parsing line during sort: ${error}`);
|
|
310
312
|
}
|
|
311
313
|
}
|
|
312
314
|
}
|
|
@@ -537,7 +539,7 @@ class Dataset {
|
|
|
537
539
|
}
|
|
538
540
|
}
|
|
539
541
|
catch (error) {
|
|
540
|
-
|
|
542
|
+
Logger_1.default.log(`Error parsing line ${line}\n${lineCount}: ${error}`);
|
|
541
543
|
}
|
|
542
544
|
}
|
|
543
545
|
}
|
|
@@ -628,7 +630,8 @@ class Dataset {
|
|
|
628
630
|
}
|
|
629
631
|
}
|
|
630
632
|
catch (error) {
|
|
631
|
-
|
|
633
|
+
Logger_1.default.log(`Error parsing line ${line}\n${lineCount}: ${error}`);
|
|
634
|
+
lineCount++;
|
|
632
635
|
}
|
|
633
636
|
}
|
|
634
637
|
}
|
|
@@ -12,7 +12,7 @@ class DatasetRecord {
|
|
|
12
12
|
const parts = row.split(delimiter);
|
|
13
13
|
for (let i = 0; i < dimensions.length; i++) {
|
|
14
14
|
const dim = dimensions[i];
|
|
15
|
-
this._value[dim.name] = TypeCaster_1.default.cast(parts[i], dim.type);
|
|
15
|
+
this._value[dim.name] = TypeCaster_1.default.cast(parts[i], dim.type, dim.format);
|
|
16
16
|
}
|
|
17
17
|
}
|
|
18
18
|
};
|
|
@@ -283,11 +283,11 @@ class TransformationEngineClass {
|
|
|
283
283
|
}
|
|
284
284
|
// Single transformation
|
|
285
285
|
if ('cast' in transformations) {
|
|
286
|
-
const { cast } = transformations;
|
|
286
|
+
const { cast, format } = transformations;
|
|
287
287
|
let oldDimension = dataset.getDimensions().find(x => x.name === field.key);
|
|
288
288
|
if (!oldDimension)
|
|
289
289
|
oldDimension = dataset.getDimensions().find(x => x.key === field.key);
|
|
290
|
-
const newDimension = Object.assign(Object.assign({}, structuredClone(oldDimension)), { type: cast });
|
|
290
|
+
const newDimension = Object.assign(Object.assign({}, structuredClone(oldDimension)), { type: cast, format: format });
|
|
291
291
|
dataset.setSingleDimension(newDimension, oldDimension);
|
|
292
292
|
}
|
|
293
293
|
return dataset;
|
|
@@ -28,11 +28,19 @@ class TypeCasterClass {
|
|
|
28
28
|
case 'datetime':
|
|
29
29
|
case 'date': {
|
|
30
30
|
let dateValue = null;
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
31
|
+
try {
|
|
32
|
+
if (format && typeof value === 'string')
|
|
33
|
+
dateValue = dayjs_1.default.utc(value, format, true).toDate();
|
|
34
|
+
else
|
|
35
|
+
dateValue = new Date(value);
|
|
36
|
+
return dateValue.toISOString();
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
34
39
|
dateValue = new Date(value);
|
|
35
|
-
|
|
40
|
+
if (!isNaN(dateValue))
|
|
41
|
+
return dateValue.toISOString();
|
|
42
|
+
throw new Error(`Error casting "${value}" to date with format "${format}": ${error}`);
|
|
43
|
+
}
|
|
36
44
|
}
|
|
37
45
|
case 'number': {
|
|
38
46
|
if (typeof value === 'number')
|