protoscript
Advanced tools
Changelog
v0.0.20
Changelog
v0.0.19
const ron = User.initialize({ firstName: "Ron" });
Changelog
v0.0.18
Changelog
v0.0.17
Uint8Array
from PartialDeep
type. This fixes a type error for TypeScript users that use bytes
.Changelog
v0.0.16
encode
methods now accept partials for nested messages as well (PartialDeep
instead of Partial
). Previously, the types required that full messages were provided for any nested messages.
Buf users will need to update their buf.gen.yaml
path:
buf.gen.yaml
version: v1
plugins:
- name: protoc-gen-protoscript
- path: ./node_modules/protoscript/compiler.js
+ path: ./node_modules/protoscript/dist/compiler.js
out: .
opt:
- language=typescript
strategy: all
Changelog
v0.0.15
This release includes a number of bug fixes
Changelog
v0.0.14
Fix intermittent EAGAIN issue encountered when compiling protos
Use glob imports for generated messages instead of destructuring. This preserves tree shaking, but preserves module namespacing to disambiguate name collisions between protos. Previously, identically named messages in different modules could causes a name collision, eg:
// foo.proto
message Foo {}
// bar.proto
import "foo.proto";
message Foo {}
Would result in errors in the generated code. Now, this is namespaced and works correctly.
Changelog
v0.0.13
Update package Protocol Buffers Well-Known Types to enable strict ESM.
Changelog
v0.0.12
Protocol Buffers Well-Known Types are now exported from protoscript
. References to well-known types are now imported from protoscript
rather than being generated. This is a non breaking change. If you have well-known types in your project, you can remove the google/protobuf
directory that was generated in previous versions alongside your other .pb.js/ts
files.
The output location of google/protobuf
was a common reason for using dest
in proto.config.mjs
so this change should facilitate zero configuration for a greater number of projects.
Changelog
v0.0.11
Include file extensions in generated file imports
introduced in v0.0.7
for TypeScript users. Generated TypeScript imports will revert to the following:- import { Foo } from './foo.pb.js';
+ import { Foo } from './foo.pb';
When targeting ESM, the TypeScript compiler expects .js
extensions and not .ts
extensions for imports because the compiler does not manipulate import paths: https://www.typescriptlang.org/docs/handbook/esm-node.html.
Including a full extension results in the following TypeScript error:
[tsserver 2691] [E] An import path cannot end with a '.ts' extension.
The TypeScript team's recommendation to use .js
extensions for .ts
file imports when targeting ESM causes a number of issues with the broader JavaScript ecosystem. Until this situation is rectified, ProtoScript will not emit ESM compliant extensions for TypeScript. This only impacts TypeScript users who wish to target ESM in Node.JS using the TypeScript compiler, as bundlers are not pedantic about file extensions. If you're impacted by this, please join the discussion in #202