From 1023e6e6eca85589c2556f50f206f943f85924c7 Mon Sep 17 00:00:00 2001
From: RedYetiDev <38299977+RedYetiDev@users.noreply.github.com>
Date: Wed, 2 Oct 2024 12:24:40 -0400
Subject: [PATCH 1/3] tools: enforce errors to not be documented in legacy
section
---
doc/api/errors.md | 114 +++++++++---------
.../parallel/test-eslint-documented-errors.js | 5 -
tools/eslint-rules/documented-errors.js | 92 ++++++++++----
3 files changed, 128 insertions(+), 83 deletions(-)
diff --git a/doc/api/errors.md b/doc/api/errors.md
index 37319f4c3c8d15..0732be827f6960 100644
--- a/doc/api/errors.md
+++ b/doc/api/errors.md
@@ -2340,6 +2340,17 @@ compiled with ICU support.
A non-context-aware native addon was loaded in a process that disallows them.
+
+
+### `ERR_OPERATION_FAILED`
+
+
+
+An operation failed. This is typically used to signal the general failure
+of an asynchronous operation.
+
### `ERR_OUT_OF_RANGE`
@@ -2422,6 +2433,42 @@ Accessing `Object.prototype.__proto__` has been forbidden using
[`Object.setPrototypeOf`][] should be used to get and set the prototype of an
object.
+
+
+### `ERR_QUIC_CONNECTION_FAILED`
+
+
+
+> Stability: 1 - Experimental
+
+Establishing a QUIC connection failed.
+
+
+
+### `ERR_QUIC_ENDPOINT_CLOSED`
+
+
+
+> Stability: 1 - Experimental
+
+A QUIC Endpoint closed with an error.
+
+
+
+### `ERR_QUIC_OPEN_STREAM_FAILED`
+
+
+
+> Stability: 1 - Experimental
+
+Opening a QUIC stream failed.
+
### `ERR_REQUIRE_CYCLE_MODULE`
@@ -2999,6 +3046,16 @@ try {
}
```
+
+
+#### `ERR_UNSUPPORTED_NODE_MODULES_TYPE_STRIPPING`
+
+
+
+Type stripping is not supported for files descendent of a `node_modules` directory.
+
### `ERR_USE_AFTER_CLOSE`
@@ -3612,17 +3669,6 @@ Used by the `Node-API` when `Constructor.prototype` is not an object.
A Node.js API was called in an unsupported manner, such as
`Buffer.write(string, encoding, offset[, length])`.
-
-
-### `ERR_OPERATION_FAILED`
-
-
-
-An operation failed. This is typically used to signal the general failure
-of an asynchronous operation.
-
### `ERR_OUTOFMEMORY`
@@ -3646,42 +3692,6 @@ removed: v10.0.0
The `node:repl` module was unable to parse data from the REPL history file.
-
-
-### `ERR_QUIC_CONNECTION_FAILED`
-
-
-
-> Stability: 1 - Experimental
-
-Establishing a QUIC connection failed.
-
-
-
-### `ERR_QUIC_ENDPOINT_CLOSED`
-
-
-
-> Stability: 1 - Experimental
-
-A QUIC Endpoint closed with an error.
-
-
-
-### `ERR_QUIC_OPEN_STREAM_FAILED`
-
-
-
-> Stability: 1 - Experimental
-
-Opening a QUIC stream failed.
-
### `ERR_SOCKET_CANNOT_SEND`
@@ -4073,16 +4083,6 @@ The public key in the certificate SubjectPublicKeyInfo could not be read.
An error occurred trying to allocate memory. This should never happen.
-
-
-#### `ERR_UNSUPPORTED_NODE_MODULES_TYPE_STRIPPING`
-
-
-
-Type stripping is not supported for files descendent of a `node_modules` directory.
-
[ES Module]: esm.md
[ICU]: intl.md#internationalization-support
[JSON Web Key Elliptic Curve Registry]: https://www.iana.org/assignments/jose/jose.xhtml#web-key-elliptic-curve
diff --git a/test/parallel/test-eslint-documented-errors.js b/test/parallel/test-eslint-documented-errors.js
index 03131306d7d95a..1759c786fd0f69 100644
--- a/test/parallel/test-eslint-documented-errors.js
+++ b/test/parallel/test-eslint-documented-errors.js
@@ -27,11 +27,6 @@ new RuleTester().run('documented-errors', rule, {
message: `"${invalidCode}" is not documented in doc/api/errors.md`,
line: 2
},
- {
- message:
- `doc/api/errors.md does not have an anchor for "${invalidCode}"`,
- line: 2
- },
]
},
]
diff --git a/tools/eslint-rules/documented-errors.js b/tools/eslint-rules/documented-errors.js
index 17bd2221097085..a46fb885bb03b3 100644
--- a/tools/eslint-rules/documented-errors.js
+++ b/tools/eslint-rules/documented-errors.js
@@ -4,35 +4,85 @@ const fs = require('fs');
const path = require('path');
const { isDefiningError } = require('./rules-utils.js');
-const doc = fs.readFileSync(path.resolve(__dirname, '../../doc/api/errors.md'),
- 'utf8');
+// Load the errors documentation file once
+const docPath = path.resolve(__dirname, '../../doc/api/errors.md');
+const doc = fs.readFileSync(docPath, 'utf8');
-function isInDoc(code) {
- return doc.includes(`### \`${code}\``);
-}
+// Helper function to parse errors documentation and return a Map
+function getErrorsInDoc() {
+ const lines = doc.split('\n');
+ let currentHeader;
+ const errors = new Map();
+ const codePattern = /^### `([^`]+)`$/;
+ const anchorPattern = /^<\/a>$/;
-function includesAnchor(code) {
- return doc.includes(``);
-}
+ function parse(line, legacy) {
+ const error = { legacy };
+ let code;
+
+ const codeMatch = line.match(codePattern);
+ if (codeMatch) {
+ error.header = true;
+ code = codeMatch[1];
+ }
+
+ const anchorMatch = line.match(anchorPattern);
+ if (anchorMatch) {
+ error.anchor = true;
+ code ??= anchorMatch[1];
+ }
+
+ if (!code) return;
+
+ // If the code already exists in the Map, merge the new error data
+ errors.set(code, {
+ ...errors.get(code),
+ ...error,
+ });
+ }
+
+ for (const line of lines) {
+ if (line.startsWith('## ')) currentHeader = line.substring(3);
+ if (currentHeader === 'Node.js error codes') parse(line, false);
+ if (currentHeader === 'Legacy Node.js error codes') parse(line, true);
+ }
-function errorForNode(node) {
- return node.expression.arguments[0].value;
+ return errors;
}
+// Main rule export
module.exports = {
- create: function(context) {
+ create(context) {
+ const errors = getErrorsInDoc();
return {
- ExpressionStatement: function(node) {
- if (!isDefiningError(node) || !errorForNode(node)) return;
- const code = errorForNode(node);
- if (!isInDoc(code)) {
- const message = `"${code}" is not documented in doc/api/errors.md`;
- context.report({ node, message });
+ ExpressionStatement(node) {
+ if (!isDefiningError(node)) return;
+
+ const code = node.expression.arguments?.[0]?.value;
+ if (!code) return;
+
+ const err = errors.get(code); // Use Map's get method to retrieve the error
+
+ if (!err || !err.header) {
+ context.report({
+ node,
+ message: `"${code}" is not documented in doc/api/errors.md`,
+ });
+ if (!err) return;
}
- if (!includesAnchor(code)) {
- const message =
- `doc/api/errors.md does not have an anchor for "${code}"`;
- context.report({ node, message });
+
+ if (!err.anchor) {
+ context.report({
+ node,
+ message: `doc/api/errors.md does not have an anchor for "${code}"`,
+ });
+ }
+
+ if (err.legacy) {
+ context.report({
+ node,
+ message: `"${code}" is marked as legacy, yet it still exists.`,
+ });
}
},
};
From e928f45ca57253052fca3b347d7d203280ee4928 Mon Sep 17 00:00:00 2001
From: RedYetiDev <38299977+RedYetiDev@users.noreply.github.com>
Date: Wed, 2 Oct 2024 12:31:20 -0400
Subject: [PATCH 2/3] fixup! tools: enforce errors to not be documented in
legacy section
---
doc/api/errors.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/doc/api/errors.md b/doc/api/errors.md
index 0732be827f6960..4ac50b198a10cb 100644
--- a/doc/api/errors.md
+++ b/doc/api/errors.md
@@ -3048,7 +3048,7 @@ try {
-#### `ERR_UNSUPPORTED_NODE_MODULES_TYPE_STRIPPING`
+### `ERR_UNSUPPORTED_NODE_MODULES_TYPE_STRIPPING`