v2.0.0-beta0
Pre-releaseThis is the beginning of our 2.0.0 major release cycle, containing any breaking changes we've been saving up since 1.0. More breaking changes are possible before 2.0.0-rc0, at which point there will be only bugfixes before 2.0.0 final.
Note: we are looking for a corporate sponsor for this release! Your company will get prominent placement in any release announcements, on the release page itself, and on the project README. If you're looking to hire any DevInfra people, this is a great way to broadcast your company's position on supporting open source! If we don't find a sponsor, we may change to a more restrictive license for the 2.0 release, with the intent to restore it to Apache-2.0 for the 2.1 release.
Breaking Changes
- We now require Bazel 6.0 or greater, since we rely on validation actions
- We require that you select a value for the
skipLibCheck
flag, as there is no good default - you can either be fast or correct. Instructions are printed to the terminal on the first build. - We require that you select a value for the
transpiler
attribute. Again, there is no good default since the choices are to be fast or compatible. Documentation is at https://github.com/aspect-build/rules_ts/blob/2.x/docs/transpiler.md - "Persistent Worker" mode is no longer enabled by default. It requires a custom
tsc
compiler program, and we don't have the resources or funding to deal with the bugs this brings. We think that choosing a faster transpiler is a better solution. If your organization would like support for worker mode, you can fund the maintenance work. Or, if you'd like to take over the persistent worker Node.js program, we are open to relocating the code to a separate repository. - The
supports_workers
attribute onts_project
is now a tri-state[-1, 0, 1]
rather than a boolean. --define=VERBOSE_LOGS
no longer has an effect, use the--@aspect_rules_ts//ts:verbose=true
flag instead- Replace usage of
load("@aspect_rules_ts//ts:repositories.bzl", "LATEST_VERSION")
withLATEST_TYPESCRIPT_VERSION
- The
ts_project
macro now produces ats_project
rule. Any bazel query expressions, aspect implementations, or other "leaky abstractions" that keyed on the kind of the underlying rule being "ts_project_rule" will need to be updated to the new name "ts_project". - json inputs that are not sources and do not have an input / output collision are now declared
Using Bzlmod with Bazel 6:
Add to your MODULE.bazel
file:
bazel_dep(name = "aspect_rules_ts", version = "2.0.0-beta0")
rules_ts_ext = use_extension(
"@aspect_rules_ts//ts:extensions.bzl",
"ext",
dev_dependency = True,
)
rules_ts_ext.deps()
use_repo(rules_ts_ext, "npm_typescript")
Using WORKSPACE
Paste this snippet into your WORKSPACE
file:
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
name = "aspect_rules_ts",
sha256 = "71fff38c05c2b866dbada246f12f57db9c793e5fad36765223563e7f6a940bb0",
strip_prefix = "rules_ts-2.0.0-beta0",
url = "https://github.com/aspect-build/rules_ts/releases/download/v2.0.0-beta0/rules_ts-v2.0.0-beta0.tar.gz",
)
##################
# rules_ts setup #
##################
# Fetches the rules_ts dependencies.
# If you want to have a different version of some dependency,
# you should fetch it *before* calling this.
# Alternatively, you can skip calling this function, so long as you've
# already fetched all the dependencies.
load("@aspect_rules_ts//ts:repositories.bzl", "rules_ts_dependencies")
rules_ts_dependencies(
# This keeps the TypeScript version in-sync with the editor, which is typically best.
ts_version_from = "//:package.json",
# Alternatively, you could pick a specific version, or use
# load("@aspect_rules_ts//ts:repositories.bzl", "LATEST_TYPESCRIPT_VERSION")
# ts_version = LATEST_TYPESCRIPT_VERSION
)
# Fetch and register node, if you haven't already
load("@rules_nodejs//nodejs:repositories.bzl", "DEFAULT_NODE_VERSION", "nodejs_register_toolchains")
nodejs_register_toolchains(
name = "node",
node_version = DEFAULT_NODE_VERSION,
)
# Register aspect_bazel_lib toolchains;
# If you use npm_translate_lock or npm_import from aspect_rules_js you can omit this block.
load("@aspect_bazel_lib//lib:repositories.bzl", "register_copy_directory_toolchains", "register_copy_to_directory_toolchains")
register_copy_directory_toolchains()
register_copy_to_directory_toolchains()
What's Changed
- chore: fix docstring indents by @gregmagolan in #343
- feat: introduce skip_lib_check attribute by @thesayyn in #345
- Revert "feat: introduce skip_lib_check attribute" by @alexeagle in #347
- feat: skipLibCheck take 2 by @alexeagle in #350
- examples: add tsconfig types example by @jbedard in #351
- feat: implement custom flags for verbosity and workers by @thesayyn in #294
- feat: configure ts_project progress_message based on transpile/declaration config by @jbedard in #355
- fix: dictionary tsconfig extends with bzlmod by @jbedard in #358
- Updated typescript versions by @UebelAndre in #353
- docs: add troubleshooting docs about undeclared dependencies by @jbedard in #359
- refactor: consider json a js source (if resolve_json_module) by @gzm0 in #322
- chore: drop support for Bazel 5 by @alexeagle in #372
- fix: ts_project macro creates same-named rule by @alexeagle in #370
- feat: ask users about skipLibCheck when upgrading to 2.0 by @alexeagle in #371
- Move TS config validation to validation output group by @dzbarsky in #138
- chore: green up 2.x branch by @alexeagle in #396
- chore: readme updates for 2.0 by @alexeagle in #395
- feat(2.0): force users to choose a transpiler by @alexeagle in #397
- chore(2.0): remove LATEST_VERSION by @alexeagle in #403
- chore(2.0): remove VERBOSE_LOGS env var by @alexeagle in #402
- chore: flip supports_workers to default False by @alexeagle in #401
- chore(docs): move transpiler migration instructions to markdown by @alexeagle in #404
New Contributors
- @UebelAndre made their first contribution in #353
- @dzbarsky made their first contribution in #138
Full Changelog: v1.3.3...v2.0.0-beta0