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” çökmesi
Özet
OpenClaw’ı Node üzerindentsx ile ç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özlendi)
- tsx: 4.21.0
- OS: macOS (yeniden üretim Node 25 çalıştıran diğer platformlarda da olası)
Yeniden üretim (yalnızca Node)
Repoda minimal yeniden üretim
Node sürümü kontrolü
- 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’inkeepNamesseçeneği bir__nameyardımcısı üretir ve işlev tanımlarını__name(...)ile sarar.- Çökme,
__namedeğerinin var olduğunu ancak çalışma zamanında bir işlev olmadığını gösteriyor; bu da yardımcının Node 25 yükleyici yolunda bu modül için eksik olduğu veya üzerine yazıldığı anlamına gelir. - Benzer
__nameyardımcısı sorunları, yardımcının eksik olduğu veya yeniden yazıldığı durumlarda diğer esbuild tüketicilerinde bildirilmiştir.
Regresyon geçmişi
2871657e(2026-01-06): Bun’ı isteğe bağlı hale getirmek için betikler Bun’dan tsx’e geçirildi.- Bundan önce (Bun yolu),
openclaw statusvegateway:watchçalışıyordu.
Geçici çözümler
- Geliştirme betikleri için Bun kullanın (mevcut geçici geri alma).
-
Repo tür denetimi için
tsgokullanın, ardından oluşturulan çıktıyı çalıştırın: -
Tarihsel not: Bu Node/tsx sorunu hata ayıklanırken burada
tsckullanılmıştı, ancak repo tür denetimi hatları artıktsgokullanıyor. -
Mümkünse TS yükleyicisinde esbuild keepNames seçeneğini devre dışı bırakın (
__nameyardımcısının eklenmesini önler); tsx şu anda bunu dışa açmıyor. -
Sorunun Node 25’e özgü olup olmadığını görmek için Node LTS (22/24) sürümlerini
tsxile test edin.
Referanslar
- 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 yeniden üretilirse,
__nameyığın izlemesiyle birlikte üst projeye minimal bir yeniden üretim bildirin.