|
33 | 33 | import java.util.ArrayList;
|
34 | 34 | import java.util.Arrays;
|
35 | 35 | import java.util.Collections;
|
| 36 | +import java.util.HashMap; |
36 | 37 | import java.util.HashSet;
|
37 | 38 | import java.util.List;
|
| 39 | +import java.util.Map; |
38 | 40 | import java.util.Objects;
|
39 | 41 | import java.util.Optional;
|
40 | 42 | import java.util.Set;
|
@@ -92,6 +94,13 @@ public Executor setExecutable(JavaTool v) {
|
92 | 94 |
|
93 | 95 | public Executor removeEnvVar(String envVarName) {
|
94 | 96 | removeEnvVars.add(Objects.requireNonNull(envVarName));
|
| 97 | + setEnvVars.remove(envVarName); |
| 98 | + return this; |
| 99 | + } |
| 100 | + |
| 101 | + public Executor setEnvVar(String envVarName, String envVarValue) { |
| 102 | + setEnvVars.put(Objects.requireNonNull(envVarName), Objects.requireNonNull(envVarValue)); |
| 103 | + removeEnvVars.remove(envVarName); |
95 | 104 | return this;
|
96 | 105 | }
|
97 | 106 |
|
@@ -370,9 +379,25 @@ private Result runExecutable() throws IOException, InterruptedException {
|
370 | 379 | builder.directory(directory.toFile());
|
371 | 380 | sb.append(String.format("; in directory [%s]", directory));
|
372 | 381 | }
|
| 382 | + if (!setEnvVars.isEmpty()) { |
| 383 | + final var defaultEnv = builder.environment(); |
| 384 | + final var envComm = Comm.compare(defaultEnv.keySet(), setEnvVars.keySet()); |
| 385 | + envComm.unique2().forEach(envVar -> { |
| 386 | + TKit.trace(String.format("Adding %s=[%s] to environment", envVar, setEnvVars.get(envVar))); |
| 387 | + }); |
| 388 | + envComm.common().forEach(envVar -> { |
| 389 | + final var curValue = defaultEnv.get(envVar); |
| 390 | + final var newValue = setEnvVars.get(envVar); |
| 391 | + if (!curValue.equals(newValue)) { |
| 392 | + TKit.trace(String.format("Setting %s=[%s] in environment", envVar, setEnvVars.get(envVar))); |
| 393 | + } |
| 394 | + }); |
| 395 | + defaultEnv.putAll(setEnvVars); |
| 396 | + } |
373 | 397 | if (!removeEnvVars.isEmpty()) {
|
374 |
| - final var envComm = Comm.compare(builder.environment().keySet(), removeEnvVars); |
375 |
| - builder.environment().keySet().removeAll(envComm.common()); |
| 398 | + final var defaultEnv = builder.environment().keySet(); |
| 399 | + final var envComm = Comm.compare(defaultEnv, removeEnvVars); |
| 400 | + defaultEnv.removeAll(envComm.common()); |
376 | 401 | envComm.common().forEach(envVar -> {
|
377 | 402 | TKit.trace(String.format("Clearing %s in environment", envVar));
|
378 | 403 | });
|
@@ -515,6 +540,7 @@ private static void trace(String msg) {
|
515 | 540 | private Set<SaveOutputType> saveOutputType;
|
516 | 541 | private Path directory;
|
517 | 542 | private Set<String> removeEnvVars = new HashSet<>();
|
| 543 | + private Map<String, String> setEnvVars = new HashMap<>(); |
518 | 544 | private boolean winEnglishOutput;
|
519 | 545 | private String winTmpDir = null;
|
520 | 546 |
|
|
0 commit comments