New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@produck/crank

Package Overview
Dependencies
Maintainers
4
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@produck/crank

executor framework

  • 0.4.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
4
Created
Source

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
});

FAQs

Package last updated on 18 Jul 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc