From 1c2298a58b48adf508a7aebfcefe889881175978 Mon Sep 17 00:00:00 2001 From: sendoru Date: Sun, 4 Aug 2024 08:18:14 +0900 Subject: [PATCH 1/4] doc: move `onread` option from `socket.connect()` to `new net.socket()` Fixes: https://github.com/nodejs/node/issues/53792 --- doc/api/net.md | 29 ++++++++++++++--------------- 1 file changed, 14 insertions(+), 15 deletions(-) diff --git a/doc/api/net.md b/doc/api/net.md index 03d29170bc495c..9e4623901cf505 100644 --- a/doc/api/net.md +++ b/doc/api/net.md @@ -667,12 +667,26 @@ changes: `false`. * `fd` {number} If specified, wrap around an existing socket with the given file descriptor, otherwise a new socket will be created. + * `onread` {Object} If specified, incoming data is stored in a single `buffer` + and passed to the supplied `callback` when data arrives on the socket. + This will cause the streaming functionality to not provide any data. + The socket will emit events like `'error'`, `'end'`, and `'close'` + as usual. Methods like `pause()` and `resume()` will also behave as + expected. + * `buffer` {Buffer|Uint8Array|Function} Either a reusable chunk of memory to + use for storing incoming data or a function that returns such. + * `callback` {Function} This function is called for every chunk of incoming + data. Two arguments are passed to it: the number of bytes written to + `buffer` and a reference to `buffer`. Return `false` from this function to + implicitly `pause()` the socket. This function will be executed in the + global context. * `readable` {boolean} Allow reads on the socket when an `fd` is passed, otherwise ignored. **Default:** `false`. * `signal` {AbortSignal} An Abort signal that may be used to destroy the socket. * `writable` {boolean} Allow writes on the socket when an `fd` is passed, otherwise ignored. **Default:** `false`. + * Returns: {net.Socket} Creates a new socket object. @@ -1038,21 +1052,6 @@ For [IPC][] connections, available `options` are: See [Identifying paths for IPC connections][]. If provided, the TCP-specific options above are ignored. -For both types, available `options` include: - -* `onread` {Object} If specified, incoming data is stored in a single `buffer` - and passed to the supplied `callback` when data arrives on the socket. - This will cause the streaming functionality to not provide any data. - The socket will emit events like `'error'`, `'end'`, and `'close'` - as usual. Methods like `pause()` and `resume()` will also behave as - expected. - * `buffer` {Buffer|Uint8Array|Function} Either a reusable chunk of memory to - use for storing incoming data or a function that returns such. - * `callback` {Function} This function is called for every chunk of incoming - data. Two arguments are passed to it: the number of bytes written to - `buffer` and a reference to `buffer`. Return `false` from this function to - implicitly `pause()` the socket. This function will be executed in the - global context. Following is an example of a client using the `onread` option: From 9d1511f03fdfcba4f95749bb4dcea0298fcec3d6 Mon Sep 17 00:00:00 2001 From: sendoru Date: Sun, 4 Aug 2024 08:19:55 +0900 Subject: [PATCH 2/4] doc: remove useless newline --- doc/api/net.md | 1 - 1 file changed, 1 deletion(-) diff --git a/doc/api/net.md b/doc/api/net.md index 9e4623901cf505..fe29d0fb0425f1 100644 --- a/doc/api/net.md +++ b/doc/api/net.md @@ -686,7 +686,6 @@ changes: socket. * `writable` {boolean} Allow writes on the socket when an `fd` is passed, otherwise ignored. **Default:** `false`. - * Returns: {net.Socket} Creates a new socket object. From 5c8117a389df3b728d32ca6a458fa131dd0a0ef0 Mon Sep 17 00:00:00 2001 From: sendoru Date: Sun, 4 Aug 2024 08:25:12 +0900 Subject: [PATCH 3/4] doc: move `net.connect()` function example to suitable section Refs: https://github.com/nodejs/node/issues/53792 --- doc/api/net.md | 37 ++++++++++++++++++++----------------- 1 file changed, 20 insertions(+), 17 deletions(-) diff --git a/doc/api/net.md b/doc/api/net.md index fe29d0fb0425f1..c5b069701f755e 100644 --- a/doc/api/net.md +++ b/doc/api/net.md @@ -1052,23 +1052,6 @@ For [IPC][] connections, available `options` are: options above are ignored. -Following is an example of a client using the `onread` option: - -```js -const net = require('node:net'); -net.connect({ - port: 80, - onread: { - // Reuses a 4KiB Buffer for every read from the socket. - buffer: Buffer.alloc(4 * 1024), - callback: function(nread, buf) { - // Received data is available in `buf` from 0 to `nread`. - console.log(buf.toString('utf8', 0, nread)); - }, - }, -}); -``` - #### `socket.connect(path[, connectListener])` * `path` {string} Path the client should connect to. See @@ -1571,6 +1554,26 @@ To connect on the socket `/tmp/echo.sock`: const client = net.createConnection({ path: '/tmp/echo.sock' }); ``` +Following is an example of a client using the `port` and `onread` +option. In this case, the `onread` option will be only used to call +`new net.Socket([options])` and the `port` option will be used to +call `socket.connect(options[, connectListener])`. + +```js +const net = require('node:net'); +net.createConnection({ + port: 80, + onread: { + // Reuses a 4KiB Buffer for every read from the socket. + buffer: Buffer.alloc(4 * 1024), + callback: function(nread, buf) { + // Received data is available in `buf` from 0 to `nread`. + console.log(buf.toString('utf8', 0, nread)); + }, + }, +}); +``` + ### `net.createConnection(path[, connectListener])`