/* * Copyright 2017-present Facebook, Inc. * * 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.facebook.buck.distributed; import com.facebook.buck.distributed.thrift.BuildJobStateFileHashEntry; import com.facebook.buck.distributed.thrift.BuildJobStateFileHashes; import com.facebook.buck.io.ArchiveMemberPath; import com.google.common.collect.Sets; import java.nio.file.Path; import java.util.Set; public class RecordedFileHashes { private final BuildJobStateFileHashes remoteFileHashes; private final Set<Path> seenPaths; private final Set<ArchiveMemberPath> seenArchiveMemberPaths; public RecordedFileHashes(Integer cellIndex) { this.remoteFileHashes = new BuildJobStateFileHashes(); this.remoteFileHashes.setCellIndex(cellIndex); this.seenPaths = Sets.newHashSet(); this.seenArchiveMemberPaths = Sets.newHashSet(); } public synchronized boolean containsAndAddPath(Path relPath) { return !seenPaths.add(relPath); } public synchronized boolean containsAndAddPath(ArchiveMemberPath relPath) { return seenArchiveMemberPaths.contains(relPath); } public synchronized void addEntry(BuildJobStateFileHashEntry entry) { remoteFileHashes.addToEntries(entry); } public BuildJobStateFileHashes getRemoteFileHashes() { return remoteFileHashes; } }