From 59fcd70c8d718624a3ab107440debbfab51e0c50 Mon Sep 17 00:00:00 2001 From: Matt Sloan Date: Mon, 24 Aug 2015 00:28:12 -0700 Subject: [PATCH] Use Path instead of string to check file exclusions to fix windows-only bug where files were not being correctly excluded. --- .../java/net/sourceforge/pmd/cpd/CPDConfiguration.java | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/pmd-core/src/main/java/net/sourceforge/pmd/cpd/CPDConfiguration.java b/pmd-core/src/main/java/net/sourceforge/pmd/cpd/CPDConfiguration.java index 9b25d16402..ac871a9b0e 100644 --- a/pmd-core/src/main/java/net/sourceforge/pmd/cpd/CPDConfiguration.java +++ b/pmd-core/src/main/java/net/sourceforge/pmd/cpd/CPDConfiguration.java @@ -10,6 +10,7 @@ import java.io.FilenameFilter; import java.io.Reader; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; +import java.nio.file.Path; import java.util.Arrays; import java.util.HashMap; import java.util.HashSet; @@ -277,7 +278,7 @@ public class CPDConfiguration extends AbstractConfiguration { } final FilenameFilter languageFilter = language.getFileFilter(); - final Set exclusions = new HashSet(); + final Set exclusions = new HashSet(); if (excludes != null) { FileFinder finder = new FileFinder(); @@ -285,10 +286,10 @@ public class CPDConfiguration extends AbstractConfiguration { if (excludedFile.isDirectory()) { List files = finder.findFilesFrom(excludedFile, languageFilter, true); for (File f : files) { - exclusions.add(f.getAbsolutePath()); + exclusions.add(f.toPath()); } } else { - exclusions.add(excludedFile.getAbsolutePath()); + exclusions.add(excludedFile.toPath()); } } } @@ -296,7 +297,7 @@ public class CPDConfiguration extends AbstractConfiguration { FilenameFilter filter = new FilenameFilter() { public boolean accept(File dir, String name) { File f = new File(dir, name); - if (exclusions.contains(f.getAbsolutePath())) { + if (exclusions.contains(f.toPath())) { System.err.println("Excluding " + f.getAbsolutePath()); return false; }