From f95f01b8952a6df37af9f444fcce3c7f83f27a48 Mon Sep 17 00:00:00 2001 From: d98762625 Date: Tue, 19 Jun 2018 09:08:45 +0100 Subject: [PATCH] Add ability to exclude operations from Node API. Exclude flow control ops --- src/node/config/excludedOperations.mjs | 15 +++++++++++++++ src/node/config/scripts/generateNodeIndex.mjs | 11 +++++++---- 2 files changed, 22 insertions(+), 4 deletions(-) create mode 100644 src/node/config/excludedOperations.mjs diff --git a/src/node/config/excludedOperations.mjs b/src/node/config/excludedOperations.mjs new file mode 100644 index 00000000..28e6cac4 --- /dev/null +++ b/src/node/config/excludedOperations.mjs @@ -0,0 +1,15 @@ +/** + * Operations to exlude from the Node API + * + * @author d98762656 [d98762625@gmail.com] + * @copyright Crown Copyright 2018 + * @license Apache-2.0 + */ +export default [ + "Fork", + "Merge", + "Jump", + "ConditionalJump", + "Label", + "Comment", +]; diff --git a/src/node/config/scripts/generateNodeIndex.mjs b/src/node/config/scripts/generateNodeIndex.mjs index 80b100a2..8998aef4 100644 --- a/src/node/config/scripts/generateNodeIndex.mjs +++ b/src/node/config/scripts/generateNodeIndex.mjs @@ -15,6 +15,9 @@ import fs from "fs"; import path from "path"; import * as operations from "../../../core/operations/index"; import { decapitalise } from "../../apiUtils"; +import excludedOperations from "../excludedOperations"; + +const includedOperations = Object.keys(operations).filter((op => excludedOperations.indexOf(op) === -1)); const dir = path.join(`${process.cwd()}/src/node`); if (!fs.existsSync(dir)) { @@ -40,7 +43,7 @@ import { wrap } from "./apiUtils"; import { `; -Object.keys(operations).forEach((op) => { +includedOperations.forEach((op) => { // prepend with core_ to avoid name collision later. code += ` ${op} as core_${op},\n`; }); @@ -68,7 +71,7 @@ function generateChef() { return { `; -Object.keys(operations).forEach((op) => { +includedOperations.forEach((op) => { code += ` "${decapitalise(op)}": wrap(core_${op}),\n`; }); @@ -78,7 +81,7 @@ code += ` }; const chef = generateChef(); `; -Object.keys(operations).forEach((op) => { +includedOperations.forEach((op) => { code += `const ${decapitalise(op)} = chef.${decapitalise(op)};\n`; }); @@ -88,7 +91,7 @@ export default chef; export { `; -Object.keys(operations).forEach((op) => { +includedOperations.forEach((op) => { code += ` ${decapitalise(op)},\n`; });