-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathpx4-logread.js
More file actions
64 lines (56 loc) · 1.71 KB
/
px4-logread.js
File metadata and controls
64 lines (56 loc) · 1.71 KB
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
#! /usr/bin/env node
var fs = require('fs');
var argv = require('minimist')(process.argv.slice(2), {boolean: ['l', 'c', 'j']});
var LogReader = require('./lib/apm-reader.js');
//This seems over complicated....
if (argv._.length === 1 && fs.existsSync(argv._[0])) {
if (argv['l'] === true) {
listMessageTypes();
}
else if (argv['t'] !== undefined) {
if (argv['j']) {
outputJSON();
} else {
outputCSV();
}
} else {
showHelp();
}
} else {
if (argv._.length === 0) {
showHelp();
} else {
console.log('File does not exist:%s', argv._[0]);
}
}
function showHelp() {
console.log('Usage: px4-logreader %filename%');
console.log('Options:');
console.log(' -l list format types');
console.log(' -c output CSV (default');
console.log(' -j output json');
console.log(' -t type to extract (i.e. IMS,CURR');
}
function listMessageTypes() {
var msgFormats = LogReader.readTypesFromFile(argv._[0]);
var keys = Object.keys(msgFormats);
for (var i = 0; i < keys.length; i++) {
console.log('%s: %s', keys[i], msgFormats[keys[i]].params);
}
}
function outputJSON() {
var messages = LogReader.readMessagesFromFile(argv._[0], argv['t']);
console.log(JSON.stringify(messages, null, '\t'));
}
function outputCSV() {
var messages = LogReader.readMessagesFromFile(argv._[0], argv['t']);
var keys = Object.keys(messages[0]);
console.log(keys.join(','));
for (var i = 0; i < messages.length; i++) {
var values = [];
for (var k = 0; k < keys.length; k++) {
values.push(messages[i][keys[k]]);
}
console.log(values.join(','));
}
}