0.4.1 • Published 10 months ago

@produck/crank v0.4.1

Weekly downloads
-
License
MIT
Repository
github
Last release
10 months ago

GitHub Workflow Status (with event) Coveralls branch npm (scoped) npm lerna NPM

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); // 'pass'
});

Usage

Import & Require

As esModule,

import {
	defineEngine, define,
	Extern,
	isToken
} from '@produck/crank';
// Or
import * as Crank from '@produck/crank';

As CommonJS,

const {
	defineEngine, define,
	Extern,
	isToken
} = require('@produck/crank');
// Or
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); // 1
});
0.4.1

10 months ago

0.4.0

10 months ago

0.3.1

10 months ago

0.3.0

10 months ago

0.2.1

10 months ago

0.2.0

10 months ago

0.1.1

10 months ago

0.1.0

10 months ago