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.
64 lines
1.8 KiB
TypeScript
Executable File
64 lines
1.8 KiB
TypeScript
Executable File
import {
|
|
defineProperties, fromTwos, getBigInt, mask, toTwos
|
|
} from "../../utils/index.js";
|
|
|
|
import { Typed } from "../typed.js";
|
|
import { Coder, WordSize } from "./abstract-coder.js";
|
|
|
|
import type { BigNumberish } from "../../utils/index.js";
|
|
|
|
import type { Reader, Writer } from "./abstract-coder.js";
|
|
|
|
|
|
const BN_0 = BigInt(0);
|
|
const BN_1 = BigInt(1);
|
|
const BN_MAX_UINT256 = BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
|
|
|
|
/**
|
|
* @_ignore
|
|
*/
|
|
export class NumberCoder extends Coder {
|
|
readonly size!: number;
|
|
readonly signed!: boolean;
|
|
|
|
constructor(size: number, signed: boolean, localName: string) {
|
|
const name = ((signed ? "int": "uint") + (size * 8));
|
|
super(name, name, localName, false);
|
|
|
|
defineProperties<NumberCoder>(this, { size, signed }, { size: "number", signed: "boolean" });
|
|
}
|
|
|
|
defaultValue(): number {
|
|
return 0;
|
|
}
|
|
|
|
encode(writer: Writer, _value: BigNumberish | Typed): number {
|
|
let value = getBigInt(Typed.dereference(_value, this.type));
|
|
|
|
// Check bounds are safe for encoding
|
|
let maxUintValue = mask(BN_MAX_UINT256, WordSize * 8);
|
|
if (this.signed) {
|
|
let bounds = mask(maxUintValue, (this.size * 8) - 1);
|
|
if (value > bounds || value < -(bounds + BN_1)) {
|
|
this._throwError("value out-of-bounds", _value);
|
|
}
|
|
value = toTwos(value, 8 * WordSize);
|
|
} else if (value < BN_0 || value > mask(maxUintValue, this.size * 8)) {
|
|
this._throwError("value out-of-bounds", _value);
|
|
}
|
|
|
|
return writer.writeValue(value);
|
|
}
|
|
|
|
decode(reader: Reader): any {
|
|
let value = mask(reader.readValue(), this.size * 8);
|
|
|
|
if (this.signed) {
|
|
value = fromTwos(value, this.size * 8);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
}
|
|
|