forked from pelias/pbf2json
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
102 lines (83 loc) · 2.5 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
var util = require('util'),
path = require('path'),
os = require('os'),
split = require('split'),
through = require('through2'),
child = require('child_process'),
exec = path.join(__dirname, 'build', util.format( 'pbf2json.%s-%s', os.platform(), os.arch() ) ),
generateParams = require('./lib/generateParams');
// custom log levels can be detected for lines with the format:
// [level] message
// supported levels (listed from least verbose to most verbose):
// error, warn, info
function getLogLevel( line ){
if( line.indexOf('[warn]') > -1 ){ return 1; }
if( line.indexOf('[info]') > -1 ){ return 2; }
return 0;
}
function errorHandler( name, level ){
return function( data ){
data.toString('utf8').trim().split('\n').forEach( function( line ){
if( getLogLevel( line ) <= level ){
console.error( util.format( '[%s]:', name ), line );
}
});
};
}
function createReadStream( config ){
const params = generateParams(config);
var proc = child.spawn( exec, params );
// propagate signals from parent to child
process.on('SIGINT', function(){ proc.kill(); });
process.on('SIGTERM', function(){ proc.kill(); });
var decoder = createJsonDecodeStream();
proc.stdout
.pipe( split() )
.pipe( through( function( chunk, enc, next ){
var str = chunk.toString('utf8'); // convert buffers to strings
// remove empty lines
if( 'string' === typeof str && str.length ){
this.push( str );
}
next();
}))
.pipe( decoder );
// print error and exit on decoder pipeline error
decoder.on( 'error', errorHandler( 'decoder', config.loglevel || 0 ) );
// print error and exit on stderr
proc.stderr.on( 'data', errorHandler( 'pbf2json', config.loglevel || 0 ) );
// terminate the process and pipeline
decoder.kill = function(){
proc.kill();
decoder.end();
};
return decoder;
}
function createJsonDecodeStream(){
return through.obj( function( str, enc, next ){
try {
var o = parseJsonStr(str, enc);
if( o ){ this.push( o ); }
}
catch( e ){
this.emit( 'error', e );
}
finally {
next();
}
});
}
const idPattern = /"id":(\d+),/;
function parseJsonStr(str, enc) {
var parsedStr = str.toString(enc);
return JSON.parse(parsedStr, (key, value) => {
if( key === 'id' ) {
const match = parsedStr.match(idPattern);
if (match) {
return String(match[1]);
}
}
return value;
});
}
module.exports.createReadStream = createReadStream;