refactor: move brother_node development artifact to dev/test-nodes subdirectory
Development Artifact Cleanup: ✅ BROTHER_NODE REORGANIZATION: Moved development test node to appropriate location - dev/test-nodes/brother_node/: Moved from root directory for better organization - Contains development configuration, test logs, and test chain data - No impact on production systems - purely development/testing artifact ✅ DEVELOPMENT ARTIFACTS IDENTIFIED: - Chain ID: aitbc-brother-chain (test/development chain) - Ports: 8010 (P2P) and 8011 (RPC) - different from production - Environment: .env file with test configuration - Logs: rpc.log and node.log from development testing session (March 15, 2026) ✅ ROOT DIRECTORY CLEANUP: Removed development clutter from production directory - brother_node/ moved to dev/test-nodes/brother_node/ - Root directory now contains only production-ready components - Development artifacts properly organized in dev/ subdirectory DIRECTORY STRUCTURE IMPROVEMENT: 📁 dev/test-nodes/: Development and testing node configurations 🏗️ Root Directory: Clean production structure with only essential components 🧪 Development Isolation: Test environments separated from production BENEFITS: ✅ Clean Production Directory: No development artifacts in root ✅ Better Organization: Development nodes grouped in dev/ subdirectory ✅ Clear Separation: Production vs development environments clearly distinguished ✅ Maintainability: Easier to identify and manage development components RESULT: Successfully moved brother_node development artifact to dev/test-nodes/ subdirectory, cleaning up the root directory while preserving development testing environment for future use.
This commit is contained in:
2963
dev/env/node_modules/@nomicfoundation/hardhat-errors/src/descriptors.ts
generated
vendored
Executable file
2963
dev/env/node_modules/@nomicfoundation/hardhat-errors/src/descriptors.ts
generated
vendored
Executable file
File diff suppressed because it is too large
Load Diff
285
dev/env/node_modules/@nomicfoundation/hardhat-errors/src/errors.ts
generated
vendored
Executable file
285
dev/env/node_modules/@nomicfoundation/hardhat-errors/src/errors.ts
generated
vendored
Executable file
@@ -0,0 +1,285 @@
|
||||
import type { ErrorDescriptor } from "./descriptors.js";
|
||||
|
||||
import { CustomError } from "@nomicfoundation/hardhat-utils/error";
|
||||
import { isObject } from "@nomicfoundation/hardhat-utils/lang";
|
||||
|
||||
import { ERRORS, ERROR_CATEGORIES } from "./descriptors.js";
|
||||
|
||||
export type ErrorMessageTemplateValue =
|
||||
| string
|
||||
| number
|
||||
| boolean
|
||||
| bigint
|
||||
| undefined
|
||||
| null
|
||||
| ErrorMessageTemplateValue[]
|
||||
| { toString(): string };
|
||||
|
||||
export type MessagetTemplateArguments<MessageTemplateT extends string> =
|
||||
MessageTemplateT extends `${string}{${infer Tag}}${infer Rest}`
|
||||
? {
|
||||
[K in
|
||||
| Tag
|
||||
| keyof MessagetTemplateArguments<Rest>]: ErrorMessageTemplateValue;
|
||||
}
|
||||
: {};
|
||||
|
||||
export type HardhatErrorConstructorArguments<
|
||||
ErrorDescriptorT extends ErrorDescriptor,
|
||||
> = keyof MessagetTemplateArguments<
|
||||
ErrorDescriptorT["messageTemplate"]
|
||||
> extends never
|
||||
? [ErrorDescriptorT, Error?]
|
||||
: [
|
||||
ErrorDescriptorT,
|
||||
MessagetTemplateArguments<ErrorDescriptorT["messageTemplate"]>,
|
||||
Error?,
|
||||
];
|
||||
|
||||
export const ERROR_PREFIX = "HHE";
|
||||
|
||||
const IS_HARDHAT_ERROR_PROPERTY_NAME = "_isHardhatError";
|
||||
const IS_HARDHAT_PLUGIN_ERROR_PROPERTY_NAME = "_isHardhatPluginError";
|
||||
|
||||
/**
|
||||
* An error thrown by Hardhat. This error is meant to be thrown by Hardhat
|
||||
* itself, and internal plugins. For errors thrown by community plugins, see
|
||||
* `HardhatPluginError`.
|
||||
*/
|
||||
export class HardhatError<
|
||||
ErrorDescriptorT extends ErrorDescriptor = ErrorDescriptor,
|
||||
> extends CustomError {
|
||||
public static readonly ERRORS: typeof ERRORS = ERRORS;
|
||||
|
||||
readonly #descriptor: ErrorDescriptorT;
|
||||
|
||||
readonly #arguments: MessagetTemplateArguments<
|
||||
ErrorDescriptorT["messageTemplate"]
|
||||
>;
|
||||
|
||||
readonly #errorCode: string;
|
||||
|
||||
readonly #formattedMessage: string;
|
||||
|
||||
constructor(
|
||||
...[
|
||||
errorDescriptor,
|
||||
messageArgumentsOrParentError,
|
||||
parentError,
|
||||
]: HardhatErrorConstructorArguments<ErrorDescriptorT>
|
||||
) {
|
||||
const errorCode = getErrorCode(errorDescriptor);
|
||||
|
||||
const formattedMessage =
|
||||
messageArgumentsOrParentError === undefined ||
|
||||
messageArgumentsOrParentError instanceof Error
|
||||
? errorDescriptor.messageTemplate
|
||||
: applyErrorMessageTemplate(
|
||||
errorDescriptor.messageTemplate,
|
||||
messageArgumentsOrParentError,
|
||||
);
|
||||
|
||||
super(
|
||||
`${errorCode}: ${formattedMessage}`,
|
||||
parentError instanceof Error
|
||||
? parentError
|
||||
: messageArgumentsOrParentError instanceof Error
|
||||
? messageArgumentsOrParentError
|
||||
: undefined,
|
||||
);
|
||||
|
||||
this.#descriptor = errorDescriptor;
|
||||
this.#errorCode = errorCode;
|
||||
this.#formattedMessage = formattedMessage;
|
||||
|
||||
if (
|
||||
messageArgumentsOrParentError === undefined ||
|
||||
messageArgumentsOrParentError instanceof Error
|
||||
) {
|
||||
/* eslint-disable @typescript-eslint/consistent-type-assertions --
|
||||
Typescript inference get's lost here, but we know that if we didn't get
|
||||
arguments, it's because the error doesn't have any. */
|
||||
this.#arguments = {} as MessagetTemplateArguments<
|
||||
ErrorDescriptorT["messageTemplate"]
|
||||
>;
|
||||
} else {
|
||||
this.#arguments = messageArgumentsOrParentError;
|
||||
}
|
||||
|
||||
// As this package is going to be used from most of our packages, there's a
|
||||
// change of users having multiple versions of it. If that happens, they may
|
||||
// have multiple `HardhatError` classes, so we can't reliably use
|
||||
// `instanceof` to check if an error is a `HardhatError`. We define a
|
||||
// pseudo-private field to use it for it. While this is not bulletproof, it
|
||||
// should be enough for our case, as we won't be changing this class often.
|
||||
Object.defineProperty(this, IS_HARDHAT_ERROR_PROPERTY_NAME, {
|
||||
configurable: false,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
value: true,
|
||||
});
|
||||
}
|
||||
|
||||
public static isHardhatError(
|
||||
other: unknown,
|
||||
): other is HardhatError<ErrorDescriptor>;
|
||||
public static isHardhatError<ErrorDescriptorT extends ErrorDescriptor>(
|
||||
other: unknown,
|
||||
descriptor?: ErrorDescriptorT,
|
||||
): other is HardhatError<ErrorDescriptorT>;
|
||||
public static isHardhatError(
|
||||
other: unknown,
|
||||
descriptor?: ErrorDescriptor,
|
||||
): other is HardhatError<ErrorDescriptor> {
|
||||
if (!isObject(other)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
const isHardhatErrorProperty = Object.getOwnPropertyDescriptor(
|
||||
other,
|
||||
IS_HARDHAT_ERROR_PROPERTY_NAME,
|
||||
);
|
||||
|
||||
return (
|
||||
isHardhatErrorProperty?.value === true &&
|
||||
// If an error descriptor is provided, check if its number matches the Hardhat error number
|
||||
(descriptor === undefined
|
||||
? true
|
||||
: "number" in other && other.number === descriptor.number)
|
||||
);
|
||||
}
|
||||
|
||||
public get number(): number {
|
||||
return this.#descriptor.number;
|
||||
}
|
||||
|
||||
public get pluginId(): string | undefined {
|
||||
for (const category of Object.values(ERROR_CATEGORIES)) {
|
||||
const isWithinCategoryRange =
|
||||
this.#descriptor.number >= category.min &&
|
||||
this.#descriptor.number <= category.max;
|
||||
|
||||
if (isWithinCategoryRange) {
|
||||
return category.pluginId;
|
||||
}
|
||||
}
|
||||
|
||||
return undefined;
|
||||
}
|
||||
|
||||
public get descriptor(): ErrorDescriptor {
|
||||
return this.#descriptor;
|
||||
}
|
||||
|
||||
public get messageArguments(): MessagetTemplateArguments<
|
||||
ErrorDescriptorT["messageTemplate"]
|
||||
> {
|
||||
return this.#arguments;
|
||||
}
|
||||
|
||||
public get errorCode(): string {
|
||||
return this.#errorCode;
|
||||
}
|
||||
|
||||
public get formattedMessage(): string {
|
||||
return this.#formattedMessage;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* An error thrown by a Hardhat plugin. This error is meant to be thrown by
|
||||
* community plugins to signal that something went wrong.
|
||||
*/
|
||||
export class HardhatPluginError extends CustomError {
|
||||
constructor(
|
||||
public readonly pluginId: string,
|
||||
message: string,
|
||||
parentError?: Error,
|
||||
) {
|
||||
super(message, parentError);
|
||||
|
||||
// See `HardhatError` constructor for an explanation of this property.
|
||||
Object.defineProperty(this, IS_HARDHAT_PLUGIN_ERROR_PROPERTY_NAME, {
|
||||
configurable: false,
|
||||
enumerable: false,
|
||||
writable: false,
|
||||
value: true,
|
||||
});
|
||||
}
|
||||
|
||||
public static isHardhatPluginError(
|
||||
other: unknown,
|
||||
): other is HardhatPluginError {
|
||||
if (!isObject(other)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
const isHardhatPluginErrorProperty = Object.getOwnPropertyDescriptor(
|
||||
other,
|
||||
IS_HARDHAT_PLUGIN_ERROR_PROPERTY_NAME,
|
||||
);
|
||||
|
||||
return isHardhatPluginErrorProperty?.value === true;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Asserts an internal invariant.
|
||||
*
|
||||
* @param invariant The condition to check.
|
||||
* @param message A message to show if the condition is false.
|
||||
*/
|
||||
export function assertHardhatInvariant(
|
||||
invariant: boolean,
|
||||
message: string,
|
||||
): asserts invariant {
|
||||
if (!invariant) {
|
||||
throw new HardhatError(ERRORS.CORE.INTERNAL.ASSERTION_ERROR, { message });
|
||||
}
|
||||
}
|
||||
|
||||
function getErrorCode(errorDescriptor: ErrorDescriptor): string {
|
||||
return `${ERROR_PREFIX}${errorDescriptor.number}`;
|
||||
}
|
||||
|
||||
/**
|
||||
* This function applies error messages templates like this:
|
||||
*
|
||||
* - Template is a string which contains a variable tags. A variable tag is a
|
||||
* a variable name surrounded by %. Eg: %plugin1%
|
||||
* - A variable name is a string of alphanumeric ascii characters.
|
||||
* - Every variable tag is replaced by its value.
|
||||
* - %% is replaced by %.
|
||||
* - Values can't contain variable tags.
|
||||
* - If a variable is not present in the template, but present in the values
|
||||
* object, an error is thrown.
|
||||
*
|
||||
* @param template The template string.
|
||||
* @param values A map of variable names to their values.
|
||||
*/
|
||||
export function applyErrorMessageTemplate(
|
||||
template: string,
|
||||
values: Record<string, ErrorMessageTemplateValue>,
|
||||
): string {
|
||||
return template.replaceAll(/{(.*?)}/g, (_match, variableName) => {
|
||||
const rawValue = values[variableName];
|
||||
|
||||
if (rawValue === undefined) {
|
||||
return "undefined";
|
||||
}
|
||||
|
||||
if (rawValue === null) {
|
||||
return "null";
|
||||
}
|
||||
|
||||
if (typeof rawValue === "bigint") {
|
||||
return `${rawValue}n`;
|
||||
}
|
||||
|
||||
if (Array.isArray(rawValue)) {
|
||||
return JSON.stringify(rawValue);
|
||||
}
|
||||
|
||||
return rawValue.toString();
|
||||
});
|
||||
}
|
||||
6
dev/env/node_modules/@nomicfoundation/hardhat-errors/src/index.ts
generated
vendored
Executable file
6
dev/env/node_modules/@nomicfoundation/hardhat-errors/src/index.ts
generated
vendored
Executable file
@@ -0,0 +1,6 @@
|
||||
export type { ErrorDescriptor } from "./descriptors.js";
|
||||
export {
|
||||
HardhatError,
|
||||
HardhatPluginError,
|
||||
assertHardhatInvariant,
|
||||
} from "./errors.js";
|
||||
Reference in New Issue
Block a user