openclaw.mjs

openclaw.mjs 是 OpenClaw 项目的命令行入口文件,负责在启动主程序前执行一系列关键的初始化操作,确保运行环境正确并加载实际的应用入口。其核心功能如下:

1. Node.js 版本检查

  • 若当前版本过低,输出错误信息(含 nvm 使用提示)并终止进程,避免因版本不兼容导致运行时异常。
ts 复制代码
const parseNodeVersion = (rawVersion) => {
  const [majorRaw = "0", minorRaw = "0"] = rawVersion.split(".");
  return {
    major: Number(majorRaw),
    minor: Number(minorRaw),
  };
};

2. 启用编译缓存

  • 调用 module.enableCompileCache() 启用 V8 代码缓存(除非设置了环境变量 NODE_DISABLE_COMPILE_CACHE),加速后续模块加载,改善 CLI 响应速度。
ts 复制代码
const ensureSupportedNodeVersion = () => {
  if (isSupportedNodeVersion(parseNodeVersion(process.versions.node))) {
    return;
  }
...
ensureSupportedNodeVersion();

关于node:module

node:module 模块的主要功能可以分为以下四类,我们先通过一个表格快速了解:

功能类别 核心API 主要作用与比喻
1. 模块信息查询 builtinModulesisBuiltin() 获取所有内置模块列表,或判断一个模块名是否为内置模块,就像是 Node.js 模块系统的"户口本"和"身份证查验员"。
2. 模块兼容与转换 createRequire() 在 ES Module (ESM) 环境中创建一个 require() 函数,以便加载 CommonJS 模块。它就像是在"现代小区"(ESM)和"老式楼房"(CommonJS)之间搭建的一座桥梁。
3. 模块加载定制 register() 允许你注册自定义的钩子函数,从而深度定制 Node.js 的模块解析(resolve)加载(load) 行为。这是赋予开发者"上帝视角"来重塑模块加载规则的核心工具。
4. 模块状态同步 syncBuiltinESMExports() 手动同步内置模块的 CommonJS 和 ES Module 两种导出方式之间的状态。它像一个"同步开关",确保在修改了内置模块的 CJS 导出后,其 ESM 的实时绑定也能保持一致。

参考文档:# Node.js

3. 安装进程警告过滤器

  • 动态导入 dist/warning-filter.js.mjs,执行其中的 installProcessWarningFilter 函数。
  • 该函数会包装 process.emitWarning,过滤掉不必要的警告(如实验性特性警告),使控制台输出更干净,与 TypeScript 运行时的警告行为保持一致。
javascript 复制代码
const installProcessWarningFilter = async () => {
  // Keep bootstrap warnings consistent with the TypeScript runtime.
  for (const specifier of ["./dist/warning-filter.js", "./dist/warning-filter.mjs"]) {
    try {
      const mod = await import(specifier);
      if (typeof mod.installProcessWarningFilter === "function") {
        mod.installProcessWarningFilter();
        return;
      }
    } catch (err) {
        ...
    }
  }
};

4. 定位并加载主入口

  • 依次尝试导入 dist/entry.jsdist/entry.mjs(构建产物的主入口文件)。
  • 若均失败,抛出错误提示"构建输出缺失",引导用户先执行构建。
csharp 复制代码
if (await tryImport("./dist/entry.js")) {
  // OK
} else if (await tryImport("./dist/entry.mjs")) {
  // OK
} else {
  ...
}
相关推荐
用户789377339085313 分钟前
前端转后端生存指南(中):化身架构师,用 ORM 魔法掌控数据库
后端·python
Master_Azur14 分钟前
JavaEE之文件操作 字符集 IO流
后端
传说之后15 分钟前
GO 语言单元测试入门
后端
古城小栈16 分钟前
Bun从Zig迁移至Rust:有何重大意义?
开发语言·后端·rust
虎子_layor18 分钟前
给 Agent 接入新模型的推理模式:从配置开关到协议适配
后端·架构
IT_陈寒44 分钟前
Java的Stream.peek()千万别乱用,血泪教训
前端·人工智能·后端
小江的记录本1 小时前
【MySQL】MySQL日志体系:redo log/undo log/binlog 三者区别、两阶段提交、如何保证数据一致性
java·数据库·后端·python·sql·mysql·面试
Jul1en_2 小时前
【Spring Cloud】Spring Cloud Config详解
后端·spring·spring cloud
Wy_编程2 小时前
go语言面向对象和异常处理
开发语言·后端·golang
易安说AI9 小时前
Codex 直接住进 JetBrains IDE 里:AI Agent 正在接管熟悉的开发入口
后端