Fix fork() method crash in ESM environments due to directory imports #927
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The
Model.fork()
method was crashing in ESM environments due to directory imports in the binary codec that don't work with Node.js ES module resolution. This affected users trying to use the library with modern ESM setups.Problem
The issue occurred when calling
model.fork()
which internally usesModel.fromBinary()
andModel.toBinary()
. These methods depend on the binary codec (Encoder/Decoder) that used directory imports like:Node.js ESM requires explicit file extensions and doesn't support directory imports without explicit index files, causing the following error:
Solution
Fixed source code: Changed directory imports to explicit named imports in the core binary codec files:
Enhanced build process: Added an automated ESM import fixer script that:
.js
extensions to relative importsindex.js
importsUpdated build script: The
build:esm
command now automatically applies ESM fixes post-compilationUsage
The fix enables seamless ESM usage:
Testing
Fixes #926.
💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.