forked from BV-BRC/p3_mauve
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmauve-parser.js
executable file
·91 lines (73 loc) · 2.05 KB
/
mauve-parser.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
/**
* Helper for parsing xmfa files
*
* Ex:
* node mauve-parser.js -i ../test-data/alignment.xmfa
*
* Author(s):
* nconrad
*
*/
const xmfaParser = require('./xmfa-parser');
const fs = require('fs');
const util = require('util');
const opts = require('commander');
const readFile = util.promisify(fs.readFile);
if (require.main === module) {
opts.option('-i, --input [value]', 'Path to .xmfa')
.parse(process.argv)
main(opts);
}
async function main(opts) {
try {
let data = await parser(opts.input, false, true);
console.log(JSON.stringify(data, null, 4));
} catch(e) {
console.error(e.message);
}
}
async function parser(path, includeSeqs, includeGaps) {
let data = await readFile(path, 'utf-8');
// use parser
let lcbs = xmfaParser.parse(data);
if (includeGaps) {
for (let i=0; i < lcbs.length; i++) {
let regions = lcbs[i];
for (let j=0; j < regions.length; j++ ) {
let region = regions[j];
region.gaps = getGaps(region.seq);
}
}
}
// only includes sequences if requested, remove paths (for now)
if (!includeSeqs) {
for (let i=0; i < lcbs.length; i++) {
let lcb = lcbs[i];
for (let j=0; j < lcb.length; j++ ) {
let region = lcb[j];
let name = region.name;
region.name = name.substr(name.lastIndexOf('/') + 1);
delete region.seq;
}
}
}
return lcbs;
}
function getGaps(sequence) {
let gaps = []
let start, end;
for (let i = 1; i <= sequence.length; i++) {
let nt = sequence.charAt(i-1);
if (!['a','t', 'g', 'c', '-', 'n'].includes(nt.toLowerCase()) ) {
console.error(`invalid char "${nt}" in sequence.`)
}
if (!start && nt === '-') start = i;
if (start && nt !== '-') {
end = i;
gaps.push({start, end});
start = null;
}
}
return gaps;
}
module.exports = parser;