Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
Node + tsx „__name is not a function“-Absturz
Zusammenfassung
Das Ausführen von OpenClaw über Node mittsx schlägt beim Start fehl mit:
tsx (Commit 2871657e, 2026-01-06). Derselbe Runtime-Pfad funktionierte mit Bun.
Umgebung
- Node: v25.x (beobachtet auf v25.3.0)
- tsx: 4.21.0
- OS: macOS (Reproduktion wahrscheinlich auch auf anderen Plattformen, die Node 25 ausführen)
Reproduktion (nur Node)
Minimale Reproduktion im Repo
Node-Versionsprüfung
- Node 25.3.0: schlägt fehl
- Node 22.22.0 (Homebrew
node@22): schlägt fehl - Node 24: hier noch nicht installiert; muss verifiziert werden
Hinweise / Hypothese
tsxverwendet esbuild, um TS/ESM zu transformieren. esbuildskeepNamesgibt einen__name-Helper aus und umschließt Funktionsdefinitionen mit__name(...).- Der Absturz zeigt, dass
__namezur Laufzeit existiert, aber keine Funktion ist, was darauf hindeutet, dass der Helper für dieses Modul im Node-25-Loader-Pfad fehlt oder überschrieben wurde. - Ähnliche Probleme mit dem
__name-Helper wurden in anderen esbuild-Consumern gemeldet, wenn der Helper fehlt oder umgeschrieben wird.
Regressionshistorie
2871657e(2026-01-06): Skripte wurden von Bun auf tsx umgestellt, um Bun optional zu machen.- Davor (Bun-Pfad) funktionierten
openclaw statusundgateway:watch.
Workarounds
- Verwenden Sie Bun für Entwicklungsskripte (aktueller temporärer Revert).
-
Verwenden Sie
tsgofür die Typprüfung des Repos und führen Sie dann die gebaute Ausgabe aus: -
Historischer Hinweis:
tscwurde hier während des Debuggings dieses Node/tsx-Problems verwendet, aber die Typprüfungs-Lanes des Repos verwenden jetzttsgo. -
Deaktivieren Sie esbuild keepNames im TS-Loader, falls möglich (verhindert das Einfügen des
__name-Helpers); tsx stellt dies derzeit nicht bereit. -
Testen Sie Node LTS (22/24) mit
tsx, um zu sehen, ob das Problem Node-25-spezifisch ist.
Referenzen
- https://opennext.js.org/cloudflare/howtos/keep_names
- https://esbuild.github.io/api/#keep-names
- https://github.com/evanw/esbuild/issues/1031
Nächste Schritte
- Auf Node 22/24 reproduzieren, um die Node-25-Regression zu bestätigen.
tsxNightly testen oder auf eine frühere Version pinnen, falls eine bekannte Regression existiert.- Wenn es auf Node LTS reproduzierbar ist, eine minimale Reproduktion upstream mit dem
__name-Stacktrace einreichen.