Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

coproq

Package Overview
Dependencies
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

coproq

message-passing coprocesses wrapped in OO syntax

  • 0.1.2
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
1
Maintainers
1
Weekly downloads
 
Created
Source

Coprocess

Build Status Coverage Status Coverage Status

Inter-process RPC wrapped in OO syntax.

var coprocess = require('coprocess');

// create a worker process
var coproc = coprocess.fork(function() {
    // worker must load its depencies as if in a separate file
    var Coprocess = require("coprocess").Coprocess;
    new Coprocess().listen({
        echo: function(x, cb) { cb(null, x) },
    });
});

// call the worker, wait for its response
coproc.call('echo', 1234, function(err, reponse) {
    // => err: null, response: 1234
});

Api

coprocess.fork( scriptName | functionBody [,cb] )

Create a new parent / worker object pair. Returns the parent object used to talk to the worker. The worker process launched running the named scriptName or the function functionBody. The callback cb is invoked as soon as the process is running, not after it's initialized. The worker process is killed when the parent process exits.

Script file names are relative to the current working directory, not the source file.

Functions are converted to source and saved to temporary files in the current directory ./node-coprocess-XXXXXX.js and get removed automatically when the parent process calls its process.on('exit') listeners. Worker functions are a convenience, they share no context with the parent function. They must load and initialize all their dependencies as if they were in their own file.

fork throws if unable to create the worker. The optional callback is invoked once the worker process is running.

var coproces = require('coprocess');
var coproc = coprocess.fork("./scripts/test.js");

coproc.close( [cb(err)] )

Terminate the worker process, either by disconnecting from it or killing it.

coproc.call( method [, arg [...]], callback(err, result) )

Invoke the named method with the given argument(s), and wait for the results. The callback will be invoked with the returned result once the call completes.

coproc.emit( event [, value [...]] )

Emit a named event and optional value(s) to the registered event listener. Events are sent back-to-back in order, no response is returned or expected. Note that events and calls are sent and dispatched in order, so receipt of a batch of events can be confirmed with a single call after the batch.

coproc.listen( event, handler(value [, ...]) )

Listen for named events emitted by the remote. The handler function is called with the received arguments whenever the named event is received.

coproc.listen('stats', function(stats) {
    // received another batch of stats, no response expected
})

coproc.listen( methods )

Register handlers for the calls in the methods name-value hash. Each handler function is provided a callback as its last argument, and must call it to signal completion and return an error or a result back to the caller. If completion signaling is not needed, it is faster to emit events.

coproc.listen({
    ping: function(cb) { cb(null) },
    echo: function(value, cb) { cb(null, value) },
})

Message Formats

Call

{ id, name, argc, argv }

Response

{ id, result }

Event

{ name, argc, argv }

Keywords

FAQs

Package last updated on 04 Jun 2022

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