org.gradle.internal.fingerprint.impl.NormalizedPathFingerprintCompareStrategy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2018 the original author or authors.
*
* 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 org.gradle.internal.fingerprint.impl;
import com.google.common.collect.ListMultimap;
import com.google.common.collect.Lists;
import com.google.common.collect.MultimapBuilder;
import org.gradle.internal.change.ChangeVisitor;
import org.gradle.internal.change.FileChange;
import org.gradle.internal.fingerprint.FileSystemLocationFingerprint;
import org.gradle.internal.fingerprint.FingerprintCompareStrategy;
import org.gradle.internal.hash.Hasher;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Map;
/**
* Compares by normalized path (relative/name only) and file contents. Order does not matter.
*/
public class NormalizedPathFingerprintCompareStrategy extends AbstractFingerprintCompareStrategy {
public static final FingerprintCompareStrategy INSTANCE = new NormalizedPathFingerprintCompareStrategy();
private static final Comparator> ENTRY_COMPARATOR = new Comparator>() {
@Override
public int compare(Map.Entry o1, Map.Entry o2) {
return o1.getKey().compareTo(o2.getKey());
}
};
private NormalizedPathFingerprintCompareStrategy() {
}
/**
* Determines changes by:
*
*
* - Determining which {@link FileSystemLocationFingerprint}s are only in the previous or current fingerprint collection.
* -
* For those only in the previous fingerprint collection it checks if some entry with the same normalized path is in the current collection.
* If it is, file is reported as modified, if not as removed.
*
* - Finally, if {@code includeAdded} is {@code true}, the remaining fingerprints which are only in the current collection are reported as added.
*
*/
@Override
protected boolean doVisitChangesSince(ChangeVisitor visitor, Map currentFingerprints, Map previousFingerprints, String propertyTitle, boolean includeAdded) {
ListMultimap unaccountedForPreviousFiles = MultimapBuilder.hashKeys(previousFingerprints.size()).linkedListValues().build();
ListMultimap addedFilesByNormalizedPath = MultimapBuilder.linkedHashKeys().linkedListValues().build();
for (Map.Entry entry : previousFingerprints.entrySet()) {
String absolutePath = entry.getKey();
FileSystemLocationFingerprint previousFingerprint = entry.getValue();
unaccountedForPreviousFiles.put(previousFingerprint, new FilePathWithType(absolutePath, previousFingerprint.getType()));
}
for (Map.Entry entry : currentFingerprints.entrySet()) {
String currentAbsolutePath = entry.getKey();
FileSystemLocationFingerprint currentFingerprint = entry.getValue();
List previousFilesForFingerprint = unaccountedForPreviousFiles.get(currentFingerprint);
if (previousFilesForFingerprint.isEmpty()) {
addedFilesByNormalizedPath.put(currentFingerprint.getNormalizedPath(), new FilePathWithType(currentAbsolutePath, currentFingerprint.getType()));
} else {
previousFilesForFingerprint.remove(0);
}
}
List> unaccountedForPreviousEntries = Lists.newArrayList(unaccountedForPreviousFiles.entries());
Collections.sort(unaccountedForPreviousEntries, ENTRY_COMPARATOR);
for (Map.Entry unaccountedForPreviousFingerprintEntry : unaccountedForPreviousEntries) {
FileSystemLocationFingerprint previousFingerprint = unaccountedForPreviousFingerprintEntry.getKey();
String normalizedPath = previousFingerprint.getNormalizedPath();
List addedFilesForNormalizedPath = addedFilesByNormalizedPath.get(normalizedPath);
if (!addedFilesForNormalizedPath.isEmpty()) {
// There might be multiple files with the same normalized path, here we choose one of them
FilePathWithType addedFile = addedFilesForNormalizedPath.remove(0);
if (!visitor.visitChange(FileChange.modified(addedFile.getAbsolutePath(), propertyTitle, previousFingerprint.getType(), addedFile.getFileType()))) {
return false;
}
} else {
FilePathWithType removedFile = unaccountedForPreviousFingerprintEntry.getValue();
if (!visitor.visitChange(FileChange.removed(removedFile.getAbsolutePath(), propertyTitle, removedFile.getFileType()))) {
return false;
}
}
}
if (includeAdded) {
for (FilePathWithType addedFile : addedFilesByNormalizedPath.values()) {
if (!visitor.visitChange(FileChange.added(addedFile.getAbsolutePath(), propertyTitle, addedFile.getFileType()))) {
return false;
}
}
}
return true;
}
@Override
public void appendToHasher(Hasher hasher, Collection fingerprints) {
appendSortedToHasher(hasher, fingerprints);
}
public static void appendSortedToHasher(Hasher hasher, Collection fingerprints) {
List sortedFingerprints = Lists.newArrayList(fingerprints);
Collections.sort(sortedFingerprints);
for (FileSystemLocationFingerprint normalizedSnapshot : sortedFingerprints) {
normalizedSnapshot.appendToHasher(hasher);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy