52 lines
1.4 KiB
JavaScript
52 lines
1.4 KiB
JavaScript
"use strict";
|
|
|
|
const Parameters = require("./parameters");
|
|
|
|
exports.applyLigationData = function (data, para, argv) {
|
|
const defaultBuildup = {};
|
|
|
|
const hives = {};
|
|
hives["default"] = { caltBuildup: [] };
|
|
for (const gr in data.simple) {
|
|
hives[`ligset-enable-${gr}`] = { appends: { caltBuildup: [data.simple[gr].ligGroup] } };
|
|
hives[`ligset-disable-${gr}`] = { removes: { caltBuildup: [data.simple[gr].ligGroup] } };
|
|
}
|
|
for (const gr in data.composite) {
|
|
const comp = data.composite[gr];
|
|
if (!comp.tag) continue;
|
|
|
|
const ligSets = createBuildup(data.simple, comp.buildup);
|
|
defaultBuildup[comp.tag] = ligSets;
|
|
hives[`ligset-inherit-${gr}`] = { caltBuildup: ligSets };
|
|
}
|
|
|
|
para.ligation = {
|
|
defaultBuildup,
|
|
caltBuildup: []
|
|
};
|
|
if (argv.ligations) {
|
|
if (argv.ligations.inherits)
|
|
Parameters.apply(para.ligation, hives, [`ligset-inherit-${argv.ligations.inherits}`]);
|
|
if (argv.ligations.disables)
|
|
Parameters.apply(
|
|
para.ligation,
|
|
hives,
|
|
argv.ligations.disables.map(x => `ligset-disable-${x}`)
|
|
);
|
|
if (argv.ligations.enables)
|
|
Parameters.apply(
|
|
para.ligation,
|
|
hives,
|
|
argv.ligations.enables.map(x => `ligset-enable-${x}`)
|
|
);
|
|
}
|
|
};
|
|
|
|
function createBuildup(simple, buildup) {
|
|
let ligSet = new Set();
|
|
for (const s of buildup) {
|
|
if (!simple[s]) throw new Error("Cannot find simple ligation group " + s);
|
|
ligSet.add(simple[s].ligGroup);
|
|
}
|
|
return Array.from(ligSet);
|
|
}
|