// Copyright 2015 The Bazel Authors. All rights reserved. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package com.google.devtools.build.lib.worker; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; import com.google.common.hash.HashCode; import com.google.devtools.build.lib.actions.BaseSpawn; import com.google.devtools.build.lib.util.Preconditions; import com.google.devtools.build.lib.vfs.Path; import java.util.List; import java.util.Map; /** * Data container that uniquely identifies a kind of worker process and is used as the key for the * {@link WorkerPool}. */ final class WorkerKey { private final ImmutableList args; private final ImmutableMap env; private final Path workDir; private final String mnemonic; /** * This is used during validation whether a worker is still usable. It is not used to uniquely * identify a kind of worker, thus it is not to be used by the .equals() / .hashCode() methods. */ private final HashCode workerFilesHash; WorkerKey( List args, Map env, Path workDir, String mnemonic, HashCode workerFilesHash) { this.args = ImmutableList.copyOf(Preconditions.checkNotNull(args)); this.env = ImmutableMap.copyOf(Preconditions.checkNotNull(env)); this.workDir = Preconditions.checkNotNull(workDir); this.mnemonic = Preconditions.checkNotNull(mnemonic); this.workerFilesHash = Preconditions.checkNotNull(workerFilesHash); } public ImmutableList getArgs() { return args; } public ImmutableMap getEnv() { return env; } public Path getWorkDir() { return workDir; } public String getMnemonic() { return mnemonic; } public HashCode getWorkerFilesHash() { return workerFilesHash; } @Override public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } WorkerKey workerKey = (WorkerKey) o; if (!args.equals(workerKey.args)) { return false; } if (!env.equals(workerKey.env)) { return false; } if (!workDir.equals(workerKey.workDir)) { return false; } return mnemonic.equals(workerKey.mnemonic); } @Override public int hashCode() { int result = args.hashCode(); result = 31 * result + env.hashCode(); result = 31 * result + workDir.hashCode(); result = 31 * result + mnemonic.hashCode(); return result; } @Override public String toString() { return BaseSpawn.asShellCommand(args, workDir, env); } }