Skip to content

Commit

Permalink
fix(gazelle): runfiles discovery (#1429)
Browse files Browse the repository at this point in the history
Pass the environment generated by the `runfiles` helper so that the
Python launcher can find the runfiles correctly as implemented in
bazelbuild/bazel#14740.

Fixes #1426
  • Loading branch information
aignas authored Sep 26, 2023
1 parent d8966b8 commit 2d6a886
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 3 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,8 @@ A brief description of the categories of changes:
dependencies improving initial build times involving external dependency
fetching.

* (gazelle) Improve runfiles lookup hermeticity.

## [0.25.0] - 2023-08-22

### Changed
Expand Down
9 changes: 8 additions & 1 deletion gazelle/python/parser.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,13 +38,20 @@ var (
)

func startParserProcess(ctx context.Context) {
parseScriptRunfile, err := runfiles.Rlocation("rules_python_gazelle_plugin/python/parse")
rfiles, err := runfiles.New()
if err != nil {
log.Printf("failed to create a runfiles object: %v\n", err)
os.Exit(1)
}

parseScriptRunfile, err := rfiles.Rlocation("rules_python_gazelle_plugin/python/parse")
if err != nil {
log.Printf("failed to initialize parser: %v\n", err)
os.Exit(1)
}

cmd := exec.CommandContext(ctx, parseScriptRunfile)
cmd.Env = append(os.Environ(), rfiles.Env()...)

cmd.Stderr = os.Stderr

Expand Down
11 changes: 9 additions & 2 deletions gazelle/python/std_modules.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,13 @@ var (
func startStdModuleProcess(ctx context.Context) {
stdModulesSeen = make(map[string]struct{})

stdModulesScriptRunfile, err := runfiles.Rlocation("rules_python_gazelle_plugin/python/std_modules")
rfiles, err := runfiles.New()
if err != nil {
log.Printf("failed to create a runfiles object: %v\n", err)
os.Exit(1)
}

stdModulesScriptRunfile, err := rfiles.Rlocation("rules_python_gazelle_plugin/python/std_modules")
if err != nil {
log.Printf("failed to initialize std_modules: %v\n", err)
os.Exit(1)
Expand All @@ -49,7 +55,8 @@ func startStdModuleProcess(ctx context.Context) {

cmd.Stderr = os.Stderr
// All userland site-packages should be ignored.
cmd.Env = []string{"PYTHONNOUSERSITE=1"}
cmd.Env = append([]string{"PYTHONNOUSERSITE=1"}, rfiles.Env()...)

stdin, err := cmd.StdinPipe()
if err != nil {
log.Printf("failed to initialize std_modules: %v\n", err)
Expand Down

0 comments on commit 2d6a886

Please sign in to comment.