Skip to content

Commit

Permalink
Revert "feat: accept (version, integrity) for pnpm_version (#1184)" (#…
Browse files Browse the repository at this point in the history
…1185)

This reverts commit 5f42dca.
  • Loading branch information
alexeagle authored Aug 2, 2023
1 parent 5f42dca commit 6474e48
Show file tree
Hide file tree
Showing 5 changed files with 8 additions and 34 deletions.
3 changes: 1 addition & 2 deletions MODULE.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,6 @@ use_repo(node, "nodejs_windows_amd64")
pnpm = use_extension("@aspect_rules_js//npm:extensions.bzl", "pnpm")
pnpm.pnpm(
name = "pnpm",
pnpm_version = "7.25.0",
pnpm_version_integrity = "sha512-FGFQUON8kJ6ma39elJ8lyD8wPIfgp3opGJD9sX0TgIJk4zSr556qCgC8AN+3BFHe4yuRkEauf4JVLW2RKyyEcA==",
)
use_repo(pnpm, "pnpm")
use_repo(pnpm, "pnpm__links")
Expand Down Expand Up @@ -176,6 +174,7 @@ npm.npm_translate_lock(
"meaning-of-life@1.0.0": ["//examples/npm_deps:patches/meaning-of-life@1.0.0-after_pnpm.patch"],
},
pnpm_lock = "//:pnpm-lock.yaml",
pnpm_version = "7.25.0",
public_hoist_packages = {
# Instructs the linker to hoist the ms@2.1.3 npm package to `node_modules/ms` in the `examples/npm_deps` package.
# Similar to adding `public-hoist-pattern[]=ms` in .npmrc but with control over which version to hoist and where
Expand Down
4 changes: 1 addition & 3 deletions WORKSPACE
Original file line number Diff line number Diff line change
Expand Up @@ -155,9 +155,7 @@ npm_translate_lock(
"meaning-of-life@1.0.0": ["//examples/npm_deps:patches/meaning-of-life@1.0.0-after_pnpm.patch"],
},
pnpm_lock = "//:pnpm-lock.yaml",
# Use a version that's not vendored into rules_js by providing a (version, integrity) tuple.
# curl --silent https://registry.npmjs.org/pnpm | jq '.versions["8.6.11"].dist.integrity'
pnpm_version = ("8.6.11", "sha512-jqknppuj45tDzJsLcLqkAxytBHZXIx9JTYkGNq0/7pSRggpio9wRxTDj4NA2ilOHPlJ5BVjB5Ij5dx65woMi5A=="),
pnpm_version = "8.6.0",
public_hoist_packages = {
# Instructs the linker to hoist the ms@2.1.3 npm package to `node_modules/ms` in the `examples/npm_deps` package.
# Similar to adding `public-hoist-pattern[]=ms` in .npmrc but with control over which version to hoist and where
Expand Down
6 changes: 3 additions & 3 deletions e2e/js_run_devserver/MODULE.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,6 @@ local_path_override(
path = "../..",
)

pnpm = use_extension("@aspect_rules_js//npm:extensions.bzl", "pnpm")
use_repo(pnpm, "pnpm")

npm = use_extension("@aspect_rules_js//npm:extensions.bzl", "npm")
npm.npm_translate_lock(
name = "npm",
Expand All @@ -31,6 +28,9 @@ npm.npm_translate_lock(
)
use_repo(npm, "npm")

pnpm = use_extension("@aspect_rules_js//npm:extensions.bzl", "pnpm")
use_repo(pnpm, "pnpm")

go_sdk = use_extension("@rules_go//go:extensions.bzl", "go_sdk")
go_sdk.download(
name = "go_sdk",
Expand Down
16 changes: 2 additions & 14 deletions npm/extensions.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -161,10 +161,6 @@ def _npm_translate_lock_attrs():
attrs["name"] = attr.string()
attrs["lifecycle_hooks_exclude"] = attr.string_list(default = [])
attrs["lifecycle_hooks_no_sandbox"] = attr.bool(default = True)

# Note, pnpm_version can't be a tuple here, so we can't accept the integrity hash.
# This is okay since you can just call the pnpm module extension below first.
# TODO(2.0): drop pnpm_version from this module extension
attrs["pnpm_version"] = attr.string(default = LATEST_PNPM_VERSION)
attrs["run_lifecycle_hooks"] = attr.bool(default = True)

Expand Down Expand Up @@ -201,20 +197,12 @@ def _pnpm_impl(module_ctx):
for attr in mod.tags.pnpm:
pnpm_repository(
name = attr.name,
pnpm_version = (
(attr.pnpm_version, attr.pnpm_version_integrity) if attr.pnpm_version_integrity else attr.pnpm_version
),
pnpm_version = attr.pnpm_version,
)

pnpm = module_extension(
implementation = _pnpm_impl,
tag_classes = {
"pnpm": tag_class(
attrs = {
"name": attr.string(),
"pnpm_version": attr.string(default = LATEST_PNPM_VERSION),
"pnpm_version_integrity": attr.string(),
},
),
"pnpm": tag_class(attrs = {"name": attr.string(), "pnpm_version": attr.string(default = LATEST_PNPM_VERSION)}),
},
)
13 changes: 1 addition & 12 deletions npm/private/pnpm_repository.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -15,23 +15,12 @@ def pnpm_repository(name, pnpm_version = LATEST_PNPM_VERSION):
Args:
name: name of the resulting external repository
pnpm_version: version of pnpm, see https://www.npmjs.com/package/pnpm?activeTab=versions
May also be a tuple of (version, integrity) where the integrity value may be fetched like:
`curl --silent https://registry.npmjs.org/pnpm | jq '.versions["8.6.11"].dist.integrity'`
"""

if not native.existing_rule(name):
if type(pnpm_version) == "tuple":
integrity = pnpm_version[1]
pnpm_version = pnpm_version[0]
elif type(pnpm_version) == "string":
integrity = PNPM_VERSIONS[pnpm_version]
else:
fail("pnpm_version should be string or tuple, got " + type(pnpm_version))

_npm_import(
name = name,
integrity = integrity,
integrity = PNPM_VERSIONS[pnpm_version],
package = "pnpm",
root_package = "",
version = pnpm_version,
Expand Down

0 comments on commit 6474e48

Please sign in to comment.