0.0.9 • Published 3 years ago

node-libsharedmemory v0.0.9

Weekly downloads
-
License
MIT
Repository
github
Last release
3 years ago

node-libsharedmemory

node-libsharedmemory is a native Node.js module that is based on libsharedmemory. It can be used to read and write to shared memory on Windows, Linux and macOS. node-libsharedmemory makes it easy to transfer data between isolated host OS processes and Node.js applications. It also helps inter-connecting modules of applications that are implemented in different programming languages.

Example

const {
    NodeSharedMemoryWriteStream,
    NodeSharedMemoryReadStream
} = require("node-libsharedmemory");

// this can happen in other Node.js processes or any other application
// using libsharedmemory to write data
const streamWriter = new NodeSharedMemoryWriteStream();

streamWriter.writeString(`{ remoteApp: { is: 'sending', data: 'ab😃ab😃ab😃' } }`);

const streamReader = new NodeSharedMemoryReadStream();

const data = streamReader.readString();

// data equals the data written via .write() before
console.log('Data received from shared memory', data);

Use

Just install it via:

npm install node-libsharedmemory

The example examples/basic should be pretty self-explanatory.

Limits

libsharedmemory does only support the following datatypes:

  • String (readString, writeString)
  • Float32Array (readFloatArray, writeFloatArray)
  • Float64Array (readDoubleArray, writeDoubleArray)

  • This library doesn't care for endinanness. This should be naturally fine because shared memory shouldn't be shared between different machine architectures. However, if you plan to copy the shared buffer onto a network layer prototcol, make sure to add an endianess indication bit.

  • At the time of writing, there is no support for shared memory persistency on Windows. Shared memory is lost after the writing process is killed.

Build

To re-build the module from source call: npm run rebuild

Test

The module can be tested via: npm test

License

node-libsharedmemory is released under the MIT license, see the LICENSE file.

Roadmap

1) Native onChange() event handling abstraction (currently needs a for-loop change detection in V8) 2) Windows shared memory persistency support

0.0.9

3 years ago

0.0.8

3 years ago

0.0.6

3 years ago

0.0.5

3 years ago

0.0.4

3 years ago

0.0.3

3 years ago

0.0.2

3 years ago

0.0.1

3 years ago