Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

go-jsonnet fails as a dependency in bzlmod using Gazelle #779

Open
antholeole opened this issue Dec 18, 2024 · 3 comments
Open

go-jsonnet fails as a dependency in bzlmod using Gazelle #779

antholeole opened this issue Dec 18, 2024 · 3 comments

Comments

@antholeole
Copy link

antholeole commented Dec 18, 2024

x-post from stackoverflow

I've put together an MVP for a build failure relating to gazelle and com_github_google_go_jsonnet: https://github.com/antholeole/bug-repro/tree/bazel

in short, I have a BUILD.bazel that looks like this:

go_library(
    name = "src_lib",
    srcs = ["main.go"],
    importpath = "repro/src",
    visibility = ["//visibility:private"],
    deps = ["@com_github_google_go_jsonnet//:go-jsonnet"],
)

building the target (in the repro, //src:src) gives the following output:

no such package '@@[unk
nown repo 'cpp_jsonnet' requested from @@gazelle++go_deps+com_github_google_go_jsonnet]//stdlib': The repository '@@[unknown repo 'cpp_jsonnet' requested from @@gazelle++go_deps+com_
github_google_go_jsonnet]' could not be resolved: No repository visible as '@cpp_jsonnet' from repository '@@gazelle++go_deps+com_github_google_go_jsonnet' and referenced by '@@gazel
le++go_deps+com_github_google_go_jsonnet//astgen:dumpstdlibast'

is there any way to supply the dependency with @cpp_jsonnet? I've tried to add a module that looks like that to the MODULE.bazel (the error changed but did not go away completely), but it smells like an antipattern. Hopefully there's an easier way to get jsonnet with gazelle.

@linhua11
Copy link

linhua11 commented Jan 6, 2025

is there any fix to this?

@linhua11
Copy link

linhua11 commented Jan 7, 2025

@antholeole

For anyone having the similiar issue, fixed it by
#keep
go_repository(
name = "com_github_google_go_jsonnet",
importpath = "github.com/google/go-jsonnet",
repo_mapping = {"@cpp_jsonnet": "@com_github_google_jsonnet"},
sum = "h1:WG4TTSARuV7bSm4PMB4ohjxe33IHT5WVTrJSU33uT4g=",
version = "v0.20.0",
)

#keep
go_repository(
name = "com_github_google_jsonnet",
importpath = "github.com/google/jsonnet",
sum = "h1:JZkvqvtuPRJ3l6aqlhMAHeYR3SOzaD8VpCR5GVpaR/0=",
version = "v0.20.0",
)

@antholeole
Copy link
Author

@linhua11 thanks! I haven't tried this yet. once i do I'll close if it works.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants