Pipe : Pipe communication
This module is a non-built-in multi-process pipe communication module. Only allow Privileged Mode system services to use. This module is not commonly used, for EdgerOS internal services only, you can ignore this chapter.
User can use the following code to import the Pipe module.
var Pipe = require('pipe');
Support
The following shows Pipe module APIs available for each permissions.
| User Mode | Privilege Mode | |
|---|---|---|
| Pipe | ● | |
| pipe.fd | ● | |
| pipe.name | ● | |
| pipe.close | ● | |
| pipe.read | ● | |
| pipe.write | ● | |
| pipe.autonomy | ● | 
Pipe Class
new Pipe(name, flags)
- name{String} Pipe name.
- flags{String} Create flags.
- Returns: {Object} Pipe object.
Create a byte-oriented pipe object.
| flags | Description | 
|---|---|
| r | Open or create a pipe for reading. | 
| w | Open or create a pipe for writing. | 
| rw | Open or create a pipe for reading and writing. | 
Since the kernel pipe file only has a read side, iosched will continuously detect readable events. To solve this problem, you can use 'rw' flags to open.
Example
var r = new Pipe('test1', 'r');
var w = new Pipe('test1', 'w');
Pipe Object
pipe.fd()
- Returns: {Integer} Pipe file descriptor.
Get the pipe file descriptor, which can be asynchronous using with iosched module.
This file descriptor is only used for asynchronous event detection and is only used for current tasks.
pipe.name()
- Returns: {String} Pipe file full name.
Get the full file name of the pipe, The full file name can be passed as a standard output parameter to the newly created process for intercepting the new process standard output.
Example
var r = new Pipe('test1', 'r');
// Pipe full name.
var stdout = r.name();
console.log(stdout);
process.spawn('./chlid.js', ['./chlid.js', '-o', `${stdout}`]);
pipe.close()
Close the pipe. If it is the standard output of other processes, do not close the pipe reader before the target process ends.
pipe.read(buffer[, offset[, length[, timeout]]])
- buffer{Buffer} Receive buffer.
- offset{Integer} Buffer offset. default:0.
- length{Integer} Receive length limit. default:buffer.length.
- timeout{Integer} Wait timeout in milliseconds. default: undefined means wait forever.
- Returns: {Integer} The number of bytes actually receive, negative error.
To read the data of the pipe, you must ensure that the current pipeline is opened in read mode.
Example
var buffer = new Buffer(64);
// Read 64 bytes, return actually read number of bytes.
var num = pipe.read(buffer);
pipe.write(string[, timeout])
- string{String} String to be send.
- timeout{Integer} Wait timeout in milliseconds. default: undefined means wait forever.
- Returns: {Integer} The number of bytes actually sent, negative error.
Write data to the pipe, you must ensure that the current pipe is opened in write mode.
Example
pipe.write('Test string');
pipe.write(buffer[, offset[, length[, timeout]]])
- buffer{Buffer} Write data buffer.
- offset{Integer} Buffer offset. default:0.
- length{Integer} Write length. default:buffer.length.
- timeout{Integer} Wait timeout in milliseconds. default: undefined means wait forever.
- Returns: {Integer} The number of bytes actually sent, negative error.
Write data to the pipe, you must ensure that the current pipe is opened in write mode.
Example
var buf = new Buffer([1, 2, 3]);
pipe.write(buf);
pipe.autonomy(on)
- on{Boolean} Whether to enable autonomy.
- Returns: {Boolean} Whether the operation was successful.
Enabling or disabling autonomy, autonomy ensures that readable event detection does not depend on the presence of a writer.




 陕公网安备61019002002605号
陕公网安备61019002002605号