Node + tsx “__name is not a function” çökmesi
Özet
OpenClaw’ı Node iletsx kullanarak çalıştırmak başlangıçta şu hatayla başarısız oluyor:
tsx’e geçirildikten sonra başladı (commit 2871657e, 2026-01-06). Aynı çalışma zamanı yolu Bun ile çalışıyordu.
Ortam
- Node: v25.x (v25.3.0 üzerinde gözlemlendi)
- tsx: 4.21.0
- İşletim sistemi: macOS (yeniden üretimin Node 25 çalıştıran diğer platformlarda da olması muhtemel)
Yeniden üretim (yalnızca Node)
Depo içindeki minimal yeniden üretim
Node sürümü denetimi
- Node 25.3.0: başarısız
- Node 22.22.0 (Homebrew
node@22): başarısız - Node 24: burada henüz yüklü değil; doğrulama gerekiyor
Notlar / hipotez
tsx, TS/ESM dönüştürmek için esbuild kullanır. esbuild’ünkeepNamesseçeneği bir__nameyardımcı işlevi üretir ve işlev tanımlarını__name(...)ile sarar.- Çökme,
__namedeğerinin mevcut olduğunu ancak çalışma zamanında bir işlev olmadığını gösteriyor; bu da yardımcı işlevin eksik olduğunu veya bu modül için Node 25 loader yolunda üzerine yazıldığını düşündürür. - Benzer
__nameyardımcı işlev sorunları, yardımcı işlev eksik olduğunda veya yeniden yazıldığında diğer esbuild kullanıcılarında da bildirilmiştir.
Regresyon geçmişi
2871657e(2026-01-06): Bun’u isteğe bağlı yapmak için betikler Bun’dan tsx’e geçirildi.- Ondan önce (Bun yolu),
openclaw statusvegateway:watchçalışıyordu.
Geçici çözümler
- Geliştirme betikleri için Bun kullanın (mevcut geçici geri dönüş).
-
Node + tsc watch kullanın, ardından derlenmiş çıktıyı çalıştırın:
-
Yerelde doğrulandı:
pnpm exec tsc -p tsconfig.json+node openclaw.mjs status, Node 25 üzerinde çalışıyor. -
Mümkünse TS loader içinde esbuild
keepNamesseçeneğini devre dışı bırakın (__nameyardımcı işlev eklemesini önler); tsx bunu şu anda dışa açmıyor. -
Sorunun Node 25’e özgü olup olmadığını görmek için
tsxile Node LTS (22/24) sürümlerini test edin.
Kaynaklar
- https://opennext.js.org/cloudflare/howtos/keep_names
- https://esbuild.github.io/api/#keep-names
- https://github.com/evanw/esbuild/issues/1031
Sonraki adımlar
- Node 25 regresyonunu doğrulamak için Node 22/24 üzerinde yeniden üretin.
- Bilinen bir regresyon varsa
tsxnightly sürümünü test edin veya daha eski bir sürüme sabitleyin. - Node LTS üzerinde de yeniden üretiliyorsa,
__nameyığın iziyle birlikte upstream’e minimal bir yeniden üretim bildirin.