crank
The framework is to generate program execution engine. You should provide executors
, program
and extern
that is customized. By providing as mentioned above, you can customize the functions of engine. And then you will get the result of execution. The execution of program support async function and common functon.
Installation
$ npm install @produck/crank
Examples
import * as Crank from '@produck/crank';
const CustomEngine = Crank.defineEngine({}, {
a: async (process) => {
return 'pass';
},
});
const extern = new CustomEngine.Extern();
const vm = new CustomEngine();
const ret = vm.execute({
*foo() {
return yield this._a();
},
*main() {
return yield this.foo();
},
}, extern).then(value => {
console.log(value);
});
Usage
Import & Require
As esModule,
import {
defineEngine, define,
Extern,
isToken
} from '@produck/crank';
import * as Crank from '@produck/crank';
As CommonJS,
const {
defineEngine, define,
Extern,
isToken
} = require('@produck/crank');
const Crank = require('@produck/crank');
Creating a Engine class by default options
import * as Crank from '@produck/crank';
const Engine = Crank.define();
Creating a Engine class by custom options
You can customize Engine features by custom options.
options.name
: The name of Engine class.
options.call
: Customized the calling of functions.
options.Extern
: Customized Extern, should be subclass of Crank.Extern
.
options.abort
: Customize when to abort the running program.
import * as Crank from '@produck/crank';
const Engine = Crank.define({
name: 'CustomEngine',
call: async (process, nextFrame, next) => await next(),
Extern,
abort: (lastInstruction) => false;
});
Creating a Engine class by custom executors
You can customize Engine functions by custom executors.
The item of executors should be async function or common functon.
import * as Crank from '@produck/crank';
const Engine = Crank.define({}, {
async b() {
return Promise.resolve(1);
},
a() {
return 1;
}
});
Execute a program
You can execute program and get returned value.
The function of program should be GeneratorFunction
or AsyncGeneratorFunction
.
The main
function is required.
The executors should be calling by this._[executorName]
.
The function of program should be calling by this.[functionName]
.
The extern should be the instance of Engine.Extern
.
import * as Crank from '@produck/crank';
const Engine = Crank.define({}, {
a() {
return 1;
}
});
const vm = new Engine();
const program = {
*main() {
return yield this._a();
}
};
const extern = new Engine.Extern();
vm.execute(program, extern).then(val => {
console.log(val);
});