aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-duplications
diff options
context:
space:
mode:
authorEvgeny Mandrikov <mandrikov@gmail.com>2012-01-10 02:50:01 +0400
committerEvgeny Mandrikov <mandrikov@gmail.com>2012-01-10 03:15:32 +0400
commit6bf81a45122cf287999a95638968147ac58e0e6a (patch)
tree59cb9d9e0f626341d37401065ecd6148e1f2571b /sonar-duplications
parenta3509a17ff32da47721d48c59768dacc2e86b3cd (diff)
downloadsonarqube-6bf81a45122cf287999a95638968147ac58e0e6a.tar.gz
sonarqube-6bf81a45122cf287999a95638968147ac58e0e6a.zip
SONAR-3139 Refactor our fork of PMD CPD
* Replace some code by our own implementation * Remove unused * Reformat to conform with our conventions
Diffstat (limited to 'sonar-duplications')
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AbstractLanguage.java55
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyLanguage.java30
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyTokenizer.java72
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDListener.java14
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDNullListener.java8
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileFinder.java30
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileReporter.java67
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Language.java10
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/ReportException.java34
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/SourceCode.java192
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/TokenEntry.java144
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokenizer.java2
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokens.java44
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserConstants.java417
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserTokenManager.java1707
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/ParseException.java218
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/SimpleCharStream.java496
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/Token.java144
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/TokenMgrError.java160
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/FileFinder.java50
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/StringUtil.java330
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractCompoundFilter.java76
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractDelegateFilter.java57
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AndFilter.java54
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/DirectoryFilter.java37
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/FileExtensionFilter.java62
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filter.java31
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filters.java220
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/NotFilter.java45
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/OrFilter.java54
-rw-r--r--sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/RegexStringFilter.java60
-rw-r--r--sonar-duplications/src/main/java/org/sonar/duplications/cpd/CPD.java1
-rw-r--r--sonar-duplications/src/main/java/org/sonar/duplications/cpd/Match.java6
-rw-r--r--sonar-duplications/src/main/java/org/sonar/duplications/cpd/MatchCollector.java23
-rw-r--r--sonar-duplications/src/test/java/net/sourceforge/pmd/cpd/AbstractLanguageTest.java62
35 files changed, 346 insertions, 4666 deletions
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AbstractLanguage.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AbstractLanguage.java
index f60f2f80044..f790339b41b 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AbstractLanguage.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AbstractLanguage.java
@@ -20,24 +20,51 @@
package net.sourceforge.pmd.cpd;
-import net.sourceforge.pmd.util.filter.Filters;
-
+import java.io.File;
import java.io.FilenameFilter;
public abstract class AbstractLanguage implements Language {
- private final Tokenizer tokenizer;
- private final FilenameFilter fileFilter;
+ private final Tokenizer tokenizer;
+ private final FilenameFilter fileFilter;
+
+ public AbstractLanguage(Tokenizer tokenizer, String... extensions) {
+ this.tokenizer = tokenizer;
+ fileFilter = new ExtensionsFilter(extensions);
+ }
+
+ /**
+ * @deprecated in 2.14, seems that not used in Sonar ecosystem - we don't scan directories.
+ */
+ public FilenameFilter getFileFilter() {
+ return fileFilter;
+ }
+
+ public Tokenizer getTokenizer() {
+ return tokenizer;
+ }
- public AbstractLanguage(Tokenizer tokenizer, String... extensions) {
- this.tokenizer = tokenizer;
- fileFilter = net.sourceforge.pmd.util.filter.Filters.toFilenameFilter(Filters.getFileExtensionOrDirectoryFilter(extensions));
- }
+ private static class ExtensionsFilter implements FilenameFilter {
+ private final String[] extensions;
- public FilenameFilter getFileFilter() {
- return fileFilter;
- }
+ public ExtensionsFilter(String... extensions) {
+ this.extensions = new String[extensions.length];
+ for (int i = 0; i < extensions.length; i++) {
+ this.extensions[i] = extensions[i].toUpperCase();
+ }
+ }
- public Tokenizer getTokenizer() {
- return tokenizer;
- }
+ public boolean accept(File dir, String name) {
+ File file = new File(dir, name);
+ if (file.isDirectory()) {
+ return true;
+ }
+ String uppercaseName = name.toUpperCase();
+ for (String extension : extensions) {
+ if (uppercaseName.endsWith(extension)) {
+ return true;
+ }
+ }
+ return false;
+ }
+ }
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyLanguage.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyLanguage.java
deleted file mode 100644
index b3c094e4cd3..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyLanguage.java
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/**
- * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
- */
-package net.sourceforge.pmd.cpd;
-
-public class AnyLanguage extends AbstractLanguage {
- public AnyLanguage(String extension) {
- super(new AnyTokenizer(), extension);
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyTokenizer.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyTokenizer.java
deleted file mode 100644
index 595fa235b45..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/AnyTokenizer.java
+++ /dev/null
@@ -1,72 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/**
- * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
- */
-package net.sourceforge.pmd.cpd;
-
-import java.io.BufferedReader;
-import java.io.CharArrayReader;
-import java.util.NoSuchElementException;
-import java.util.StringTokenizer;
-
-/**
- * This class does a best-guess try-anything tokenization.
- *
- * @author jheintz
- */
-public class AnyTokenizer implements Tokenizer {
- public static final String TOKENS = " \t!#$%^&*(){}-=+<>/\\`~;:";
-
- public void tokenize(SourceCode sourceCode, Tokens tokenEntries) {
- StringBuffer sb = sourceCode.getCodeBuffer();
- BufferedReader reader = new BufferedReader(new CharArrayReader(sb.toString().toCharArray()));
- try {
- int lineNumber = 1;
- String line = reader.readLine();
- while (line != null) {
- StringTokenizer tokenizer = new StringTokenizer(line, TOKENS, true);
- try {
- String token = tokenizer.nextToken();
- while (token != null) {
- if (!token.equals(" ") && !token.equals("\t")) {
- tokenEntries.add(new TokenEntry(token, sourceCode.getFileName(), lineNumber));
- }
- token = tokenizer.nextToken();
- }
- } catch (NoSuchElementException ex) {
- // done with tokens
- }
- // advance iteration variables
- line = reader.readLine();
- lineNumber++;
- }
- } catch (Exception ex) {
- ex.printStackTrace();
- } finally {
- try {
- reader.close();
- } catch (Exception ex) {
- }
- tokenEntries.add(TokenEntry.getEOF());
- }
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDListener.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDListener.java
index fa17bce8d2e..fa8f455e586 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDListener.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDListener.java
@@ -27,13 +27,13 @@ import java.io.File;
public interface CPDListener {
- public static final int INIT = 0;
- public static final int HASH = 1;
- public static final int MATCH = 2;
- public static final int GROUPING = 3;
- public static final int DONE = 4;
+ public static final int INIT = 0;
+ public static final int HASH = 1;
+ public static final int MATCH = 2;
+ public static final int GROUPING = 3;
+ public static final int DONE = 4;
- void addedFile(int fileCount, File file);
+ void addedFile(int fileCount, File file);
- void phaseUpdate(int phase);
+ void phaseUpdate(int phase);
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDNullListener.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDNullListener.java
index 13a97b24346..e2e33c13eda 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDNullListener.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/CPDNullListener.java
@@ -26,9 +26,9 @@ package net.sourceforge.pmd.cpd;
import java.io.File;
public class CPDNullListener implements CPDListener {
- public void addedFile(int fileCount, File file) {
- }
+ public void addedFile(int fileCount, File file) {
+ }
- public void phaseUpdate(int phase) {
- }
+ public void phaseUpdate(int phase) {
+ }
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileFinder.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileFinder.java
deleted file mode 100644
index f2c61bd25d2..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileFinder.java
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/**
- * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
- */
-package net.sourceforge.pmd.cpd;
-
-/**
- * @deprecated Use net.sourceforge.pmd.util.FileFinder instead.
- */
-public class FileFinder extends net.sourceforge.pmd.util.FileFinder {
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileReporter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileReporter.java
deleted file mode 100644
index 6c530b690a3..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/FileReporter.java
+++ /dev/null
@@ -1,67 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/**
- * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
- */
-package net.sourceforge.pmd.cpd;
-
-import java.io.*;
-
-/**
- * @author Philippe T'Seyen
- */
-public class FileReporter {
- private File reportFile;
- private String encoding;
-
- public FileReporter(String encoding) {
- this(null, encoding);
- }
-
- public FileReporter(File reportFile) {
- this(reportFile, System.getProperty("file.encoding"));
- }
-
- public FileReporter(File reportFile, String encoding) {
- this.reportFile = reportFile;
- this.encoding = encoding;
- }
-
- public void report(String content) throws ReportException {
- try {
- Writer writer = null;
- try {
- OutputStream outputStream;
- if (reportFile == null) {
- outputStream = System.out;
- } else {
- outputStream = new FileOutputStream(reportFile);
- }
- writer = new BufferedWriter(new OutputStreamWriter(outputStream, encoding));
- writer.write(content);
- } finally {
- if (writer != null) writer.close();
- }
- } catch (IOException ioe) {
- throw new ReportException(ioe);
- }
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Language.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Language.java
index f9f418d64c0..6e3a5b4b29d 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Language.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Language.java
@@ -26,10 +26,10 @@ package net.sourceforge.pmd.cpd;
import java.io.FilenameFilter;
public interface Language {
-
- String fileSeparator = System.getProperty("file.separator");
-
- public Tokenizer getTokenizer();
- public FilenameFilter getFileFilter();
+ String fileSeparator = System.getProperty("file.separator");
+
+ public Tokenizer getTokenizer();
+
+ public FilenameFilter getFileFilter();
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/ReportException.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/ReportException.java
deleted file mode 100644
index f2d371b45cb..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/ReportException.java
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/**
- * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
- */
-package net.sourceforge.pmd.cpd;
-
-/**
- * @author Philippe T'Seyen
- */
-public class ReportException extends Exception {
-
- public ReportException(Throwable cause) {
- super();
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/SourceCode.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/SourceCode.java
index 2ce2ea4b42c..3e89bd5c42f 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/SourceCode.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/SourceCode.java
@@ -32,125 +32,125 @@ public class SourceCode {
public static final String EOL = System.getProperty("line.separator", "\n");
- public static abstract class CodeLoader {
- private SoftReference<List<String>> code;
-
- public List<String> getCode() {
- List<String> c = null;
- if (code != null) {
- c = code.get();
- }
- if (c != null) {
- return c;
- }
- this.code = new SoftReference<List<String>>(load());
- return code.get();
- }
+ public static abstract class CodeLoader {
+ private SoftReference<List<String>> code;
- public abstract String getFileName();
-
- protected abstract Reader getReader() throws Exception;
-
- protected List<String> load() {
- LineNumberReader lnr = null;
- try {
- lnr = new LineNumberReader(getReader());
- List<String> lines = new ArrayList<String>();
- String currentLine;
- while ((currentLine = lnr.readLine()) != null) {
- lines.add(currentLine);
- }
- return lines;
- } catch (Exception e) {
- e.printStackTrace();
- throw new RuntimeException("Problem while reading " + getFileName() + ":" + e.getMessage());
- } finally {
- try {
- if (lnr != null)
- lnr.close();
- } catch (Exception e) {
- throw new RuntimeException("Problem while reading " + getFileName() + ":" + e.getMessage());
- }
- }
- }
+ public List<String> getCode() {
+ List<String> c = null;
+ if (code != null) {
+ c = code.get();
+ }
+ if (c != null) {
+ return c;
+ }
+ this.code = new SoftReference<List<String>>(load());
+ return code.get();
}
- public static class FileCodeLoader extends CodeLoader {
- private File file;
- private String encoding;
+ public abstract String getFileName();
- public FileCodeLoader(File file, String encoding) {
- this.file = file;
- this.encoding = encoding;
- }
+ protected abstract Reader getReader() throws Exception;
- public Reader getReader() throws Exception {
- return new InputStreamReader(new FileInputStream(file), encoding);
+ protected List<String> load() {
+ LineNumberReader lnr = null;
+ try {
+ lnr = new LineNumberReader(getReader());
+ List<String> lines = new ArrayList<String>();
+ String currentLine;
+ while ((currentLine = lnr.readLine()) != null) {
+ lines.add(currentLine);
}
-
- public String getFileName() {
- return this.file.getAbsolutePath();
+ return lines;
+ } catch (Exception e) {
+ e.printStackTrace();
+ throw new RuntimeException("Problem while reading " + getFileName() + ":" + e.getMessage());
+ } finally {
+ try {
+ if (lnr != null)
+ lnr.close();
+ } catch (Exception e) {
+ throw new RuntimeException("Problem while reading " + getFileName() + ":" + e.getMessage());
}
+ }
}
+ }
- public static class StringCodeLoader extends CodeLoader {
- public static final String DEFAULT_NAME = "CODE_LOADED_FROM_STRING";
+ public static class FileCodeLoader extends CodeLoader {
+ private File file;
+ private String encoding;
- private String source_code;
+ public FileCodeLoader(File file, String encoding) {
+ this.file = file;
+ this.encoding = encoding;
+ }
- private String name;
+ public Reader getReader() throws Exception {
+ return new InputStreamReader(new FileInputStream(file), encoding);
+ }
- public StringCodeLoader(String code) {
- this(code, DEFAULT_NAME);
- }
+ public String getFileName() {
+ return this.file.getAbsolutePath();
+ }
+ }
- public StringCodeLoader(String code, String name) {
- this.source_code = code;
- this.name = name;
- }
+ public static class StringCodeLoader extends CodeLoader {
+ public static final String DEFAULT_NAME = "CODE_LOADED_FROM_STRING";
- public Reader getReader() {
- return new StringReader(source_code);
- }
+ private String source_code;
- public String getFileName() {
- return name;
- }
- }
-
- private CodeLoader cl;
+ private String name;
- public SourceCode(CodeLoader cl) {
- this.cl = cl;
+ public StringCodeLoader(String code) {
+ this(code, DEFAULT_NAME);
}
- public List<String> getCode() {
- return cl.getCode();
+ public StringCodeLoader(String code, String name) {
+ this.source_code = code;
+ this.name = name;
}
- public StringBuffer getCodeBuffer() {
- StringBuffer sb = new StringBuffer();
- List<String> lines = cl.getCode();
- for ( String line : lines ) {
- sb.append(line);
- sb.append(EOL);
- }
- return sb;
+ public Reader getReader() {
+ return new StringReader(source_code);
}
- public String getSlice(int startLine, int endLine) {
- StringBuffer sb = new StringBuffer();
- List lines = cl.getCode();
- for (int i = (startLine == 0 ? startLine :startLine - 1); i < endLine && i < lines.size(); i++) {
- if (sb.length() != 0) {
- sb.append(EOL);
- }
- sb.append((String) lines.get(i));
- }
- return sb.toString();
+ public String getFileName() {
+ return name;
}
+ }
- public String getFileName() {
- return cl.getFileName();
+ private CodeLoader cl;
+
+ public SourceCode(CodeLoader cl) {
+ this.cl = cl;
+ }
+
+ public List<String> getCode() {
+ return cl.getCode();
+ }
+
+ public StringBuffer getCodeBuffer() {
+ StringBuffer sb = new StringBuffer();
+ List<String> lines = cl.getCode();
+ for (String line : lines) {
+ sb.append(line);
+ sb.append(EOL);
+ }
+ return sb;
+ }
+
+ public String getSlice(int startLine, int endLine) {
+ StringBuffer sb = new StringBuffer();
+ List lines = cl.getCode();
+ for (int i = (startLine == 0 ? startLine : startLine - 1); i < endLine && i < lines.size(); i++) {
+ if (sb.length() != 0) {
+ sb.append(EOL);
+ }
+ sb.append((String) lines.get(i));
}
+ return sb.toString();
+ }
+
+ public String getFileName() {
+ return cl.getFileName();
+ }
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/TokenEntry.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/TokenEntry.java
index 1da17017bf5..2586b560fa5 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/TokenEntry.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/TokenEntry.java
@@ -28,77 +28,77 @@ import java.util.Map;
public class TokenEntry implements Comparable<TokenEntry> {
- public static final TokenEntry EOF = new TokenEntry();
-
- private String tokenSrcID;
- private int beginLine;
- private int index;
- private int identifier;
- private int hashCode;
-
- private final static Map<String, Integer> Tokens = new HashMap<String, Integer>();
- private static int TokenCount = 0;
-
- private TokenEntry() {
- this.identifier = 0;
- this.tokenSrcID = "EOFMarker";
- }
-
- public TokenEntry(String image, String tokenSrcID, int beginLine) {
- Integer i = Tokens.get(image);
- if (i == null) {
- i = Tokens.size() + 1;
- Tokens.put(image, i);
- }
- this.identifier = i.intValue();
- this.tokenSrcID = tokenSrcID;
- this.beginLine = beginLine;
- this.index = TokenCount++;
- }
-
- public static TokenEntry getEOF() {
- TokenCount++;
- return EOF;
- }
-
- public static void clearImages() {
- Tokens.clear();
- TokenCount = 0;
- }
-
- public String getTokenSrcID() {
- return tokenSrcID;
- }
-
- public int getBeginLine() {
- return beginLine;
- }
-
- public int getIdentifier() {
- return this.identifier;
- }
-
- public int getIndex() {
- return this.index;
- }
-
- public int hashCode() {
- return hashCode;
- }
-
- public void setHashCode(int hashCode) {
- this.hashCode = hashCode;
+ public static final TokenEntry EOF = new TokenEntry();
+
+ private String tokenSrcID;
+ private int beginLine;
+ private int index;
+ private int identifier;
+ private int hashCode;
+
+ private final static Map<String, Integer> Tokens = new HashMap<String, Integer>();
+ private static int TokenCount = 0;
+
+ private TokenEntry() {
+ this.identifier = 0;
+ this.tokenSrcID = "EOFMarker";
+ }
+
+ public TokenEntry(String image, String tokenSrcID, int beginLine) {
+ Integer i = Tokens.get(image);
+ if (i == null) {
+ i = Tokens.size() + 1;
+ Tokens.put(image, i);
}
-
- public boolean equals(Object o) {
- if (!(o instanceof TokenEntry)) {
- return false;
- }
- TokenEntry other = (TokenEntry) o;
- return other.hashCode == hashCode;
- }
-
- public int compareTo(TokenEntry other) {
- return getIndex() - other.getIndex();
+ this.identifier = i.intValue();
+ this.tokenSrcID = tokenSrcID;
+ this.beginLine = beginLine;
+ this.index = TokenCount++;
+ }
+
+ public static TokenEntry getEOF() {
+ TokenCount++;
+ return EOF;
+ }
+
+ public static void clearImages() {
+ Tokens.clear();
+ TokenCount = 0;
+ }
+
+ public String getTokenSrcID() {
+ return tokenSrcID;
+ }
+
+ public int getBeginLine() {
+ return beginLine;
+ }
+
+ public int getIdentifier() {
+ return this.identifier;
+ }
+
+ public int getIndex() {
+ return this.index;
+ }
+
+ public int hashCode() {
+ return hashCode;
+ }
+
+ public void setHashCode(int hashCode) {
+ this.hashCode = hashCode;
+ }
+
+ public boolean equals(Object o) {
+ if (!(o instanceof TokenEntry)) {
+ return false;
}
-} \ No newline at end of file
+ TokenEntry other = (TokenEntry) o;
+ return other.hashCode == hashCode;
+ }
+
+ public int compareTo(TokenEntry other) {
+ return getIndex() - other.getIndex();
+ }
+}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokenizer.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokenizer.java
index 54f8c216779..e0d5c8baf44 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokenizer.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokenizer.java
@@ -26,5 +26,5 @@ package net.sourceforge.pmd.cpd;
import java.io.IOException;
public interface Tokenizer {
- void tokenize(SourceCode tokens, Tokens tokenEntries) throws IOException;
+ void tokenize(SourceCode tokens, Tokens tokenEntries) throws IOException;
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokens.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokens.java
index 67731611a84..33118dd50dd 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokens.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/Tokens.java
@@ -31,34 +31,34 @@ import java.util.List;
public class Tokens {
- private List<TokenEntry> tokens = new ArrayList<TokenEntry>();
+ private List<TokenEntry> tokens = new ArrayList<TokenEntry>();
- public void add(TokenEntry tokenEntry) {
- this.tokens.add(tokenEntry);
- }
+ public void add(TokenEntry tokenEntry) {
+ this.tokens.add(tokenEntry);
+ }
- public Iterator<TokenEntry> iterator() {
- return tokens.iterator();
- }
+ public Iterator<TokenEntry> iterator() {
+ return tokens.iterator();
+ }
- private TokenEntry get(int index) {
- return tokens.get(index);
- }
+ private TokenEntry get(int index) {
+ return tokens.get(index);
+ }
- public int size() {
- return tokens.size();
- }
+ public int size() {
+ return tokens.size();
+ }
- public int getLineCount(TokenEntry mark, Match match) {
- TokenEntry endTok = get(mark.getIndex() + match.getTokenCount() - 1);
- if (endTok == TokenEntry.EOF) {
- endTok = get(mark.getIndex() + match.getTokenCount() - 2);
- }
- return endTok.getBeginLine() - mark.getBeginLine() + 1;
+ public int getLineCount(TokenEntry mark, Match match) {
+ TokenEntry endTok = get(mark.getIndex() + match.getTokenCount() - 1);
+ if (endTok == TokenEntry.EOF) {
+ endTok = get(mark.getIndex() + match.getTokenCount() - 2);
}
+ return endTok.getBeginLine() - mark.getBeginLine() + 1;
+ }
- public List<TokenEntry> getTokens() {
- return tokens;
- }
+ public List<TokenEntry> getTokens() {
+ return tokens;
+ }
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserConstants.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserConstants.java
deleted file mode 100644
index 57ec6e503d7..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserConstants.java
+++ /dev/null
@@ -1,417 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/* Generated By:JavaCC: Do not edit this line. CPPParserConstants.java */
-package net.sourceforge.pmd.cpd.cppast;
-
-
-/**
- * Token literal values and constants.
- * Generated by org.javacc.parser.OtherFilesGen#start()
- */
-public interface CPPParserConstants {
-
- /** End of File. */
- int EOF = 0;
- /** RegularExpression Id. */
- int LCURLYBRACE = 19;
- /** RegularExpression Id. */
- int RCURLYBRACE = 20;
- /** RegularExpression Id. */
- int LSQUAREBRACKET = 21;
- /** RegularExpression Id. */
- int RSQUAREBRACKET = 22;
- /** RegularExpression Id. */
- int LPARENTHESIS = 23;
- /** RegularExpression Id. */
- int RPARENTHESIS = 24;
- /** RegularExpression Id. */
- int SCOPE = 25;
- /** RegularExpression Id. */
- int COLON = 26;
- /** RegularExpression Id. */
- int SEMICOLON = 27;
- /** RegularExpression Id. */
- int COMMA = 28;
- /** RegularExpression Id. */
- int QUESTIONMARK = 29;
- /** RegularExpression Id. */
- int ELLIPSIS = 30;
- /** RegularExpression Id. */
- int ASSIGNEQUAL = 31;
- /** RegularExpression Id. */
- int TIMESEQUAL = 32;
- /** RegularExpression Id. */
- int DIVIDEEQUAL = 33;
- /** RegularExpression Id. */
- int MODEQUAL = 34;
- /** RegularExpression Id. */
- int PLUSEQUAL = 35;
- /** RegularExpression Id. */
- int MINUSEQUAL = 36;
- /** RegularExpression Id. */
- int SHIFTLEFTEQUAL = 37;
- /** RegularExpression Id. */
- int SHIFTRIGHTEQUAL = 38;
- /** RegularExpression Id. */
- int BITWISEANDEQUAL = 39;
- /** RegularExpression Id. */
- int BITWISEXOREQUAL = 40;
- /** RegularExpression Id. */
- int BITWISEOREQUAL = 41;
- /** RegularExpression Id. */
- int OR = 42;
- /** RegularExpression Id. */
- int AND = 43;
- /** RegularExpression Id. */
- int BITWISEOR = 44;
- /** RegularExpression Id. */
- int BITWISEXOR = 45;
- /** RegularExpression Id. */
- int AMPERSAND = 46;
- /** RegularExpression Id. */
- int EQUAL = 47;
- /** RegularExpression Id. */
- int NOTEQUAL = 48;
- /** RegularExpression Id. */
- int LESSTHAN = 49;
- /** RegularExpression Id. */
- int GREATERTHAN = 50;
- /** RegularExpression Id. */
- int LESSTHANOREQUALTO = 51;
- /** RegularExpression Id. */
- int GREATERTHANOREQUALTO = 52;
- /** RegularExpression Id. */
- int SHIFTLEFT = 53;
- /** RegularExpression Id. */
- int SHIFTRIGHT = 54;
- /** RegularExpression Id. */
- int PLUS = 55;
- /** RegularExpression Id. */
- int MINUS = 56;
- /** RegularExpression Id. */
- int STAR = 57;
- /** RegularExpression Id. */
- int DIVIDE = 58;
- /** RegularExpression Id. */
- int MOD = 59;
- /** RegularExpression Id. */
- int PLUSPLUS = 60;
- /** RegularExpression Id. */
- int MINUSMINUS = 61;
- /** RegularExpression Id. */
- int TILDE = 62;
- /** RegularExpression Id. */
- int NOT = 63;
- /** RegularExpression Id. */
- int DOT = 64;
- /** RegularExpression Id. */
- int POINTERTO = 65;
- /** RegularExpression Id. */
- int DOTSTAR = 66;
- /** RegularExpression Id. */
- int ARROWSTAR = 67;
- /** RegularExpression Id. */
- int AUTO = 68;
- /** RegularExpression Id. */
- int BREAK = 69;
- /** RegularExpression Id. */
- int CASE = 70;
- /** RegularExpression Id. */
- int CATCH = 71;
- /** RegularExpression Id. */
- int CHAR = 72;
- /** RegularExpression Id. */
- int CONST = 73;
- /** RegularExpression Id. */
- int CONTINUE = 74;
- /** RegularExpression Id. */
- int _DEFAULT = 75;
- /** RegularExpression Id. */
- int DELETE = 76;
- /** RegularExpression Id. */
- int DO = 77;
- /** RegularExpression Id. */
- int DOUBLE = 78;
- /** RegularExpression Id. */
- int ELSE = 79;
- /** RegularExpression Id. */
- int ENUM = 80;
- /** RegularExpression Id. */
- int EXTERN = 81;
- /** RegularExpression Id. */
- int FLOAT = 82;
- /** RegularExpression Id. */
- int FOR = 83;
- /** RegularExpression Id. */
- int FRIEND = 84;
- /** RegularExpression Id. */
- int GOTO = 85;
- /** RegularExpression Id. */
- int IF = 86;
- /** RegularExpression Id. */
- int INLINE = 87;
- /** RegularExpression Id. */
- int INT = 88;
- /** RegularExpression Id. */
- int LONG = 89;
- /** RegularExpression Id. */
- int NEW = 90;
- /** RegularExpression Id. */
- int PRIVATE = 91;
- /** RegularExpression Id. */
- int PROTECTED = 92;
- /** RegularExpression Id. */
- int PUBLIC = 93;
- /** RegularExpression Id. */
- int REDECLARED = 94;
- /** RegularExpression Id. */
- int REGISTER = 95;
- /** RegularExpression Id. */
- int RETURN = 96;
- /** RegularExpression Id. */
- int SHORT = 97;
- /** RegularExpression Id. */
- int SIGNED = 98;
- /** RegularExpression Id. */
- int SIZEOF = 99;
- /** RegularExpression Id. */
- int STATIC = 100;
- /** RegularExpression Id. */
- int STRUCT = 101;
- /** RegularExpression Id. */
- int CLASS = 102;
- /** RegularExpression Id. */
- int SWITCH = 103;
- /** RegularExpression Id. */
- int TEMPLATE = 104;
- /** RegularExpression Id. */
- int THIS = 105;
- /** RegularExpression Id. */
- int TRY = 106;
- /** RegularExpression Id. */
- int TYPEDEF = 107;
- /** RegularExpression Id. */
- int UNION = 108;
- /** RegularExpression Id. */
- int UNSIGNED = 109;
- /** RegularExpression Id. */
- int VIRTUAL = 110;
- /** RegularExpression Id. */
- int VOID = 111;
- /** RegularExpression Id. */
- int VOLATILE = 112;
- /** RegularExpression Id. */
- int WHILE = 113;
- /** RegularExpression Id. */
- int OPERATOR = 114;
- /** RegularExpression Id. */
- int TRUETOK = 115;
- /** RegularExpression Id. */
- int FALSETOK = 116;
- /** RegularExpression Id. */
- int THROW = 117;
- /** RegularExpression Id. */
- int OCTALINT = 118;
- /** RegularExpression Id. */
- int OCTALLONG = 119;
- /** RegularExpression Id. */
- int UNSIGNED_OCTALINT = 120;
- /** RegularExpression Id. */
- int UNSIGNED_OCTALLONG = 121;
- /** RegularExpression Id. */
- int DECIMALINT = 122;
- /** RegularExpression Id. */
- int DECIMALLONG = 123;
- /** RegularExpression Id. */
- int UNSIGNED_DECIMALINT = 124;
- /** RegularExpression Id. */
- int UNSIGNED_DECIMALLONG = 125;
- /** RegularExpression Id. */
- int HEXADECIMALINT = 126;
- /** RegularExpression Id. */
- int HEXADECIMALLONG = 127;
- /** RegularExpression Id. */
- int UNSIGNED_HEXADECIMALINT = 128;
- /** RegularExpression Id. */
- int UNSIGNED_HEXADECIMALLONG = 129;
- /** RegularExpression Id. */
- int FLOATONE = 130;
- /** RegularExpression Id. */
- int FLOATTWO = 131;
- /** RegularExpression Id. */
- int CHARACTER = 132;
- /** RegularExpression Id. */
- int STRING = 133;
- /** RegularExpression Id. */
- int ID = 135;
-
- /** Lexical state. */
- int DEFAULT = 0;
- /** Lexical state. */
- int IN_LINE_COMMENT = 1;
- /** Lexical state. */
- int IN_COMMENT = 2;
- /** Lexical state. */
- int IN_PREPROCESSOR_OUTPUT_COMMENT = 3;
- /** Lexical state. */
- int PREPROCESSOR_OUTPUT = 4;
-
- /** Literal token values. */
- String[] tokenImage = {
- "<EOF>",
- "\" \"",
- "\"\\f\"",
- "\"\\t\"",
- "\"\\r\\n\"",
- "\"\\n\"",
- "\"//\"",
- "\"/*\"",
- "\"#\"",
- "\"\\n\"",
- "<token of kind 10>",
- "\"*/\"",
- "<token of kind 12>",
- "\"*/\"",
- "\"\\n\"",
- "\"/*\"",
- "\"\\\\\\n\"",
- "\"\\\\\\r\\n\"",
- "<token of kind 18>",
- "\"{\"",
- "\"}\"",
- "\"[\"",
- "\"]\"",
- "\"(\"",
- "\")\"",
- "\"::\"",
- "\":\"",
- "\";\"",
- "\",\"",
- "\"?\"",
- "\"...\"",
- "\"=\"",
- "\"*=\"",
- "\"/=\"",
- "\"%=\"",
- "\"+=\"",
- "\"-=\"",
- "\"<<=\"",
- "\">>=\"",
- "\"&=\"",
- "\"^=\"",
- "\"|=\"",
- "\"||\"",
- "\"&&\"",
- "\"|\"",
- "\"^\"",
- "\"&\"",
- "\"==\"",
- "\"!=\"",
- "\"<\"",
- "\">\"",
- "\"<=\"",
- "\">=\"",
- "\"<<\"",
- "\">>\"",
- "\"+\"",
- "\"-\"",
- "\"*\"",
- "\"/\"",
- "\"%\"",
- "\"++\"",
- "\"--\"",
- "\"~\"",
- "\"!\"",
- "\".\"",
- "\"->\"",
- "\".*\"",
- "\"->*\"",
- "\"auto\"",
- "\"break\"",
- "\"case\"",
- "\"catch\"",
- "\"char\"",
- "\"const\"",
- "\"continue\"",
- "\"default\"",
- "\"delete\"",
- "\"do\"",
- "\"double\"",
- "\"else\"",
- "\"enum\"",
- "\"extern\"",
- "\"float\"",
- "\"for\"",
- "\"friend\"",
- "\"goto\"",
- "\"if\"",
- "\"inline\"",
- "\"int\"",
- "\"long\"",
- "\"new\"",
- "\"private\"",
- "\"protected\"",
- "\"public\"",
- "\"redeclared\"",
- "\"register\"",
- "\"return\"",
- "\"short\"",
- "\"signed\"",
- "\"sizeof\"",
- "\"static\"",
- "\"struct\"",
- "\"class\"",
- "\"switch\"",
- "\"template\"",
- "\"this\"",
- "\"try\"",
- "\"typedef\"",
- "\"union\"",
- "\"unsigned\"",
- "\"virtual\"",
- "\"void\"",
- "\"volatile\"",
- "\"while\"",
- "\"operator\"",
- "\"true\"",
- "\"false\"",
- "\"throw\"",
- "<OCTALINT>",
- "<OCTALLONG>",
- "<UNSIGNED_OCTALINT>",
- "<UNSIGNED_OCTALLONG>",
- "<DECIMALINT>",
- "<DECIMALLONG>",
- "<UNSIGNED_DECIMALINT>",
- "<UNSIGNED_DECIMALLONG>",
- "<HEXADECIMALINT>",
- "<HEXADECIMALLONG>",
- "<UNSIGNED_HEXADECIMALINT>",
- "<UNSIGNED_HEXADECIMALLONG>",
- "<FLOATONE>",
- "<FLOATTWO>",
- "<CHARACTER>",
- "<STRING>",
- "\"finally\"",
- "<ID>",
- };
-
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserTokenManager.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserTokenManager.java
deleted file mode 100644
index a5421f2e805..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/CPPParserTokenManager.java
+++ /dev/null
@@ -1,1707 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/* Generated By:JavaCC: Do not edit this line. CPPParserTokenManager.java */
-package net.sourceforge.pmd.cpd.cppast;
-
-/** Token Manager. */
-public class CPPParserTokenManager implements CPPParserConstants
-{
- private static String filename;
- public static void setFileName(String name) {
- filename = name;
- }
- public static String getFileName() {
- return filename;
- }
-
- /** Debug output. */
- public static java.io.PrintStream debugStream = System.out;
- /** Set debug output. */
- public static void setDebugStream(java.io.PrintStream ds) { debugStream = ds; }
-private static final int jjStopStringLiteralDfa_0(int pos, long active0, long active1, long active2)
-{
- switch (pos)
- {
- case 0:
- if ((active1 & 0x3ffffffffffff0L) != 0L || (active2 & 0x40L) != 0L)
- {
- jjmatchedKind = 135;
- return 29;
- }
- if ((active0 & 0x40000000L) != 0L || (active1 & 0x5L) != 0L)
- return 1;
- return -1;
- case 1:
- if ((active1 & 0x3fffffffbf9ff0L) != 0L || (active2 & 0x40L) != 0L)
- {
- if (jjmatchedPos != 1)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 1;
- }
- return 29;
- }
- if ((active1 & 0x406000L) != 0L)
- return 29;
- return -1;
- case 2:
- if ((active1 & 0x3ffbfffab7dff0L) != 0L || (active2 & 0x40L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 2;
- return 29;
- }
- if ((active1 & 0x40005080000L) != 0L)
- return 29;
- return -1;
- case 3:
- if ((active1 & 0x3779fff8965ea0L) != 0L || (active2 & 0x40L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 3;
- return 29;
- }
- if ((active1 & 0x8820002218150L) != 0L)
- return 29;
- return -1;
- case 4:
- if ((active1 & 0x569bdf8925c00L) != 0L || (active2 & 0x40L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 4;
- return 29;
- }
- if ((active1 & 0x321042000402a0L) != 0L)
- return 29;
- return -1;
- case 5:
- if ((active1 & 0x56900d8000c00L) != 0L || (active2 & 0x40L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 5;
- return 29;
- }
- if ((active1 & 0xbd20925000L) != 0L)
- return 29;
- return -1;
- case 6:
- if ((active1 & 0x52100d0000400L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 6;
- return 29;
- }
- if ((active1 & 0x480008000800L) != 0L || (active2 & 0x40L) != 0L)
- return 29;
- return -1;
- case 7:
- if ((active1 & 0x50000000L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 7;
- return 29;
- }
- if ((active1 & 0x5210080000400L) != 0L)
- return 29;
- return -1;
- case 8:
- if ((active1 & 0x40000000L) != 0L)
- {
- jjmatchedKind = 135;
- jjmatchedPos = 8;
- return 29;
- }
- if ((active1 & 0x10000000L) != 0L)
- return 29;
- return -1;
- default :
- return -1;
- }
-}
-private static final int jjStartNfa_0(int pos, long active0, long active1, long active2)
-{
- return jjMoveNfa_0(jjStopStringLiteralDfa_0(pos, active0, active1, active2), pos + 1);
-}
-static private int jjStopAtPos(int pos, int kind)
-{
- jjmatchedKind = kind;
- jjmatchedPos = pos;
- return pos + 1;
-}
-static private int jjMoveStringLiteralDfa0_0()
-{
- switch(curChar)
- {
- case 13:
- return jjMoveStringLiteralDfa1_0(0x10L, 0x0L, 0x0L);
- case 33:
- jjmatchedKind = 63;
- return jjMoveStringLiteralDfa1_0(0x1000000000000L, 0x0L, 0x0L);
- case 35:
- return jjStopAtPos(0, 8);
- case 37:
- jjmatchedKind = 59;
- return jjMoveStringLiteralDfa1_0(0x400000000L, 0x0L, 0x0L);
- case 38:
- jjmatchedKind = 46;
- return jjMoveStringLiteralDfa1_0(0x88000000000L, 0x0L, 0x0L);
- case 40:
- return jjStopAtPos(0, 23);
- case 41:
- return jjStopAtPos(0, 24);
- case 42:
- jjmatchedKind = 57;
- return jjMoveStringLiteralDfa1_0(0x100000000L, 0x0L, 0x0L);
- case 43:
- jjmatchedKind = 55;
- return jjMoveStringLiteralDfa1_0(0x1000000800000000L, 0x0L, 0x0L);
- case 44:
- return jjStopAtPos(0, 28);
- case 45:
- jjmatchedKind = 56;
- return jjMoveStringLiteralDfa1_0(0x2000001000000000L, 0xaL, 0x0L);
- case 46:
- jjmatchedKind = 64;
- return jjMoveStringLiteralDfa1_0(0x40000000L, 0x4L, 0x0L);
- case 47:
- jjmatchedKind = 58;
- return jjMoveStringLiteralDfa1_0(0x2000000c0L, 0x0L, 0x0L);
- case 58:
- jjmatchedKind = 26;
- return jjMoveStringLiteralDfa1_0(0x2000000L, 0x0L, 0x0L);
- case 59:
- return jjStopAtPos(0, 27);
- case 60:
- jjmatchedKind = 49;
- return jjMoveStringLiteralDfa1_0(0x28002000000000L, 0x0L, 0x0L);
- case 61:
- jjmatchedKind = 31;
- return jjMoveStringLiteralDfa1_0(0x800000000000L, 0x0L, 0x0L);
- case 62:
- jjmatchedKind = 50;
- return jjMoveStringLiteralDfa1_0(0x50004000000000L, 0x0L, 0x0L);
- case 63:
- return jjStopAtPos(0, 29);
- case 91:
- return jjStopAtPos(0, 21);
- case 93:
- return jjStopAtPos(0, 22);
- case 94:
- jjmatchedKind = 45;
- return jjMoveStringLiteralDfa1_0(0x10000000000L, 0x0L, 0x0L);
- case 97:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x10L, 0x0L);
- case 98:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x20L, 0x0L);
- case 99:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x40000007c0L, 0x0L);
- case 100:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x7800L, 0x0L);
- case 101:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x38000L, 0x0L);
- case 102:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x100000001c0000L, 0x40L);
- case 103:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x200000L, 0x0L);
- case 105:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x1c00000L, 0x0L);
- case 108:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x2000000L, 0x0L);
- case 110:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x4000000L, 0x0L);
- case 111:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x4000000000000L, 0x0L);
- case 112:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x38000000L, 0x0L);
- case 114:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x1c0000000L, 0x0L);
- case 115:
- return jjMoveStringLiteralDfa1_0(0x0L, 0xbe00000000L, 0x0L);
- case 116:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x280f0000000000L, 0x0L);
- case 117:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x300000000000L, 0x0L);
- case 118:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x1c00000000000L, 0x0L);
- case 119:
- return jjMoveStringLiteralDfa1_0(0x0L, 0x2000000000000L, 0x0L);
- case 123:
- return jjStopAtPos(0, 19);
- case 124:
- jjmatchedKind = 44;
- return jjMoveStringLiteralDfa1_0(0x60000000000L, 0x0L, 0x0L);
- case 125:
- return jjStopAtPos(0, 20);
- case 126:
- return jjStopAtPos(0, 62);
- default :
- return jjMoveNfa_0(28, 0);
- }
-}
-static private int jjMoveStringLiteralDfa1_0(long active0, long active1, long active2)
-{
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(0, active0, active1, active2);
- return 1;
- }
- switch(curChar)
- {
- case 10:
- if ((active0 & 0x10L) != 0L)
- return jjStopAtPos(1, 4);
- break;
- case 38:
- if ((active0 & 0x80000000000L) != 0L)
- return jjStopAtPos(1, 43);
- break;
- case 42:
- if ((active0 & 0x80L) != 0L)
- return jjStopAtPos(1, 7);
- else if ((active1 & 0x4L) != 0L)
- return jjStopAtPos(1, 66);
- break;
- case 43:
- if ((active0 & 0x1000000000000000L) != 0L)
- return jjStopAtPos(1, 60);
- break;
- case 45:
- if ((active0 & 0x2000000000000000L) != 0L)
- return jjStopAtPos(1, 61);
- break;
- case 46:
- return jjMoveStringLiteralDfa2_0(active0, 0x40000000L, active1, 0L, active2, 0L);
- case 47:
- if ((active0 & 0x40L) != 0L)
- return jjStopAtPos(1, 6);
- break;
- case 58:
- if ((active0 & 0x2000000L) != 0L)
- return jjStopAtPos(1, 25);
- break;
- case 60:
- if ((active0 & 0x20000000000000L) != 0L)
- {
- jjmatchedKind = 53;
- jjmatchedPos = 1;
- }
- return jjMoveStringLiteralDfa2_0(active0, 0x2000000000L, active1, 0L, active2, 0L);
- case 61:
- if ((active0 & 0x100000000L) != 0L)
- return jjStopAtPos(1, 32);
- else if ((active0 & 0x200000000L) != 0L)
- return jjStopAtPos(1, 33);
- else if ((active0 & 0x400000000L) != 0L)
- return jjStopAtPos(1, 34);
- else if ((active0 & 0x800000000L) != 0L)
- return jjStopAtPos(1, 35);
- else if ((active0 & 0x1000000000L) != 0L)
- return jjStopAtPos(1, 36);
- else if ((active0 & 0x8000000000L) != 0L)
- return jjStopAtPos(1, 39);
- else if ((active0 & 0x10000000000L) != 0L)
- return jjStopAtPos(1, 40);
- else if ((active0 & 0x20000000000L) != 0L)
- return jjStopAtPos(1, 41);
- else if ((active0 & 0x800000000000L) != 0L)
- return jjStopAtPos(1, 47);
- else if ((active0 & 0x1000000000000L) != 0L)
- return jjStopAtPos(1, 48);
- else if ((active0 & 0x8000000000000L) != 0L)
- return jjStopAtPos(1, 51);
- else if ((active0 & 0x10000000000000L) != 0L)
- return jjStopAtPos(1, 52);
- break;
- case 62:
- if ((active0 & 0x40000000000000L) != 0L)
- {
- jjmatchedKind = 54;
- jjmatchedPos = 1;
- }
- else if ((active1 & 0x2L) != 0L)
- {
- jjmatchedKind = 65;
- jjmatchedPos = 1;
- }
- return jjMoveStringLiteralDfa2_0(active0, 0x4000000000L, active1, 0x8L, active2, 0L);
- case 97:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x100000000000c0L, active2, 0L);
- case 101:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x101c4001800L, active2, 0L);
- case 102:
- if ((active1 & 0x400000L) != 0L)
- return jjStartNfaWithStates_0(1, 86, 29);
- break;
- case 104:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x22020200000100L, active2, 0L);
- case 105:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x400c00000000L, active2, 0x40L);
- case 108:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x4000048000L, active2, 0L);
- case 110:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x300001810000L, active2, 0L);
- case 111:
- if ((active1 & 0x2000L) != 0L)
- {
- jjmatchedKind = 77;
- jjmatchedPos = 1;
- }
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x1800002284600L, active2, 0L);
- case 112:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x4000000000000L, active2, 0L);
- case 114:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x8040018100020L, active2, 0L);
- case 116:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x3000000000L, active2, 0L);
- case 117:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x20000010L, active2, 0L);
- case 119:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x8000000000L, active2, 0L);
- case 120:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x20000L, active2, 0L);
- case 121:
- return jjMoveStringLiteralDfa2_0(active0, 0L, active1, 0x80000000000L, active2, 0L);
- case 124:
- if ((active0 & 0x40000000000L) != 0L)
- return jjStopAtPos(1, 42);
- break;
- default :
- break;
- }
- return jjStartNfa_0(0, active0, active1, active2);
-}
-static private int jjMoveStringLiteralDfa2_0(long old0, long active0, long old1, long active1, long old2, long active2)
-{
- if (((active0 &= old0) | (active1 &= old1) | (active2 &= old2)) == 0L)
- return jjStartNfa_0(0, old0, old1, old2);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(1, active0, active1, active2);
- return 2;
- }
- switch(curChar)
- {
- case 42:
- if ((active1 & 0x8L) != 0L)
- return jjStopAtPos(2, 67);
- break;
- case 46:
- if ((active0 & 0x40000000L) != 0L)
- return jjStopAtPos(2, 30);
- break;
- case 61:
- if ((active0 & 0x2000000000L) != 0L)
- return jjStopAtPos(2, 37);
- else if ((active0 & 0x4000000000L) != 0L)
- return jjStopAtPos(2, 38);
- break;
- case 97:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x5000000100L, active2, 0L);
- case 98:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x20000000L, active2, 0L);
- case 100:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x40000000L, active2, 0L);
- case 101:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x4000000000020L, active2, 0L);
- case 102:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x800L, active2, 0L);
- case 103:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x480000000L, active2, 0L);
- case 105:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x2928008100000L, active2, 0L);
- case 108:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x11000000801000L, active2, 0L);
- case 109:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x10000000000L, active2, 0L);
- case 110:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x2000600L, active2, 0x40L);
- case 111:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x210040000L, active2, 0L);
- case 112:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x80000000000L, active2, 0L);
- case 114:
- if ((active1 & 0x80000L) != 0L)
- return jjStartNfaWithStates_0(2, 83, 29);
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x20402000000000L, active2, 0L);
- case 115:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x200000008040L, active2, 0L);
- case 116:
- if ((active1 & 0x1000000L) != 0L)
- return jjStartNfaWithStates_0(2, 88, 29);
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x100220090L, active2, 0L);
- case 117:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x8000000014000L, active2, 0L);
- case 119:
- if ((active1 & 0x4000000L) != 0L)
- return jjStartNfaWithStates_0(2, 90, 29);
- break;
- case 121:
- if ((active1 & 0x40000000000L) != 0L)
- return jjStartNfaWithStates_0(2, 106, 29);
- break;
- case 122:
- return jjMoveStringLiteralDfa3_0(active0, 0L, active1, 0x800000000L, active2, 0L);
- default :
- break;
- }
- return jjStartNfa_0(1, active0, active1, active2);
-}
-static private int jjMoveStringLiteralDfa3_0(long old0, long active0, long old1, long active1, long old2, long active2)
-{
- if (((active0 &= old0) | (active1 &= old1) | (active2 &= old2)) == 0L)
- return jjStartNfa_0(1, old0, old1, old2);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(2, 0L, active1, active2);
- return 3;
- }
- switch(curChar)
- {
- case 97:
- return jjMoveStringLiteralDfa4_0(active1, 0x1000000040820L, active2, 0x40L);
- case 98:
- return jjMoveStringLiteralDfa4_0(active1, 0x4000L, active2, 0L);
- case 99:
- return jjMoveStringLiteralDfa4_0(active1, 0x80L, active2, 0L);
- case 100:
- if ((active1 & 0x800000000000L) != 0L)
- return jjStartNfaWithStates_0(3, 111, 29);
- break;
- case 101:
- if ((active1 & 0x40L) != 0L)
- return jjStartNfaWithStates_0(3, 70, 29);
- else if ((active1 & 0x8000L) != 0L)
- return jjStartNfaWithStates_0(3, 79, 29);
- else if ((active1 & 0x8000000000000L) != 0L)
- return jjStartNfaWithStates_0(3, 115, 29);
- return jjMoveStringLiteralDfa4_0(active1, 0x80840121000L, active2, 0L);
- case 103:
- if ((active1 & 0x2000000L) != 0L)
- return jjStartNfaWithStates_0(3, 89, 29);
- break;
- case 105:
- return jjMoveStringLiteralDfa4_0(active1, 0x200080800000L, active2, 0L);
- case 108:
- return jjMoveStringLiteralDfa4_0(active1, 0x2000020000000L, active2, 0L);
- case 109:
- if ((active1 & 0x10000L) != 0L)
- return jjStartNfaWithStates_0(3, 80, 29);
- break;
- case 110:
- return jjMoveStringLiteralDfa4_0(active1, 0x400000000L, active2, 0L);
- case 111:
- if ((active1 & 0x10L) != 0L)
- return jjStartNfaWithStates_0(3, 68, 29);
- else if ((active1 & 0x200000L) != 0L)
- return jjStartNfaWithStates_0(3, 85, 29);
- return jjMoveStringLiteralDfa4_0(active1, 0x20100000000000L, active2, 0L);
- case 112:
- return jjMoveStringLiteralDfa4_0(active1, 0x10000000000L, active2, 0L);
- case 114:
- if ((active1 & 0x100L) != 0L)
- return jjStartNfaWithStates_0(3, 72, 29);
- return jjMoveStringLiteralDfa4_0(active1, 0x4000200000000L, active2, 0L);
- case 115:
- if ((active1 & 0x20000000000L) != 0L)
- return jjStartNfaWithStates_0(3, 105, 29);
- return jjMoveStringLiteralDfa4_0(active1, 0x10004000000200L, active2, 0L);
- case 116:
- return jjMoveStringLiteralDfa4_0(active1, 0x409010000400L, active2, 0L);
- case 117:
- return jjMoveStringLiteralDfa4_0(active1, 0x2100000000L, active2, 0L);
- case 118:
- return jjMoveStringLiteralDfa4_0(active1, 0x8000000L, active2, 0L);
- default :
- break;
- }
- return jjStartNfa_0(2, 0L, active1, active2);
-}
-static private int jjMoveStringLiteralDfa4_0(long old1, long active1, long old2, long active2)
-{
- if (((active1 &= old1) | (active2 &= old2)) == 0L)
- return jjStartNfa_0(2, 0L, old1, old2);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(3, 0L, active1, active2);
- return 4;
- }
- switch(curChar)
- {
- case 97:
- return jjMoveStringLiteralDfa5_0(active1, 0x4000008000000L, active2, 0L);
- case 99:
- return jjMoveStringLiteralDfa5_0(active1, 0xa040000000L, active2, 0L);
- case 100:
- return jjMoveStringLiteralDfa5_0(active1, 0x80000000000L, active2, 0L);
- case 101:
- if ((active1 & 0x2000000000000L) != 0L)
- return jjStartNfaWithStates_0(4, 113, 29);
- else if ((active1 & 0x10000000000000L) != 0L)
- return jjStartNfaWithStates_0(4, 116, 29);
- return jjMoveStringLiteralDfa5_0(active1, 0x410000000L, active2, 0L);
- case 103:
- return jjMoveStringLiteralDfa5_0(active1, 0x200000000000L, active2, 0L);
- case 104:
- if ((active1 & 0x80L) != 0L)
- return jjStartNfaWithStates_0(4, 71, 29);
- break;
- case 105:
- return jjMoveStringLiteralDfa5_0(active1, 0x1020000400L, active2, 0L);
- case 107:
- if ((active1 & 0x20L) != 0L)
- return jjStartNfaWithStates_0(4, 69, 29);
- break;
- case 108:
- return jjMoveStringLiteralDfa5_0(active1, 0x10000004000L, active2, 0x40L);
- case 110:
- if ((active1 & 0x100000000000L) != 0L)
- return jjStartNfaWithStates_0(4, 108, 29);
- return jjMoveStringLiteralDfa5_0(active1, 0x900000L, active2, 0L);
- case 111:
- return jjMoveStringLiteralDfa5_0(active1, 0x800000000L, active2, 0L);
- case 114:
- return jjMoveStringLiteralDfa5_0(active1, 0x100020000L, active2, 0L);
- case 115:
- if ((active1 & 0x4000000000L) != 0L)
- return jjStartNfaWithStates_0(4, 102, 29);
- return jjMoveStringLiteralDfa5_0(active1, 0x80000000L, active2, 0L);
- case 116:
- if ((active1 & 0x200L) != 0L)
- return jjStartNfaWithStates_0(4, 73, 29);
- else if ((active1 & 0x40000L) != 0L)
- return jjStartNfaWithStates_0(4, 82, 29);
- else if ((active1 & 0x200000000L) != 0L)
- return jjStartNfaWithStates_0(4, 97, 29);
- return jjMoveStringLiteralDfa5_0(active1, 0x1000000001000L, active2, 0L);
- case 117:
- return jjMoveStringLiteralDfa5_0(active1, 0x400000000800L, active2, 0L);
- case 119:
- if ((active1 & 0x20000000000000L) != 0L)
- return jjStartNfaWithStates_0(4, 117, 29);
- break;
- default :
- break;
- }
- return jjStartNfa_0(3, 0L, active1, active2);
-}
-static private int jjMoveStringLiteralDfa5_0(long old1, long active1, long old2, long active2)
-{
- if (((active1 &= old1) | (active2 &= old2)) == 0L)
- return jjStartNfa_0(3, 0L, old1, old2);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(4, 0L, active1, active2);
- return 5;
- }
- switch(curChar)
- {
- case 97:
- return jjMoveStringLiteralDfa6_0(active1, 0x410000000000L, active2, 0L);
- case 99:
- if ((active1 & 0x20000000L) != 0L)
- return jjStartNfaWithStates_0(5, 93, 29);
- else if ((active1 & 0x1000000000L) != 0L)
- return jjStartNfaWithStates_0(5, 100, 29);
- return jjMoveStringLiteralDfa6_0(active1, 0x10000000L, active2, 0L);
- case 100:
- if ((active1 & 0x100000L) != 0L)
- return jjStartNfaWithStates_0(5, 84, 29);
- else if ((active1 & 0x400000000L) != 0L)
- return jjStartNfaWithStates_0(5, 98, 29);
- break;
- case 101:
- if ((active1 & 0x1000L) != 0L)
- return jjStartNfaWithStates_0(5, 76, 29);
- else if ((active1 & 0x4000L) != 0L)
- return jjStartNfaWithStates_0(5, 78, 29);
- else if ((active1 & 0x800000L) != 0L)
- return jjStartNfaWithStates_0(5, 87, 29);
- return jjMoveStringLiteralDfa6_0(active1, 0x80000000000L, active2, 0L);
- case 102:
- if ((active1 & 0x800000000L) != 0L)
- return jjStartNfaWithStates_0(5, 99, 29);
- break;
- case 104:
- if ((active1 & 0x8000000000L) != 0L)
- return jjStartNfaWithStates_0(5, 103, 29);
- break;
- case 105:
- return jjMoveStringLiteralDfa6_0(active1, 0x1000000000000L, active2, 0L);
- case 108:
- return jjMoveStringLiteralDfa6_0(active1, 0x40000800L, active2, 0x40L);
- case 110:
- if ((active1 & 0x20000L) != 0L)
- return jjStartNfaWithStates_0(5, 81, 29);
- else if ((active1 & 0x100000000L) != 0L)
- return jjStartNfaWithStates_0(5, 96, 29);
- return jjMoveStringLiteralDfa6_0(active1, 0x200000000400L, active2, 0L);
- case 116:
- if ((active1 & 0x2000000000L) != 0L)
- return jjStartNfaWithStates_0(5, 101, 29);
- return jjMoveStringLiteralDfa6_0(active1, 0x4000088000000L, active2, 0L);
- default :
- break;
- }
- return jjStartNfa_0(4, 0L, active1, active2);
-}
-static private int jjMoveStringLiteralDfa6_0(long old1, long active1, long old2, long active2)
-{
- if (((active1 &= old1) | (active2 &= old2)) == 0L)
- return jjStartNfa_0(4, 0L, old1, old2);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(5, 0L, active1, active2);
- return 6;
- }
- switch(curChar)
- {
- case 97:
- return jjMoveStringLiteralDfa7_0(active1, 0x40000000L, active2, 0L);
- case 101:
- if ((active1 & 0x8000000L) != 0L)
- return jjStartNfaWithStates_0(6, 91, 29);
- return jjMoveStringLiteralDfa7_0(active1, 0x200080000000L, active2, 0L);
- case 102:
- if ((active1 & 0x80000000000L) != 0L)
- return jjStartNfaWithStates_0(6, 107, 29);
- break;
- case 108:
- if ((active1 & 0x400000000000L) != 0L)
- return jjStartNfaWithStates_0(6, 110, 29);
- return jjMoveStringLiteralDfa7_0(active1, 0x1000000000000L, active2, 0L);
- case 111:
- return jjMoveStringLiteralDfa7_0(active1, 0x4000000000000L, active2, 0L);
- case 116:
- if ((active1 & 0x800L) != 0L)
- return jjStartNfaWithStates_0(6, 75, 29);
- return jjMoveStringLiteralDfa7_0(active1, 0x10010000000L, active2, 0L);
- case 117:
- return jjMoveStringLiteralDfa7_0(active1, 0x400L, active2, 0L);
- case 121:
- if ((active2 & 0x40L) != 0L)
- return jjStartNfaWithStates_0(6, 134, 29);
- break;
- default :
- break;
- }
- return jjStartNfa_0(5, 0L, active1, active2);
-}
-static private int jjMoveStringLiteralDfa7_0(long old1, long active1, long old2, long active2)
-{
- if (((active1 &= old1) | (active2 &= old2)) == 0L)
- return jjStartNfa_0(5, 0L, old1, old2);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(6, 0L, active1, 0L);
- return 7;
- }
- switch(curChar)
- {
- case 100:
- if ((active1 & 0x200000000000L) != 0L)
- return jjStartNfaWithStates_0(7, 109, 29);
- break;
- case 101:
- if ((active1 & 0x400L) != 0L)
- return jjStartNfaWithStates_0(7, 74, 29);
- else if ((active1 & 0x10000000000L) != 0L)
- return jjStartNfaWithStates_0(7, 104, 29);
- else if ((active1 & 0x1000000000000L) != 0L)
- return jjStartNfaWithStates_0(7, 112, 29);
- return jjMoveStringLiteralDfa8_0(active1, 0x10000000L);
- case 114:
- if ((active1 & 0x80000000L) != 0L)
- return jjStartNfaWithStates_0(7, 95, 29);
- else if ((active1 & 0x4000000000000L) != 0L)
- return jjStartNfaWithStates_0(7, 114, 29);
- return jjMoveStringLiteralDfa8_0(active1, 0x40000000L);
- default :
- break;
- }
- return jjStartNfa_0(6, 0L, active1, 0L);
-}
-static private int jjMoveStringLiteralDfa8_0(long old1, long active1)
-{
- if (((active1 &= old1)) == 0L)
- return jjStartNfa_0(6, 0L, old1, 0L);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(7, 0L, active1, 0L);
- return 8;
- }
- switch(curChar)
- {
- case 100:
- if ((active1 & 0x10000000L) != 0L)
- return jjStartNfaWithStates_0(8, 92, 29);
- break;
- case 101:
- return jjMoveStringLiteralDfa9_0(active1, 0x40000000L);
- default :
- break;
- }
- return jjStartNfa_0(7, 0L, active1, 0L);
-}
-static private int jjMoveStringLiteralDfa9_0(long old1, long active1)
-{
- if (((active1 &= old1)) == 0L)
- return jjStartNfa_0(7, 0L, old1, 0L);
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- jjStopStringLiteralDfa_0(8, 0L, active1, 0L);
- return 9;
- }
- switch(curChar)
- {
- case 100:
- if ((active1 & 0x40000000L) != 0L)
- return jjStartNfaWithStates_0(9, 94, 29);
- break;
- default :
- break;
- }
- return jjStartNfa_0(8, 0L, active1, 0L);
-}
-static private int jjStartNfaWithStates_0(int pos, int kind, int state)
-{
- jjmatchedKind = kind;
- jjmatchedPos = pos;
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) { return pos + 1; }
- return jjMoveNfa_0(state, pos + 1);
-}
-static final long[] jjbitVec0 = {
- 0x0L, 0x0L, 0xffffffffffffffffL, 0xffffffffffffffffL
-};
-static private int jjMoveNfa_0(int startState, int curPos)
-{
- int startsAt = 0;
- jjnewStateCnt = 78;
- int i = 1;
- jjstateSet[0] = startState;
- int kind = 0x7fffffff;
- for (;;)
- {
- if (++jjround == 0x7fffffff)
- ReInitRounds();
- if (curChar < 64)
- {
- long l = 1L << curChar;
- do
- {
- switch(jjstateSet[--i])
- {
- case 28:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddStates(0, 5);
- else if (curChar == 36)
- {
- if (kind > 135)
- kind = 135;
- jjCheckNAdd(29);
- }
- else if (curChar == 34)
- jjCheckNAddStates(6, 8);
- else if (curChar == 39)
- jjCheckNAddTwoStates(7, 9);
- else if (curChar == 46)
- jjCheckNAdd(1);
- if ((0x3fe000000000000L & l) != 0L)
- {
- if (kind > 122)
- kind = 122;
- jjCheckNAddStates(9, 16);
- }
- else if (curChar == 48)
- jjAddStates(17, 20);
- if (curChar == 48)
- {
- if (kind > 118)
- kind = 118;
- jjCheckNAddStates(21, 28);
- }
- break;
- case 0:
- if (curChar == 46)
- jjCheckNAdd(1);
- break;
- case 1:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 130)
- kind = 130;
- jjCheckNAddStates(29, 31);
- break;
- case 3:
- if ((0x280000000000L & l) != 0L)
- jjCheckNAdd(4);
- break;
- case 4:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 130)
- kind = 130;
- jjCheckNAddTwoStates(4, 5);
- break;
- case 6:
- if (curChar == 39)
- jjCheckNAddTwoStates(7, 9);
- break;
- case 7:
- if ((0xffffff7fffffdbffL & l) != 0L)
- jjCheckNAddTwoStates(7, 8);
- break;
- case 8:
- if (curChar == 39 && kind > 132)
- kind = 132;
- break;
- case 10:
- if ((0x8000008400000000L & l) != 0L)
- jjCheckNAdd(8);
- break;
- case 11:
- if (curChar == 48)
- jjCheckNAddTwoStates(12, 8);
- break;
- case 12:
- if ((0xff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(12, 8);
- break;
- case 13:
- if ((0x3fe000000000000L & l) != 0L)
- jjCheckNAddTwoStates(14, 8);
- break;
- case 14:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(14, 8);
- break;
- case 16:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(16, 8);
- break;
- case 17:
- if (curChar == 34)
- jjCheckNAddStates(6, 8);
- break;
- case 18:
- if ((0xfffffffbffffdbffL & l) != 0L)
- jjCheckNAddStates(6, 8);
- break;
- case 20:
- if ((0x8000008400000400L & l) != 0L)
- jjCheckNAddStates(6, 8);
- break;
- case 21:
- if (curChar == 34 && kind > 133)
- kind = 133;
- break;
- case 22:
- if (curChar == 48)
- jjCheckNAddStates(32, 35);
- break;
- case 23:
- if ((0xff000000000000L & l) != 0L)
- jjCheckNAddStates(32, 35);
- break;
- case 24:
- if ((0x3fe000000000000L & l) != 0L)
- jjCheckNAddStates(36, 39);
- break;
- case 25:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddStates(36, 39);
- break;
- case 27:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddStates(40, 43);
- break;
- case 29:
- if ((0x3ff001000000000L & l) == 0L)
- break;
- if (kind > 135)
- kind = 135;
- jjCheckNAdd(29);
- break;
- case 30:
- if (curChar != 48)
- break;
- if (kind > 118)
- kind = 118;
- jjCheckNAddStates(21, 28);
- break;
- case 31:
- if ((0xff000000000000L & l) == 0L)
- break;
- if (kind > 118)
- kind = 118;
- jjCheckNAdd(31);
- break;
- case 32:
- if ((0xff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(32, 33);
- break;
- case 34:
- if ((0xff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(34, 35);
- break;
- case 36:
- if ((0xff000000000000L & l) != 0L)
- jjCheckNAddStates(44, 46);
- break;
- case 41:
- if ((0x3fe000000000000L & l) == 0L)
- break;
- if (kind > 122)
- kind = 122;
- jjCheckNAddStates(9, 16);
- break;
- case 42:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 122)
- kind = 122;
- jjCheckNAdd(42);
- break;
- case 43:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(43, 44);
- break;
- case 45:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(45, 46);
- break;
- case 47:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddStates(47, 49);
- break;
- case 52:
- if (curChar == 48)
- jjAddStates(17, 20);
- break;
- case 54:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 126)
- kind = 126;
- jjstateSet[jjnewStateCnt++] = 54;
- break;
- case 56:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 127)
- kind = 127;
- jjAddStates(50, 51);
- break;
- case 59:
- if ((0x3ff000000000000L & l) != 0L)
- jjAddStates(52, 53);
- break;
- case 62:
- if ((0x3ff000000000000L & l) != 0L)
- jjAddStates(54, 56);
- break;
- case 67:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddStates(0, 5);
- break;
- case 68:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(68, 69);
- break;
- case 69:
- if (curChar != 46)
- break;
- if (kind > 130)
- kind = 130;
- jjCheckNAddStates(57, 59);
- break;
- case 70:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 130)
- kind = 130;
- jjCheckNAddStates(57, 59);
- break;
- case 71:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(71, 0);
- break;
- case 72:
- if ((0x3ff000000000000L & l) != 0L)
- jjCheckNAddTwoStates(72, 73);
- break;
- case 74:
- if ((0x280000000000L & l) != 0L)
- jjCheckNAdd(75);
- break;
- case 75:
- if ((0x3ff000000000000L & l) == 0L)
- break;
- if (kind > 131)
- kind = 131;
- jjCheckNAddTwoStates(75, 76);
- break;
- default : break;
- }
- } while(i != startsAt);
- }
- else if (curChar < 128)
- {
- long l = 1L << (curChar & 077);
- do
- {
- switch(jjstateSet[--i])
- {
- case 28:
- if ((0x7fffffe87fffffeL & l) != 0L)
- {
- if (kind > 135)
- kind = 135;
- jjCheckNAdd(29);
- }
- if (curChar == 76)
- jjAddStates(60, 61);
- break;
- case 2:
- if ((0x2000000020L & l) != 0L)
- jjAddStates(62, 63);
- break;
- case 5:
- if ((0x104000001040L & l) != 0L && kind > 130)
- kind = 130;
- break;
- case 7:
- if ((0xffffffffefffffffL & l) != 0L)
- jjCheckNAddTwoStates(7, 8);
- break;
- case 9:
- if (curChar == 92)
- jjAddStates(64, 67);
- break;
- case 10:
- if ((0x54404610000000L & l) != 0L)
- jjCheckNAdd(8);
- break;
- case 15:
- if ((0x100000001000000L & l) != 0L)
- jjCheckNAdd(16);
- break;
- case 16:
- if ((0x7e0000007eL & l) != 0L)
- jjCheckNAddTwoStates(16, 8);
- break;
- case 18:
- if ((0xffffffffefffffffL & l) != 0L)
- jjCheckNAddStates(6, 8);
- break;
- case 19:
- if (curChar == 92)
- jjAddStates(68, 71);
- break;
- case 20:
- if ((0x54404610000000L & l) != 0L)
- jjCheckNAddStates(6, 8);
- break;
- case 26:
- if ((0x100000001000000L & l) != 0L)
- jjCheckNAdd(27);
- break;
- case 27:
- if ((0x7e0000007eL & l) != 0L)
- jjCheckNAddStates(40, 43);
- break;
- case 29:
- if ((0x7fffffe87fffffeL & l) == 0L)
- break;
- if (kind > 135)
- kind = 135;
- jjCheckNAdd(29);
- break;
- case 33:
- if ((0x100000001000L & l) != 0L && kind > 119)
- kind = 119;
- break;
- case 35:
- if ((0x20000000200000L & l) != 0L && kind > 120)
- kind = 120;
- break;
- case 37:
- if ((0x100000001000L & l) != 0L && kind > 121)
- kind = 121;
- break;
- case 38:
- if ((0x20000000200000L & l) != 0L)
- jjstateSet[jjnewStateCnt++] = 37;
- break;
- case 39:
- if ((0x20000000200000L & l) != 0L && kind > 121)
- kind = 121;
- break;
- case 40:
- if ((0x100000001000L & l) != 0L)
- jjstateSet[jjnewStateCnt++] = 39;
- break;
- case 44:
- if ((0x20100000201000L & l) != 0L && kind > 123)
- kind = 123;
- break;
- case 46:
- if ((0x20000000200000L & l) != 0L && kind > 124)
- kind = 124;
- break;
- case 48:
- if ((0x100000001000L & l) != 0L && kind > 125)
- kind = 125;
- break;
- case 49:
- if ((0x20000000200000L & l) != 0L)
- jjstateSet[jjnewStateCnt++] = 48;
- break;
- case 50:
- if ((0x20000000200000L & l) != 0L && kind > 125)
- kind = 125;
- break;
- case 51:
- if ((0x100000001000L & l) != 0L)
- jjstateSet[jjnewStateCnt++] = 50;
- break;
- case 53:
- if ((0x100000001000000L & l) != 0L)
- jjCheckNAdd(54);
- break;
- case 54:
- if ((0x7e0000007eL & l) == 0L)
- break;
- if (kind > 126)
- kind = 126;
- jjCheckNAdd(54);
- break;
- case 55:
- if ((0x100000001000000L & l) != 0L)
- jjCheckNAdd(56);
- break;
- case 56:
- if ((0x7e0000007eL & l) == 0L)
- break;
- if (kind > 127)
- kind = 127;
- jjCheckNAddTwoStates(56, 57);
- break;
- case 57:
- if ((0x20100000201000L & l) != 0L && kind > 127)
- kind = 127;
- break;
- case 58:
- if ((0x100000001000000L & l) != 0L)
- jjCheckNAdd(59);
- break;
- case 59:
- if ((0x7e0000007eL & l) != 0L)
- jjCheckNAddTwoStates(59, 60);
- break;
- case 60:
- if ((0x20000000200000L & l) != 0L && kind > 128)
- kind = 128;
- break;
- case 61:
- if ((0x100000001000000L & l) != 0L)
- jjCheckNAdd(62);
- break;
- case 62:
- if ((0x7e0000007eL & l) != 0L)
- jjCheckNAddStates(54, 56);
- break;
- case 63:
- if ((0x100000001000L & l) != 0L && kind > 129)
- kind = 129;
- break;
- case 64:
- if ((0x20000000200000L & l) != 0L)
- jjstateSet[jjnewStateCnt++] = 63;
- break;
- case 65:
- if ((0x20000000200000L & l) != 0L && kind > 129)
- kind = 129;
- break;
- case 66:
- if ((0x100000001000L & l) != 0L)
- jjstateSet[jjnewStateCnt++] = 65;
- break;
- case 73:
- if ((0x2000000020L & l) != 0L)
- jjAddStates(72, 73);
- break;
- case 76:
- if ((0x104000001040L & l) != 0L && kind > 131)
- kind = 131;
- break;
- case 77:
- if (curChar == 76)
- jjAddStates(60, 61);
- break;
- default : break;
- }
- } while(i != startsAt);
- }
- else
- {
- int i2 = (curChar & 0xff) >> 6;
- long l2 = 1L << (curChar & 077);
- do
- {
- switch(jjstateSet[--i])
- {
- case 7:
- if ((jjbitVec0[i2] & l2) != 0L)
- jjAddStates(74, 75);
- break;
- case 18:
- if ((jjbitVec0[i2] & l2) != 0L)
- jjAddStates(6, 8);
- break;
- default : break;
- }
- } while(i != startsAt);
- }
- if (kind != 0x7fffffff)
- {
- jjmatchedKind = kind;
- jjmatchedPos = curPos;
- kind = 0x7fffffff;
- }
- ++curPos;
- if ((i = jjnewStateCnt) == (startsAt = 78 - (jjnewStateCnt = startsAt)))
- return curPos;
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) { return curPos; }
- }
-}
-static private int jjMoveStringLiteralDfa0_1()
-{
- switch(curChar)
- {
- case 10:
- return jjStopAtPos(0, 9);
- default :
- return 1;
- }
-}
-static private int jjMoveStringLiteralDfa0_4()
-{
- switch(curChar)
- {
- case 10:
- return jjStopAtPos(0, 14);
- case 47:
- return jjMoveStringLiteralDfa1_4(0x8000L);
- case 92:
- return jjMoveStringLiteralDfa1_4(0x30000L);
- default :
- return 1;
- }
-}
-static private int jjMoveStringLiteralDfa1_4(long active0)
-{
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- return 1;
- }
- switch(curChar)
- {
- case 10:
- if ((active0 & 0x10000L) != 0L)
- return jjStopAtPos(1, 16);
- break;
- case 13:
- return jjMoveStringLiteralDfa2_4(active0, 0x20000L);
- case 42:
- if ((active0 & 0x8000L) != 0L)
- return jjStopAtPos(1, 15);
- break;
- default :
- return 2;
- }
- return 2;
-}
-static private int jjMoveStringLiteralDfa2_4(long old0, long active0)
-{
- if (((active0 &= old0)) == 0L)
- return 2;
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- return 2;
- }
- switch(curChar)
- {
- case 10:
- if ((active0 & 0x20000L) != 0L)
- return jjStopAtPos(2, 17);
- break;
- default :
- return 3;
- }
- return 3;
-}
-static private int jjMoveStringLiteralDfa0_3()
-{
- switch(curChar)
- {
- case 42:
- return jjMoveStringLiteralDfa1_3(0x2000L);
- default :
- return 1;
- }
-}
-static private int jjMoveStringLiteralDfa1_3(long active0)
-{
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- return 1;
- }
- switch(curChar)
- {
- case 47:
- if ((active0 & 0x2000L) != 0L)
- return jjStopAtPos(1, 13);
- break;
- default :
- return 2;
- }
- return 2;
-}
-static private int jjMoveStringLiteralDfa0_2()
-{
- switch(curChar)
- {
- case 42:
- return jjMoveStringLiteralDfa1_2(0x800L);
- default :
- return 1;
- }
-}
-static private int jjMoveStringLiteralDfa1_2(long active0)
-{
- try { curChar = input_stream.readChar(); }
- catch(java.io.IOException e) {
- return 1;
- }
- switch(curChar)
- {
- case 47:
- if ((active0 & 0x800L) != 0L)
- return jjStopAtPos(1, 11);
- break;
- default :
- return 2;
- }
- return 2;
-}
-static final int[] jjnextStates = {
- 68, 69, 71, 0, 72, 73, 18, 19, 21, 42, 43, 44, 45, 46, 47, 49,
- 51, 53, 55, 58, 61, 31, 32, 33, 34, 35, 36, 38, 40, 1, 2, 5,
- 18, 19, 23, 21, 18, 19, 25, 21, 18, 19, 27, 21, 36, 38, 40, 47,
- 49, 51, 56, 57, 59, 60, 62, 64, 66, 70, 2, 5, 6, 17, 3, 4,
- 10, 11, 13, 15, 20, 22, 24, 26, 74, 75, 7, 8,
-};
-
-/** Token literal values. */
-public static final String[] jjstrLiteralImages = {
-"", null, null, null, null, null, null, null, null, null, null, null, null,
-null, null, null, null, null, null, "\173", "\175", "\133", "\135", "\50", "\51",
-"\72\72", "\72", "\73", "\54", "\77", "\56\56\56", "\75", "\52\75", "\57\75", "\45\75",
-"\53\75", "\55\75", "\74\74\75", "\76\76\75", "\46\75", "\136\75", "\174\75",
-"\174\174", "\46\46", "\174", "\136", "\46", "\75\75", "\41\75", "\74", "\76", "\74\75",
-"\76\75", "\74\74", "\76\76", "\53", "\55", "\52", "\57", "\45", "\53\53", "\55\55",
-"\176", "\41", "\56", "\55\76", "\56\52", "\55\76\52", "\141\165\164\157",
-"\142\162\145\141\153", "\143\141\163\145", "\143\141\164\143\150", "\143\150\141\162",
-"\143\157\156\163\164", "\143\157\156\164\151\156\165\145", "\144\145\146\141\165\154\164",
-"\144\145\154\145\164\145", "\144\157", "\144\157\165\142\154\145", "\145\154\163\145",
-"\145\156\165\155", "\145\170\164\145\162\156", "\146\154\157\141\164", "\146\157\162",
-"\146\162\151\145\156\144", "\147\157\164\157", "\151\146", "\151\156\154\151\156\145", "\151\156\164",
-"\154\157\156\147", "\156\145\167", "\160\162\151\166\141\164\145",
-"\160\162\157\164\145\143\164\145\144", "\160\165\142\154\151\143", "\162\145\144\145\143\154\141\162\145\144",
-"\162\145\147\151\163\164\145\162", "\162\145\164\165\162\156", "\163\150\157\162\164",
-"\163\151\147\156\145\144", "\163\151\172\145\157\146", "\163\164\141\164\151\143",
-"\163\164\162\165\143\164", "\143\154\141\163\163", "\163\167\151\164\143\150",
-"\164\145\155\160\154\141\164\145", "\164\150\151\163", "\164\162\171", "\164\171\160\145\144\145\146",
-"\165\156\151\157\156", "\165\156\163\151\147\156\145\144", "\166\151\162\164\165\141\154",
-"\166\157\151\144", "\166\157\154\141\164\151\154\145", "\167\150\151\154\145",
-"\157\160\145\162\141\164\157\162", "\164\162\165\145", "\146\141\154\163\145", "\164\150\162\157\167", null, null,
-null, null, null, null, null, null, null, null, null, null, null, null, null, null,
-"\146\151\156\141\154\154\171", null, };
-
-/** Lexer state names. */
-public static final String[] lexStateNames = {
- "DEFAULT",
- "IN_LINE_COMMENT",
- "IN_COMMENT",
- "IN_PREPROCESSOR_OUTPUT_COMMENT",
- "PREPROCESSOR_OUTPUT",
-};
-
-/** Lex State array. */
-public static final int[] jjnewLexState = {
- -1, -1, -1, -1, -1, -1, 1, 2, 4, 0, -1, 0, -1, 4, 0, 3, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-};
-static final long[] jjtoToken = {
- 0xfffffffffff80001L, 0xffffffffffffffffL, 0xffL,
-};
-static final long[] jjtoSkip = {
- 0xebfeL, 0x0L, 0x0L,
-};
-static final long[] jjtoMore = {
- 0x71400L, 0x0L, 0x0L,
-};
-static protected SimpleCharStream input_stream;
-static private final int[] jjrounds = new int[78];
-static private final int[] jjstateSet = new int[156];
-static protected char curChar;
-/** Constructor. */
-public CPPParserTokenManager(SimpleCharStream stream){
- if (input_stream != null)
- throw new TokenMgrError("ERROR: Second call to constructor of static lexer. You must use ReInit() to initialize the static variables.", TokenMgrError.STATIC_LEXER_ERROR);
- input_stream = stream;
-}
-
-/** Constructor. */
-public CPPParserTokenManager(SimpleCharStream stream, int lexState){
- this(stream);
- SwitchTo(lexState);
-}
-
-/** Reinitialise parser. */
-static public void ReInit(SimpleCharStream stream)
-{
- jjmatchedPos = jjnewStateCnt = 0;
- curLexState = defaultLexState;
- input_stream = stream;
- ReInitRounds();
-}
-static private void ReInitRounds()
-{
- int i;
- jjround = 0x80000001;
- for (i = 78; i-- > 0;)
- jjrounds[i] = 0x80000000;
-}
-
-/** Reinitialise parser. */
-static public void ReInit(SimpleCharStream stream, int lexState)
-{
- ReInit(stream);
- SwitchTo(lexState);
-}
-
-/** Switch to specified lex state. */
-static public void SwitchTo(int lexState)
-{
- if (lexState >= 5 || lexState < 0)
- throw new TokenMgrError("Error: Ignoring invalid lexical state : " + lexState + ". State unchanged.", TokenMgrError.INVALID_LEXICAL_STATE);
- else
- curLexState = lexState;
-}
-
-static protected Token jjFillToken()
-{
- final Token t;
- final String curTokenImage;
- final int beginLine;
- final int endLine;
- final int beginColumn;
- final int endColumn;
- String im = jjstrLiteralImages[jjmatchedKind];
- curTokenImage = (im == null) ? input_stream.GetImage() : im;
- beginLine = input_stream.getBeginLine();
- beginColumn = input_stream.getBeginColumn();
- endLine = input_stream.getEndLine();
- endColumn = input_stream.getEndColumn();
- t = Token.newToken(jjmatchedKind, curTokenImage);
-
- t.beginLine = beginLine;
- t.endLine = endLine;
- t.beginColumn = beginColumn;
- t.endColumn = endColumn;
-
- return t;
-}
-
-static int curLexState = 0;
-static int defaultLexState = 0;
-static int jjnewStateCnt;
-static int jjround;
-static int jjmatchedPos;
-static int jjmatchedKind;
-
-/** Get the next Token. */
-public static Token getNextToken()
-{
- Token matchedToken;
- int curPos = 0;
-
- EOFLoop :
- for (;;)
- {
- try
- {
- curChar = input_stream.BeginToken();
- }
- catch(java.io.IOException e)
- {
- jjmatchedKind = 0;
- matchedToken = jjFillToken();
- return matchedToken;
- }
-
- for (;;)
- {
- switch(curLexState)
- {
- case 0:
- try { input_stream.backup(0);
- while (curChar <= 32 && (0x100001600L & (1L << curChar)) != 0L)
- curChar = input_stream.BeginToken();
- }
- catch (java.io.IOException e1) { continue EOFLoop; }
- jjmatchedKind = 0x7fffffff;
- jjmatchedPos = 0;
- curPos = jjMoveStringLiteralDfa0_0();
- break;
- case 1:
- jjmatchedKind = 0x7fffffff;
- jjmatchedPos = 0;
- curPos = jjMoveStringLiteralDfa0_1();
- if (jjmatchedPos == 0 && jjmatchedKind > 10)
- {
- jjmatchedKind = 10;
- }
- break;
- case 2:
- jjmatchedKind = 0x7fffffff;
- jjmatchedPos = 0;
- curPos = jjMoveStringLiteralDfa0_2();
- if (jjmatchedPos == 0 && jjmatchedKind > 12)
- {
- jjmatchedKind = 12;
- }
- break;
- case 3:
- jjmatchedKind = 0x7fffffff;
- jjmatchedPos = 0;
- curPos = jjMoveStringLiteralDfa0_3();
- if (jjmatchedPos == 0 && jjmatchedKind > 12)
- {
- jjmatchedKind = 12;
- }
- break;
- case 4:
- jjmatchedKind = 0x7fffffff;
- jjmatchedPos = 0;
- curPos = jjMoveStringLiteralDfa0_4();
- if (jjmatchedPos == 0 && jjmatchedKind > 18)
- {
- jjmatchedKind = 18;
- }
- break;
- }
- if (jjmatchedKind != 0x7fffffff)
- {
- if (jjmatchedPos + 1 < curPos)
- input_stream.backup(curPos - jjmatchedPos - 1);
- if ((jjtoToken[jjmatchedKind >> 6] & (1L << (jjmatchedKind & 077))) != 0L)
- {
- matchedToken = jjFillToken();
- if (jjnewLexState[jjmatchedKind] != -1)
- curLexState = jjnewLexState[jjmatchedKind];
- return matchedToken;
- }
- else if ((jjtoSkip[jjmatchedKind >> 6] & (1L << (jjmatchedKind & 077))) != 0L)
- {
- if (jjnewLexState[jjmatchedKind] != -1)
- curLexState = jjnewLexState[jjmatchedKind];
- continue EOFLoop;
- }
- if (jjnewLexState[jjmatchedKind] != -1)
- curLexState = jjnewLexState[jjmatchedKind];
- curPos = 0;
- jjmatchedKind = 0x7fffffff;
- try {
- curChar = input_stream.readChar();
- continue;
- }
- catch (java.io.IOException e1) { }
- }
- int error_line = input_stream.getEndLine();
- int error_column = input_stream.getEndColumn();
- String error_after = null;
- boolean EOFSeen = false;
- try { input_stream.readChar(); input_stream.backup(1); }
- catch (java.io.IOException e1) {
- EOFSeen = true;
- error_after = curPos <= 1 ? "" : input_stream.GetImage();
- if (curChar == '\n' || curChar == '\r') {
- error_line++;
- error_column = 0;
- }
- else
- error_column++;
- }
- if (!EOFSeen) {
- input_stream.backup(1);
- error_after = curPos <= 1 ? "" : input_stream.GetImage();
- }
- throw new TokenMgrError(EOFSeen, curLexState, error_line, error_column, error_after, curChar, TokenMgrError.LEXICAL_ERROR);
- }
- }
-}
-
-static private void jjCheckNAdd(int state)
-{
- if (jjrounds[state] != jjround)
- {
- jjstateSet[jjnewStateCnt++] = state;
- jjrounds[state] = jjround;
- }
-}
-static private void jjAddStates(int start, int end)
-{
- do {
- jjstateSet[jjnewStateCnt++] = jjnextStates[start];
- } while (start++ != end);
-}
-static private void jjCheckNAddTwoStates(int state1, int state2)
-{
- jjCheckNAdd(state1);
- jjCheckNAdd(state2);
-}
-
-static private void jjCheckNAddStates(int start, int end)
-{
- do {
- jjCheckNAdd(jjnextStates[start]);
- } while (start++ != end);
-}
-
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/ParseException.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/ParseException.java
deleted file mode 100644
index c093ff15c5c..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/ParseException.java
+++ /dev/null
@@ -1,218 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/* Generated By:JavaCC: Do not edit this line. ParseException.java Version 4.1 */
-/* JavaCCOptions:KEEP_LINE_COL=null */
-package net.sourceforge.pmd.cpd.cppast;
-
-/**
- * This exception is thrown when parse errors are encountered.
- * You can explicitly create objects of this exception type by
- * calling the method generateParseException in the generated
- * parser.
- *
- * You can modify this class to customize your error reporting
- * mechanisms so long as you retain the public fields.
- */
-public class ParseException extends RuntimeException {
-
- /**
- * This constructor is used by the method "generateParseException"
- * in the generated parser. Calling this constructor generates
- * a new object of this type with the fields "currentToken",
- * "expectedTokenSequences", and "tokenImage" set. The boolean
- * flag "specialConstructor" is also set to true to indicate that
- * this constructor was used to create this object.
- * This constructor calls its super class with the empty string
- * to force the "toString" method of parent class "Throwable" to
- * print the error message in the form:
- * ParseException: <result of getMessage>
- */
- public ParseException(Token currentTokenVal,
- int[][] expectedTokenSequencesVal,
- String[] tokenImageVal
- )
- {
- super("");
- specialConstructor = true;
- currentToken = currentTokenVal;
- expectedTokenSequences = expectedTokenSequencesVal;
- tokenImage = tokenImageVal;
- }
-
- /**
- * The following constructors are for use by you for whatever
- * purpose you can think of. Constructing the exception in this
- * manner makes the exception behave in the normal way - i.e., as
- * documented in the class "Throwable". The fields "errorToken",
- * "expectedTokenSequences", and "tokenImage" do not contain
- * relevant information. The JavaCC generated code does not use
- * these constructors.
- */
-
- public ParseException() {
- super();
- specialConstructor = false;
- }
-
- /** Constructor with message. */
- public ParseException(String message) {
- super(message);
- specialConstructor = false;
- }
-
- /**
- * This variable determines which constructor was used to create
- * this object and thereby affects the semantics of the
- * "getMessage" method (see below).
- */
- protected boolean specialConstructor;
-
- /**
- * This is the last token that has been consumed successfully. If
- * this object has been created due to a parse error, the token
- * followng this token will (therefore) be the first error token.
- */
- public Token currentToken;
-
- /**
- * Each entry in this array is an array of integers. Each array
- * of integers represents a sequence of tokens (by their ordinal
- * values) that is expected at this point of the parse.
- */
- public int[][] expectedTokenSequences;
-
- /**
- * This is a reference to the "tokenImage" array of the generated
- * parser within which the parse error occurred. This array is
- * defined in the generated ...Constants interface.
- */
- public String[] tokenImage;
-
- /**
- * This method has the standard behavior when this object has been
- * created using the standard constructors. Otherwise, it uses
- * "currentToken" and "expectedTokenSequences" to generate a parse
- * error message and returns it. If this object has been created
- * due to a parse error, and you do not catch it (it gets thrown
- * from the parser), then this method is called during the printing
- * of the final stack trace, and hence the correct error message
- * gets displayed.
- */
- public String getMessage() {
- if (!specialConstructor) {
- return super.getMessage();
- }
- StringBuffer expected = new StringBuffer();
- int maxSize = 0;
- for (int i = 0; i < expectedTokenSequences.length; i++) {
- if (maxSize < expectedTokenSequences[i].length) {
- maxSize = expectedTokenSequences[i].length;
- }
- for (int j = 0; j < expectedTokenSequences[i].length; j++) {
- expected.append(tokenImage[expectedTokenSequences[i][j]]).append(' ');
- }
- if (expectedTokenSequences[i][expectedTokenSequences[i].length - 1] != 0) {
- expected.append("...");
- }
- expected.append(eol).append(" ");
- }
- String retval = "Encountered \"";
- Token tok = currentToken.next;
- for (int i = 0; i < maxSize; i++) {
- if (i != 0) retval += " ";
- if (tok.kind == 0) {
- retval += tokenImage[0];
- break;
- }
- retval += " " + tokenImage[tok.kind];
- retval += " \"";
- retval += add_escapes(tok.image);
- retval += " \"";
- tok = tok.next;
- }
- retval += "\" at line " + currentToken.next.beginLine + ", column " + currentToken.next.beginColumn;
- retval += "." + eol;
- if (expectedTokenSequences.length == 1) {
- retval += "Was expecting:" + eol + " ";
- } else {
- retval += "Was expecting one of:" + eol + " ";
- }
- retval += expected.toString();
- return retval;
- }
-
- /**
- * The end of line string for this machine.
- */
- protected String eol = System.getProperty("line.separator", "\n");
-
- /**
- * Used to convert raw characters to their escaped version
- * when these raw version cannot be used as part of an ASCII
- * string literal.
- */
- protected String add_escapes(String str) {
- StringBuffer retval = new StringBuffer();
- char ch;
- for (int i = 0; i < str.length(); i++) {
- switch (str.charAt(i))
- {
- case 0 :
- continue;
- case '\b':
- retval.append("\\b");
- continue;
- case '\t':
- retval.append("\\t");
- continue;
- case '\n':
- retval.append("\\n");
- continue;
- case '\f':
- retval.append("\\f");
- continue;
- case '\r':
- retval.append("\\r");
- continue;
- case '\"':
- retval.append("\\\"");
- continue;
- case '\'':
- retval.append("\\\'");
- continue;
- case '\\':
- retval.append("\\\\");
- continue;
- default:
- if ((ch = str.charAt(i)) < 0x20 || ch > 0x7e) {
- String s = "0000" + Integer.toString(ch, 16);
- retval.append("\\u" + s.substring(s.length() - 4, s.length()));
- } else {
- retval.append(ch);
- }
- continue;
- }
- }
- return retval.toString();
- }
-
-}
-/* JavaCC - OriginalChecksum=8b42f597f21215eb130252440c369111 (do not edit this line) */
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/SimpleCharStream.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/SimpleCharStream.java
deleted file mode 100644
index 54005b298d1..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/SimpleCharStream.java
+++ /dev/null
@@ -1,496 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/* Generated By:JavaCC: Do not edit this line. SimpleCharStream.java Version 4.1 */
-/* JavaCCOptions:STATIC=true */
-package net.sourceforge.pmd.cpd.cppast;
-
-/**
- * An implementation of interface CharStream, where the stream is assumed to
- * contain only ASCII characters (without unicode processing).
- */
-
-public class SimpleCharStream
-{
-/** Whether parser is static. */
- public static final boolean staticFlag = true;
- static int bufsize;
- static int available;
- static int tokenBegin;
-/** Position in buffer. */
- static public int bufpos = -1;
- static protected int bufline[];
- static protected int bufcolumn[];
-
- static protected int column = 0;
- static protected int line = 1;
-
- static protected boolean prevCharIsCR = false;
- static protected boolean prevCharIsLF = false;
-
- static protected java.io.Reader inputStream;
-
- static protected char[] buffer;
- static protected int maxNextCharInd = 0;
- static protected int inBuf = 0;
- static protected int tabSize = 8;
-
- static protected void setTabSize(int i) { tabSize = i; }
- static protected int getTabSize(int i) { return tabSize; }
-
-
- static protected void ExpandBuff(boolean wrapAround)
- {
- char[] newbuffer = new char[bufsize + 2048];
- int newbufline[] = new int[bufsize + 2048];
- int newbufcolumn[] = new int[bufsize + 2048];
-
- try
- {
- if (wrapAround)
- {
- System.arraycopy(buffer, tokenBegin, newbuffer, 0, bufsize - tokenBegin);
- System.arraycopy(buffer, 0, newbuffer,
- bufsize - tokenBegin, bufpos);
- buffer = newbuffer;
-
- System.arraycopy(bufline, tokenBegin, newbufline, 0, bufsize - tokenBegin);
- System.arraycopy(bufline, 0, newbufline, bufsize - tokenBegin, bufpos);
- bufline = newbufline;
-
- System.arraycopy(bufcolumn, tokenBegin, newbufcolumn, 0, bufsize - tokenBegin);
- System.arraycopy(bufcolumn, 0, newbufcolumn, bufsize - tokenBegin, bufpos);
- bufcolumn = newbufcolumn;
-
- maxNextCharInd = (bufpos += (bufsize - tokenBegin));
- }
- else
- {
- System.arraycopy(buffer, tokenBegin, newbuffer, 0, bufsize - tokenBegin);
- buffer = newbuffer;
-
- System.arraycopy(bufline, tokenBegin, newbufline, 0, bufsize - tokenBegin);
- bufline = newbufline;
-
- System.arraycopy(bufcolumn, tokenBegin, newbufcolumn, 0, bufsize - tokenBegin);
- bufcolumn = newbufcolumn;
-
- maxNextCharInd = (bufpos -= tokenBegin);
- }
- }
- catch (Throwable t)
- {
- throw new Error(t.getMessage());
- }
-
-
- bufsize += 2048;
- available = bufsize;
- tokenBegin = 0;
- }
-
- static protected void FillBuff() throws java.io.IOException
- {
- if (maxNextCharInd == available)
- {
- if (available == bufsize)
- {
- if (tokenBegin > 2048)
- {
- bufpos = maxNextCharInd = 0;
- available = tokenBegin;
- }
- else if (tokenBegin < 0)
- bufpos = maxNextCharInd = 0;
- else
- ExpandBuff(false);
- }
- else if (available > tokenBegin)
- available = bufsize;
- else if ((tokenBegin - available) < 2048)
- ExpandBuff(true);
- else
- available = tokenBegin;
- }
-
- int i;
- try {
- if ((i = inputStream.read(buffer, maxNextCharInd,
- available - maxNextCharInd)) == -1)
- {
- inputStream.close();
- throw new java.io.IOException();
- }
- else
- maxNextCharInd += i;
- return;
- }
- catch(java.io.IOException e) {
- --bufpos;
- backup(0);
- if (tokenBegin == -1)
- tokenBegin = bufpos;
- throw e;
- }
- }
-
-/** Start. */
- static public char BeginToken() throws java.io.IOException
- {
- tokenBegin = -1;
- char c = readChar();
- tokenBegin = bufpos;
-
- return c;
- }
-
- static protected void UpdateLineColumn(char c)
- {
- column++;
-
- if (prevCharIsLF)
- {
- prevCharIsLF = false;
- line += (column = 1);
- }
- else if (prevCharIsCR)
- {
- prevCharIsCR = false;
- if (c == '\n')
- {
- prevCharIsLF = true;
- }
- else
- line += (column = 1);
- }
-
- switch (c)
- {
- case '\r' :
- prevCharIsCR = true;
- break;
- case '\n' :
- prevCharIsLF = true;
- break;
- case '\t' :
- column--;
- column += (tabSize - (column % tabSize));
- break;
- default :
- break;
- }
-
- bufline[bufpos] = line;
- bufcolumn[bufpos] = column;
- }
-
-/** Read a character. */
- static public char readChar() throws java.io.IOException
- {
- if (inBuf > 0)
- {
- --inBuf;
-
- if (++bufpos == bufsize)
- bufpos = 0;
-
- return buffer[bufpos];
- }
-
- if (++bufpos >= maxNextCharInd)
- FillBuff();
-
- char c = buffer[bufpos];
-
- UpdateLineColumn(c);
- return c;
- }
-
- /**
- * @deprecated
- * @see #getEndColumn
- */
-
- static public int getColumn() {
- return bufcolumn[bufpos];
- }
-
- /**
- * @deprecated
- * @see #getEndLine
- */
-
- static public int getLine() {
- return bufline[bufpos];
- }
-
- /** Get token end column number. */
- static public int getEndColumn() {
- return bufcolumn[bufpos];
- }
-
- /** Get token end line number. */
- static public int getEndLine() {
- return bufline[bufpos];
- }
-
- /** Get token beginning column number. */
- static public int getBeginColumn() {
- return bufcolumn[tokenBegin];
- }
-
- /** Get token beginning line number. */
- static public int getBeginLine() {
- return bufline[tokenBegin];
- }
-
-/** Backup a number of characters. */
- static public void backup(int amount) {
-
- inBuf += amount;
- if ((bufpos -= amount) < 0)
- bufpos += bufsize;
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.Reader dstream, int startline,
- int startcolumn, int buffersize)
- {
- if (inputStream != null)
- throw new Error("\n ERROR: Second call to the constructor of a static SimpleCharStream.\n" +
- " You must either use ReInit() or set the JavaCC option STATIC to false\n" +
- " during the generation of this class.");
- inputStream = dstream;
- line = startline;
- column = startcolumn - 1;
-
- available = bufsize = buffersize;
- buffer = new char[buffersize];
- bufline = new int[buffersize];
- bufcolumn = new int[buffersize];
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.Reader dstream, int startline,
- int startcolumn)
- {
- this(dstream, startline, startcolumn, 4096);
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.Reader dstream)
- {
- this(dstream, 1, 1, 4096);
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.Reader dstream, int startline,
- int startcolumn, int buffersize)
- {
- inputStream = dstream;
- line = startline;
- column = startcolumn - 1;
-
- if (buffer == null || buffersize != buffer.length)
- {
- available = bufsize = buffersize;
- buffer = new char[buffersize];
- bufline = new int[buffersize];
- bufcolumn = new int[buffersize];
- }
- prevCharIsLF = prevCharIsCR = false;
- tokenBegin = inBuf = maxNextCharInd = 0;
- bufpos = -1;
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.Reader dstream, int startline,
- int startcolumn)
- {
- ReInit(dstream, startline, startcolumn, 4096);
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.Reader dstream)
- {
- ReInit(dstream, 1, 1, 4096);
- }
- /** Constructor. */
- public SimpleCharStream(java.io.InputStream dstream, String encoding, int startline,
- int startcolumn, int buffersize) throws java.io.UnsupportedEncodingException
- {
- this(encoding == null ? new java.io.InputStreamReader(dstream) : new java.io.InputStreamReader(dstream, encoding), startline, startcolumn, buffersize);
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.InputStream dstream, int startline,
- int startcolumn, int buffersize)
- {
- this(new java.io.InputStreamReader(dstream), startline, startcolumn, buffersize);
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.InputStream dstream, String encoding, int startline,
- int startcolumn) throws java.io.UnsupportedEncodingException
- {
- this(dstream, encoding, startline, startcolumn, 4096);
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.InputStream dstream, int startline,
- int startcolumn)
- {
- this(dstream, startline, startcolumn, 4096);
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.InputStream dstream, String encoding) throws java.io.UnsupportedEncodingException
- {
- this(dstream, encoding, 1, 1, 4096);
- }
-
- /** Constructor. */
- public SimpleCharStream(java.io.InputStream dstream)
- {
- this(dstream, 1, 1, 4096);
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.InputStream dstream, String encoding, int startline,
- int startcolumn, int buffersize) throws java.io.UnsupportedEncodingException
- {
- ReInit(encoding == null ? new java.io.InputStreamReader(dstream) : new java.io.InputStreamReader(dstream, encoding), startline, startcolumn, buffersize);
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.InputStream dstream, int startline,
- int startcolumn, int buffersize)
- {
- ReInit(new java.io.InputStreamReader(dstream), startline, startcolumn, buffersize);
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.InputStream dstream, String encoding) throws java.io.UnsupportedEncodingException
- {
- ReInit(dstream, encoding, 1, 1, 4096);
- }
-
- /** Reinitialise. */
- public void ReInit(java.io.InputStream dstream)
- {
- ReInit(dstream, 1, 1, 4096);
- }
- /** Reinitialise. */
- public void ReInit(java.io.InputStream dstream, String encoding, int startline,
- int startcolumn) throws java.io.UnsupportedEncodingException
- {
- ReInit(dstream, encoding, startline, startcolumn, 4096);
- }
- /** Reinitialise. */
- public void ReInit(java.io.InputStream dstream, int startline,
- int startcolumn)
- {
- ReInit(dstream, startline, startcolumn, 4096);
- }
- /** Get token literal value. */
- static public String GetImage()
- {
- if (bufpos >= tokenBegin)
- return new String(buffer, tokenBegin, bufpos - tokenBegin + 1);
- else
- return new String(buffer, tokenBegin, bufsize - tokenBegin) +
- new String(buffer, 0, bufpos + 1);
- }
-
- /** Get the suffix. */
- static public char[] GetSuffix(int len)
- {
- char[] ret = new char[len];
-
- if ((bufpos + 1) >= len)
- System.arraycopy(buffer, bufpos - len + 1, ret, 0, len);
- else
- {
- System.arraycopy(buffer, bufsize - (len - bufpos - 1), ret, 0,
- len - bufpos - 1);
- System.arraycopy(buffer, 0, ret, len - bufpos - 1, bufpos + 1);
- }
-
- return ret;
- }
-
- /** Reset buffer when finished. */
- static public void Done()
- {
- buffer = null;
- bufline = null;
- bufcolumn = null;
- }
-
- /**
- * Method to adjust line and column numbers for the start of a token.
- */
- static public void adjustBeginLineColumn(int newLine, int newCol)
- {
- int start = tokenBegin;
- int len;
-
- if (bufpos >= tokenBegin)
- {
- len = bufpos - tokenBegin + inBuf + 1;
- }
- else
- {
- len = bufsize - tokenBegin + bufpos + 1 + inBuf;
- }
-
- int i = 0, j = 0, k = 0;
- int nextColDiff = 0, columnDiff = 0;
-
- while (i < len &&
- bufline[j = start % bufsize] == bufline[k = ++start % bufsize])
- {
- bufline[j] = newLine;
- nextColDiff = columnDiff + bufcolumn[k] - bufcolumn[j];
- bufcolumn[j] = newCol + columnDiff;
- columnDiff = nextColDiff;
- i++;
- }
-
- if (i < len)
- {
- bufline[j] = newLine++;
- bufcolumn[j] = newCol + columnDiff;
-
- while (i++ < len)
- {
- if (bufline[j = start % bufsize] != bufline[++start % bufsize])
- bufline[j] = newLine++;
- else
- bufline[j] = newLine;
- }
- }
-
- line = bufline[j];
- column = bufcolumn[j];
- }
-
-}
-/* JavaCC - OriginalChecksum=9bbb8cb4295bb8f7d58e31ce57dc2e0f (do not edit this line) */
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/Token.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/Token.java
deleted file mode 100644
index 15f78e80a1f..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/Token.java
+++ /dev/null
@@ -1,144 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/* Generated By:JavaCC: Do not edit this line. Token.java Version 4.1 */
-/* JavaCCOptions:TOKEN_EXTENDS=,KEEP_LINE_COL=null */
-package net.sourceforge.pmd.cpd.cppast;
-
-/**
- * Describes the input token stream.
- */
-
-public class Token {
-
- /**
- * An integer that describes the kind of this token. This numbering
- * system is determined by JavaCCParser, and a table of these numbers is
- * stored in the file ...Constants.java.
- */
- public int kind;
-
- /** The line number of the first character of this Token. */
- public int beginLine;
- /** The column number of the first character of this Token. */
- public int beginColumn;
- /** The line number of the last character of this Token. */
- public int endLine;
- /** The column number of the last character of this Token. */
- public int endColumn;
-
- /**
- * The string image of the token.
- */
- public String image;
-
- /**
- * A reference to the next regular (non-special) token from the input
- * stream. If this is the last token from the input stream, or if the
- * token manager has not read tokens beyond this one, this field is
- * set to null. This is true only if this token is also a regular
- * token. Otherwise, see below for a description of the contents of
- * this field.
- */
- public Token next;
-
- /**
- * This field is used to access special tokens that occur prior to this
- * token, but after the immediately preceding regular (non-special) token.
- * If there are no such special tokens, this field is set to null.
- * When there are more than one such special token, this field refers
- * to the last of these special tokens, which in turn refers to the next
- * previous special token through its specialToken field, and so on
- * until the first special token (whose specialToken field is null).
- * The next fields of special tokens refer to other special tokens that
- * immediately follow it (without an intervening regular token). If there
- * is no such token, this field is null.
- */
- public Token specialToken;
-
- /**
- * An optional attribute value of the Token.
- * Tokens which are not used as syntactic sugar will often contain
- * meaningful values that will be used later on by the compiler or
- * interpreter. This attribute value is often different from the image.
- * Any subclass of Token that actually wants to return a non-null value can
- * override this method as appropriate.
- */
- public Object getValue() {
- return null;
- }
-
- /**
- * No-argument constructor
- */
- public Token() {}
-
- /**
- * Constructs a new token for the specified Image.
- */
- public Token(int kind)
- {
- this(kind, null);
- }
-
- /**
- * Constructs a new token for the specified Image and Kind.
- */
- public Token(int kind, String image)
- {
- this.kind = kind;
- this.image = image;
- }
-
- /**
- * Returns the image.
- */
- public String toString()
- {
- return image;
- }
-
- /**
- * Returns a new Token object, by default. However, if you want, you
- * can create and return subclass objects based on the value of ofKind.
- * Simply add the cases to the switch for all those special cases.
- * For example, if you have a subclass of Token called IDToken that
- * you want to create if ofKind is ID, simply add something like :
- *
- * case MyParserConstants.ID : return new IDToken(ofKind, image);
- *
- * to the following switch statement. Then you can cast matchedToken
- * variable to the appropriate type and use sit in your lexical actions.
- */
- public static Token newToken(int ofKind, String image)
- {
- switch(ofKind)
- {
- default : return new Token(ofKind, image);
- }
- }
-
- public static Token newToken(int ofKind)
- {
- return newToken(ofKind, null);
- }
-
-}
-/* JavaCC - OriginalChecksum=1917659c640ac2c65feaa32a37580421 (do not edit this line) */
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/TokenMgrError.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/TokenMgrError.java
deleted file mode 100644
index e51205fe2f9..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/cpd/cppast/TokenMgrError.java
+++ /dev/null
@@ -1,160 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/* Generated By:JavaCC: Do not edit this line. TokenMgrError.java Version 4.1 */
-/* JavaCCOptions: */
-package net.sourceforge.pmd.cpd.cppast;
-
-/** Token Manager Error. */
-public class TokenMgrError extends Error
-{
-
- /*
- * Ordinals for various reasons why an Error of this type can be thrown.
- */
-
- /**
- * Lexical error occurred.
- */
- static final int LEXICAL_ERROR = 0;
-
- /**
- * An attempt was made to create a second instance of a static token manager.
- */
- static final int STATIC_LEXER_ERROR = 1;
-
- /**
- * Tried to change to an invalid lexical state.
- */
- static final int INVALID_LEXICAL_STATE = 2;
-
- /**
- * Detected (and bailed out of) an infinite loop in the token manager.
- */
- static final int LOOP_DETECTED = 3;
-
- /**
- * Indicates the reason why the exception is thrown. It will have
- * one of the above 4 values.
- */
- int errorCode;
-
- /**
- * Replaces unprintable characters by their escaped (or unicode escaped)
- * equivalents in the given string
- */
- protected static final String addEscapes(String str) {
- StringBuffer retval = new StringBuffer();
- char ch;
- for (int i = 0; i < str.length(); i++) {
- switch (str.charAt(i))
- {
- case 0 :
- continue;
- case '\b':
- retval.append("\\b");
- continue;
- case '\t':
- retval.append("\\t");
- continue;
- case '\n':
- retval.append("\\n");
- continue;
- case '\f':
- retval.append("\\f");
- continue;
- case '\r':
- retval.append("\\r");
- continue;
- case '\"':
- retval.append("\\\"");
- continue;
- case '\'':
- retval.append("\\\'");
- continue;
- case '\\':
- retval.append("\\\\");
- continue;
- default:
- if ((ch = str.charAt(i)) < 0x20 || ch > 0x7e) {
- String s = "0000" + Integer.toString(ch, 16);
- retval.append("\\u" + s.substring(s.length() - 4, s.length()));
- } else {
- retval.append(ch);
- }
- continue;
- }
- }
- return retval.toString();
- }
-
- /**
- * Returns a detailed message for the Error when it is thrown by the
- * token manager to indicate a lexical error.
- * Parameters :
- * EOFSeen : indicates if EOF caused the lexical error
- * curLexState : lexical state in which this error occurred
- * errorLine : line number when the error occurred
- * errorColumn : column number when the error occurred
- * errorAfter : prefix that was seen before this error occurred
- * curchar : the offending character
- * Note: You can customize the lexical error message by modifying this method.
- */
- protected static String LexicalError(boolean EOFSeen, int lexState, int errorLine, int errorColumn, String errorAfter, char curChar) {
- return("Lexical error in file " + CPPParserTokenManager.getFileName() + " at line " +
- errorLine + ", column " +
- errorColumn + ". Encountered: " +
- (EOFSeen ? "<EOF> " : ("\"" + addEscapes(String.valueOf(curChar)) + "\"") + " (" + (int)curChar + "), ") +
- "after : \"" + addEscapes(errorAfter) + "\"");
- }
-
- /**
- * You can also modify the body of this method to customize your error messages.
- * For example, cases like LOOP_DETECTED and INVALID_LEXICAL_STATE are not
- * of end-users concern, so you can return something like :
- *
- * "Internal Error : Please file a bug report .... "
- *
- * from this method for such cases in the release version of your parser.
- */
- public String getMessage() {
- return super.getMessage();
- }
-
- /*
- * Constructors of various flavors follow.
- */
-
- /** No arg constructor. */
- public TokenMgrError() {
- }
-
- /** Constructor with message and reason. */
- public TokenMgrError(String message, int reason) {
- super(message);
- errorCode = reason;
- }
-
- /** Full Constructor. */
- public TokenMgrError(boolean EOFSeen, int lexState, int errorLine, int errorColumn, String errorAfter, char curChar, int reason) {
- this(LexicalError(EOFSeen, lexState, errorLine, errorColumn, errorAfter, curChar), reason);
- }
-}
-/* JavaCC - OriginalChecksum=7925b33c412b4bfa3a7147ae3e790276 (do not edit this line) */
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/FileFinder.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/FileFinder.java
index 42f8764f264..2f17ee51433 100644
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/FileFinder.java
+++ b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/FileFinder.java
@@ -30,33 +30,33 @@ import java.util.List;
*/
public class FileFinder {
- private FilenameFilter filter;
- private static final String FILE_SEP = System.getProperty("file.separator");
+ private FilenameFilter filter;
+ private static final String FILE_SEP = System.getProperty("file.separator");
- public List<File> findFilesFrom(String dir, FilenameFilter filter, boolean recurse) {
- this.filter = filter;
- List<File> files = new ArrayList<File>();
- scanDirectory(new File(dir), files, recurse);
- return files;
- }
+ public List<File> findFilesFrom(String dir, FilenameFilter filter, boolean recurse) {
+ this.filter = filter;
+ List<File> files = new ArrayList<File>();
+ scanDirectory(new File(dir), files, recurse);
+ return files;
+ }
- /**
- * Implements a tail recursive file scanner
- */
- private void scanDirectory(File dir, List<File> list, boolean recurse) {
- String[] candidates = dir.list(filter);
- if (candidates == null) {
- return;
- }
- for (int i = 0; i < candidates.length; i++) {
- File tmp = new File(dir + FILE_SEP + candidates[i]);
- if (tmp.isDirectory()) {
- if (recurse) {
- scanDirectory(tmp, list, true);
- }
- } else {
- list.add(new File(dir + FILE_SEP + candidates[i]));
- }
+ /**
+ * Implements a tail recursive file scanner
+ */
+ private void scanDirectory(File dir, List<File> list, boolean recurse) {
+ String[] candidates = dir.list(filter);
+ if (candidates == null) {
+ return;
+ }
+ for (int i = 0; i < candidates.length; i++) {
+ File tmp = new File(dir + FILE_SEP + candidates[i]);
+ if (tmp.isDirectory()) {
+ if (recurse) {
+ scanDirectory(tmp, list, true);
}
+ } else {
+ list.add(new File(dir + FILE_SEP + candidates[i]));
+ }
}
+ }
}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/StringUtil.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/StringUtil.java
deleted file mode 100644
index ce84dd3dc0d..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/StringUtil.java
+++ /dev/null
@@ -1,330 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-/**
- * BSD-style license; for more info see http://pmd.sourceforge.net/license.html
- */
-package net.sourceforge.pmd.util;
-
-import java.util.ArrayList;
-import java.util.Iterator;
-import java.util.List;
-
-public class StringUtil {
-
- public static final String[] EMPTY_STRINGS = new String[0];
- private static final boolean supportsUTF8 = System.getProperty("net.sourceforge.pmd.supportUTF8", "no").equals("yes");
- private static final String[] ENTITIES;
-
- static {
- ENTITIES = new String[256 - 126];
- for (int i = 126; i <= 255; i++) {
- ENTITIES[i - 126] = "&#" + i + ';';
- }
- }
-
- public static String replaceString(String original, char oldChar, String newString) {
-
- String fixedNew = newString == null ? "" : newString;
-
- StringBuffer desc = new StringBuffer();
- int index = original.indexOf(oldChar);
- int last = 0;
- while (index != -1) {
- desc.append(original.substring(last, index));
- desc.append(fixedNew);
- last = index + 1;
- index = original.indexOf(oldChar, last);
- }
- desc.append(original.substring(last));
- return desc.toString();
- }
-
- public static String replaceString(String original, String oldString, String newString) {
-
- String fixedNew = newString == null ? "" : newString;
-
- StringBuffer desc = new StringBuffer();
- int index = original.indexOf(oldString);
- int last = 0;
- while (index != -1) {
- desc.append(original.substring(last, index));
- desc.append(fixedNew);
- last = index + oldString.length();
- index = original.indexOf(oldString, last);
- }
- desc.append(original.substring(last));
- return desc.toString();
- }
-
- /**
- * Appends to a StringBuffer the String src where non-ASCII and
- * XML special chars are escaped.
- *
- * @param buf The destination XML stream
- * @param src The String to append to the stream
- */
- public static void appendXmlEscaped(StringBuffer buf, String src) {
- appendXmlEscaped(buf, src, supportsUTF8);
- }
-
- public static String htmlEncode(String string) {
- String encoded = StringUtil.replaceString(string, '&', "&amp;");
- encoded = StringUtil.replaceString(encoded, '<', "&lt;");
- return StringUtil.replaceString(encoded, '>', "&gt;");
- }
-
- // TODO - unify the method above with the one below
-
- private static void appendXmlEscaped(StringBuffer buf, String src, boolean supportUTF8) {
- char c;
- for (int i = 0; i < src.length(); i++) {
- c = src.charAt(i);
- if (c > '~') {// 126
- if (!supportUTF8) {
- if (c <= 255) {
- buf.append(ENTITIES[c - 126]);
- } else {
- buf.append("&u").append(Integer.toHexString(c)).append(';');
- }
- } else {
- buf.append(c);
- }
- } else if (c == '&')
- buf.append("&amp;");
- else if (c == '"')
- buf.append("&quot;");
- else if (c == '<')
- buf.append("&lt;");
- else if (c == '>')
- buf.append("&gt;");
- else
- buf.append(c);
- }
- }
-
- /**
- * Parses the input source using the delimiter specified. This method is much
- * faster than using the StringTokenizer or String.split(char) approach and
- * serves as a replacement for String.split() for JDK1.3 that doesn't have it.
- *
- * FIXME - we're on JDK 1.4 now, can we replace this with String.split?
- *
- * @param source String
- * @param delimiter char
- * @return String[]
- */
- public static String[] substringsOf(String source, char delimiter) {
-
- if (source == null || source.length() == 0) {
- return EMPTY_STRINGS;
- }
-
- int delimiterCount = 0;
- int length = source.length();
- char[] chars = source.toCharArray();
-
- for (int i=0; i<length; i++) {
- if (chars[i] == delimiter) delimiterCount++;
- }
-
- if (delimiterCount == 0) return new String[] { source };
-
- String results[] = new String[delimiterCount+1];
-
- int i = 0;
- int offset = 0;
-
- while (offset <= length) {
- int pos = source.indexOf(delimiter, offset);
- if (pos < 0) pos = length;
- results[i++] = pos == offset ? "" : source.substring(offset, pos);
- offset = pos + 1;
- }
-
- return results;
- }
-
- /**
- * Much more efficient than StringTokenizer.
- *
- * @param str String
- * @param separator char
- * @return String[]
- */
- public static String[] substringsOf(String str, String separator) {
-
- if (str == null || str.length() == 0) {
- return EMPTY_STRINGS;
- }
-
- int index = str.indexOf(separator);
- if (index == -1) {
- return new String[]{str};
- }
-
- List<String> list = new ArrayList<String>();
- int currPos = 0;
- int len = separator.length();
- while (index != -1) {
- list.add(str.substring(currPos, index));
- currPos = index + len;
- index = str.indexOf(separator, currPos);
- }
- list.add(str.substring(currPos));
- return list.toArray(new String[list.size()]);
- }
-
-
- /**
- * Copies the elements returned by the iterator onto the string buffer
- * each delimited by the separator.
- *
- * @param sb StringBuffer
- * @param iter Iterator
- * @param separator String
- */
- public static void asStringOn(StringBuffer sb, Iterator iter, String separator) {
-
- if (!iter.hasNext()) return;
-
- sb.append(iter.next());
-
- while (iter.hasNext()) {
- sb.append(separator);
- sb.append(iter.next());
- }
- }
- /**
- * Return the length of the shortest string in the array.
- * If any one of them is null then it returns 0.
- *
- * @param strings String[]
- * @return int
- */
- public static int lengthOfShortestIn(String[] strings) {
-
- int minLength = Integer.MAX_VALUE;
-
- for (int i=0; i<strings.length; i++) {
- if (strings[i] == null) return 0;
- minLength = Math.min(minLength, strings[i].length());
- }
-
- return minLength;
- }
-
- /**
- * Determine the maximum number of common leading whitespace characters
- * the strings share in the same sequence. Useful for determining how
- * many leading characters can be removed to shift all the text in the
- * strings to the left without misaligning them.
- *
- * @param strings String[]
- * @return int
- */
- public static int maxCommonLeadingWhitespaceForAll(String[] strings) {
-
- int shortest = lengthOfShortestIn(strings);
- if (shortest == 0) return 0;
-
- char[] matches = new char[shortest];
-
- String str;
- for (int m=0; m<matches.length; m++) {
- matches[m] = strings[0].charAt(m);
- if (!Character.isWhitespace(matches[m])) return m;
- for (int i=0; i<strings.length; i++) {
- str = strings[i];
- if (str.charAt(m) != matches[m]) return m;
- }
- }
-
- return shortest;
- }
-
- /**
- * Trims off the leading characters off the strings up to the trimDepth
- * specified. Returns the same strings if trimDepth = 0
- *
- * @param strings
- * @param trimDepth
- * @return String[]
- */
- public static String[] trimStartOn(String[] strings, int trimDepth) {
-
- if (trimDepth == 0) return strings;
-
- String[] results = new String[strings.length];
- for (int i=0; i<strings.length; i++) {
- results[i] = strings[i].substring(trimDepth);
- }
- return results;
- }
-
- /**
- * Left pads a string.
- * @param s The String to pad
- * @param length The desired minimum length of the resulting padded String
- * @return The resulting left padded String
- */
- public static String lpad(String s, int length) {
- String res = s;
- if (length - s.length() > 0) {
- char [] arr = new char[length - s.length()];
- java.util.Arrays.fill(arr, ' ');
- res = new StringBuffer(length).append(arr).append(s).toString();
- }
- return res;
- }
-
- /**
- * Are the two String values the same.
- * The Strings can be optionally trimmed before checking.
- * The Strings can be optionally compared ignoring case.
- * The Strings can be have embedded whitespace standardized before comparing.
- * Two null values are treated as equal.
- *
- * @param s1 The first String.
- * @param s2 The second String.
- * @param trim Indicates if the Strings should be trimmed before comparison.
- * @param ignoreCase Indicates if the case of the Strings should ignored during comparison.
- * @param standardizeWhitespace Indicates if the embedded whitespace should be standardized before comparison.
- * @return <code>true</code> if the Strings are the same, <code>false</code> otherwise.
- */
- public static boolean isSame(String s1, String s2, boolean trim, boolean ignoreCase, boolean standardizeWhitespace) {
- if (s1 == s2) {
- return true;
- } else if (s1 == null || s2 == null) {
- return false;
- } else {
- if (trim) {
- s1 = s1.trim();
- s2 = s2.trim();
- }
- if (standardizeWhitespace) {
- // Replace all whitespace with a standard single space character.
- s1 = s1.replaceAll("\\s+", " ");
- s2 = s2.replaceAll("\\s+", " ");
- }
- return ignoreCase ? s1.equalsIgnoreCase(s2) : s1.equals(s2);
- }
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractCompoundFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractCompoundFilter.java
deleted file mode 100644
index 13e300689f9..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractCompoundFilter.java
+++ /dev/null
@@ -1,76 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-import java.util.ArrayList;
-import java.util.List;
-
-/**
- * A base class for Filters which implements behavior using a List of other
- * Filters.
- *
- * @param <T>
- * The underlying type on which the filter applies.
- */
-public abstract class AbstractCompoundFilter<T> implements Filter<T> {
-
- protected List<Filter<T>> filters;
-
- public AbstractCompoundFilter() {
- filters = new ArrayList<Filter<T>>(2);
- }
-
- public AbstractCompoundFilter(Filter<T>... filters) {
- this.filters = new ArrayList<Filter<T>>(filters.length);
- for (Filter<T> filter : filters) {
- this.filters.add(filter);
- }
- }
-
- public List<Filter<T>> getFilters() {
- return filters;
- }
-
- public void setFilters(List<Filter<T>> filters) {
- this.filters = filters;
- }
-
- public void addFilter(Filter<T> filter) {
- filters.add(filter);
- }
-
- protected abstract String getOperator();
-
- public String toString() {
- StringBuilder builder = new StringBuilder();
- builder.append("(");
- for (int i = 0; i < filters.size(); i++) {
- if (i > 0) {
- builder.append(" ");
- builder.append(getOperator());
- builder.append(" ");
- }
- builder.append(filters.get(i));
- }
- builder.append(")");
- return builder.toString();
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractDelegateFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractDelegateFilter.java
deleted file mode 100644
index e203bb58b6c..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AbstractDelegateFilter.java
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-/**
- * A base class for Filters which implements behavior using delegation
- * to an underlying filter.
- *
- * @param <T>
- * The underlying type on which the filter applies.
- */
-public abstract class AbstractDelegateFilter<T> implements Filter<T> {
- protected Filter<T> filter;
-
- public AbstractDelegateFilter() {
- }
-
- public AbstractDelegateFilter(Filter<T> filter) {
- this.filter = filter;
- }
-
- public Filter<T> getFilter() {
- return filter;
- }
-
- public void setFilter(Filter<T> filter) {
- this.filter = filter;
- }
-
- // Subclass should override to do something other the simply delegate.
- public boolean filter(T obj) {
- return filter.filter(obj);
- }
-
- // Subclass should override to do something other the simply delegate.
- public String toString() {
- return filter.toString();
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AndFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AndFilter.java
deleted file mode 100644
index 96ab80a3edd..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/AndFilter.java
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-/**
- * A logical AND of a list of Filters. This implementation is short circuiting.
- *
- * @param <T>
- * The underlying type on which the filter applies.
- */
-public class AndFilter<T> extends AbstractCompoundFilter<T> {
-
- public AndFilter() {
- super();
- }
-
- public AndFilter(Filter<T>... filters) {
- super(filters);
- }
-
- public boolean filter(T obj) {
- boolean match = true;
- for (Filter<T> filter : filters) {
- if (!filter.filter(obj)) {
- match = false;
- break;
- }
- }
- return match;
- }
-
- @Override
- protected String getOperator() {
- return "and";
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/DirectoryFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/DirectoryFilter.java
deleted file mode 100644
index 4d632ec23b0..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/DirectoryFilter.java
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-import java.io.File;
-
-/**
- * Directory filter.
- */
-public class DirectoryFilter implements Filter<File> {
- public static final DirectoryFilter INSTANCE = new DirectoryFilter();
-
- private DirectoryFilter() {
- }
-
- public boolean filter(File file) {
- return file.isDirectory();
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/FileExtensionFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/FileExtensionFilter.java
deleted file mode 100644
index f442e8e93ef..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/FileExtensionFilter.java
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-import java.io.File;
-
-public class FileExtensionFilter implements Filter<File> {
- protected final String[] extensions;
- protected final boolean ignoreCase;
-
- /**
- * Matches any files with the given extensions, ignoring case
- */
- public FileExtensionFilter(String... extensions) {
- this(true, extensions);
- }
-
- /**
- * Matches any files with the given extensions, optionally ignoring case.
- */
- public FileExtensionFilter(boolean ignoreCase, String... extensions) {
- this.extensions = extensions;
- this.ignoreCase = ignoreCase;
- if (ignoreCase) {
- for (int i = 0; i < this.extensions.length; i++) {
- this.extensions[i] = this.extensions[i].toUpperCase();
- }
- }
- }
-
- public boolean filter(File file) {
- boolean accept = extensions == null;
- if (!accept) {
- for (String extension : extensions) {
- String name = file.getName();
- if (ignoreCase ? name.toUpperCase().endsWith(extension) : name.endsWith(extension)) {
- accept = true;
- break;
- }
- }
- }
- return accept;
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filter.java
deleted file mode 100644
index 2acd458c6c6..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filter.java
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-/**
- * A Filter interface, used for filtering arbitrary objects.
- *
- * @param <T>
- * The underlying type on which the filter applies.
- */
-public interface Filter<T> {
- boolean filter(T obj);
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filters.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filters.java
deleted file mode 100644
index 9acd1a61660..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/Filters.java
+++ /dev/null
@@ -1,220 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-import java.io.File;
-import java.io.FilenameFilter;
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.List;
-
-/**
- * Utility class for working with Filters. Contains builder style methods,
- * apply methods, as well as mechanisms for adapting Filters and FilenameFilters.
- */
-public class Filters {
-
- /**
- * Filter a given Collection.
- * @param <T> Type of the Collection.
- * @param filter A Filter upon the Type of objects in the Collection.
- * @param collection The Collection to filter.
- * @return A List containing only those objects for which the Filter returned <code>true</code>.
- */
- public static <T> List<T> filter(Filter<T> filter, Collection<T> collection) {
- List<T> list = new ArrayList<T>();
- for (T obj : collection) {
- if (filter.filter(obj)) {
- list.add(obj);
- }
- }
- return list;
- }
-
- /**
- * Get a File Filter for files with the given extensions, ignoring case.
- * @param extensions The extensions to filter.
- * @return A File Filter.
- */
- public static Filter<File> getFileExtensionFilter(String... extensions) {
- return new FileExtensionFilter(extensions);
- }
-
- /**
- * Get a File Filter for directories.
- * @return A File Filter.
- */
- public static Filter<File> getDirectoryFilter() {
- return DirectoryFilter.INSTANCE;
- }
-
- /**
- * Get a File Filter for directories or for files with the given extensions, ignoring case.
- * @param extensions The extensions to filter.
- * @return A File Filter.
- */
- public static Filter<File> getFileExtensionOrDirectoryFilter(String... extensions) {
- return new OrFilter<File>(getFileExtensionFilter(extensions), getDirectoryFilter());
- }
-
- /**
- * Given a String Filter, expose as a File Filter. The File paths are
- * normalized to a standard pattern using <code>/</code> as a path separator
- * which can be used cross platform easily in a regular expression based
- * String Filter.
- *
- * @param filter A String Filter.
- * @return A File Filter.
- */
- public static Filter<File> toNormalizedFileFilter(final Filter<String> filter) {
- return new Filter<File>() {
- public boolean filter(File file) {
- String path = file.getPath();
- path = path.replace('\\', '/');
- return filter.filter(path);
- }
-
- public String toString() {
- return filter.toString();
- }
- };
- }
-
- /**
- * Given a String Filter, expose as a Filter on another type. The
- * <code>toString()</code> method is called on the objects of the other
- * type and delegated to the String Filter.
- * @param <T> The desired type.
- * @param filter The existing String Filter.
- * @return A Filter on the desired type.
- */
- public static <T> Filter<T> fromStringFilter(final Filter<String> filter) {
- return new Filter<T>() {
- public boolean filter(T obj) {
- return filter.filter(obj.toString());
- }
-
- public String toString() {
- return filter.toString();
- }
- };
- }
-
- /**
- * Given a File Filter, expose as a FilenameFilter.
- * @param filter The File Filter.
- * @return A FilenameFilter.
- */
- public static FilenameFilter toFilenameFilter(final Filter<File> filter) {
- return new FilenameFilter() {
- public boolean accept(File dir, String name) {
- return filter.filter(new File(dir, name));
- }
-
- public String toString() {
- return filter.toString();
- }
- };
- }
-
- /**
- * Given a FilenameFilter, expose as a File Filter.
- * @param filter The FilenameFilter.
- * @return A File Filter.
- */
- public static Filter<File> toFileFilter(final FilenameFilter filter) {
- return new Filter<File>() {
- public boolean filter(File file) {
- return filter.accept(file.getParentFile(), file.getName());
- }
-
- public String toString() {
- return filter.toString();
- }
- };
- }
-
- /**
- * Construct a String Filter using set of include and exclude regular
- * expressions. If there are no include regular expressions provide, then
- * a regular expression is added which matches every String by default.
- * A String is included as long as it matches an include regular expression
- * and does not match an exclude regular expression.
- * <p>
- * In other words, exclude patterns override include patterns.
- *
- * @param includeRegexes The include regular expressions. May be <code>null</code>.
- * @param excludeRegexes The exclude regular expressions. May be <code>null</code>.
- * @return A String Filter.
- */
- public static Filter<String> buildRegexFilterExcludeOverInclude(List<String> includeRegexes,
- List<String> excludeRegexes) {
- OrFilter<String> includeFilter = new OrFilter<String>();
- if (includeRegexes == null || includeRegexes.size() == 0) {
- includeFilter.addFilter(new RegexStringFilter(".*"));
- } else {
- for (String includeRegex : includeRegexes) {
- includeFilter.addFilter(new RegexStringFilter(includeRegex));
- }
- }
-
- OrFilter<String> excludeFilter = new OrFilter<String>();
- if (excludeRegexes != null) {
- for (String excludeRegex : excludeRegexes) {
- excludeFilter.addFilter(new RegexStringFilter(excludeRegex));
- }
- }
-
- return new AndFilter<String>(includeFilter, new NotFilter<String>(excludeFilter));
- }
-
- /**
- * Construct a String Filter using set of include and exclude regular
- * expressions. If there are no include regular expressions provide, then
- * a regular expression is added which matches every String by default.
- * A String is included as long as the case that there is an include which
- * matches or there is not an exclude which matches.
- * <p>
- * In other words, include patterns override exclude patterns.
- *
- * @param includeRegexes The include regular expressions. May be <code>null</code>.
- * @param excludeRegexes The exclude regular expressions. May be <code>null</code>.
- * @return A String Filter.
- */
- public static Filter<String> buildRegexFilterIncludeOverExclude(List<String> includeRegexes,
- List<String> excludeRegexes) {
- OrFilter<String> includeFilter = new OrFilter<String>();
- if (includeRegexes != null) {
- for (String includeRegex : includeRegexes) {
- includeFilter.addFilter(new RegexStringFilter(includeRegex));
- }
- }
-
- OrFilter<String> excludeFilter = new OrFilter<String>();
- if (excludeRegexes != null) {
- for (String excludeRegex : excludeRegexes) {
- excludeFilter.addFilter(new RegexStringFilter(excludeRegex));
- }
- }
-
- return new OrFilter<String>(includeFilter, new NotFilter<String>(excludeFilter));
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/NotFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/NotFilter.java
deleted file mode 100644
index aeb77ce4bbe..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/NotFilter.java
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-/**
- * A logical NEGATION of a Filter.
- *
- * @param <T>
- * The underlying type on which the filter applies.
- */
-public class NotFilter<T> extends AbstractDelegateFilter<T> {
- public NotFilter() {
- super();
- }
-
- public NotFilter(Filter<T> filter) {
- super(filter);
- }
-
- public boolean filter(T obj) {
- return !filter.filter(obj);
- }
-
- public String toString() {
- return "not (" + filter + ")";
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/OrFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/OrFilter.java
deleted file mode 100644
index 142d4131b26..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/OrFilter.java
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-/**
- * A logical OR of a list of Filters. This implementation is short circuiting.
- *
- * @param <T>
- * The underlying type on which the filter applies.
- */
-public class OrFilter<T> extends AbstractCompoundFilter<T> {
-
- public OrFilter() {
- super();
- }
-
- public OrFilter(Filter<T>... filters) {
- super(filters);
- }
-
- public boolean filter(T obj) {
- boolean match = false;
- for (Filter<T> filter : filters) {
- if (filter.filter(obj)) {
- match = true;
- break;
- }
- }
- return match;
- }
-
- @Override
- protected String getOperator() {
- return "or";
- }
-}
diff --git a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/RegexStringFilter.java b/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/RegexStringFilter.java
deleted file mode 100644
index b23b202d783..00000000000
--- a/sonar-duplications/src/main/java/net/sourceforge/pmd/util/filter/RegexStringFilter.java
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Sonar, open source software quality management tool.
- * Copyright (C) 2008-2011 SonarSource
- * mailto:contact AT sonarsource DOT com
- *
- * Sonar is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * Sonar is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with Sonar; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
- */
-
-package net.sourceforge.pmd.util.filter;
-
-import java.util.regex.Pattern;
-
-/**
- * A filter to which uses a regular expression to match upon Strings.
- */
-public class RegexStringFilter implements Filter<String> {
-
- protected String regex;
-
- protected Pattern pattern;
-
- public RegexStringFilter() {
- }
-
- public RegexStringFilter(String regex) {
- this.regex = regex;
- }
-
- public String getRegex() {
- return regex;
- }
-
- public void setRegex(String regex) {
- this.regex = regex;
- this.pattern = null;
- }
-
- public boolean filter(String obj) {
- if (pattern == null) {
- pattern = Pattern.compile(regex);
- }
- return pattern.matcher(obj).matches();
- }
-
- public String toString() {
- return "matches " + regex;
- }
-}
diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/cpd/CPD.java b/sonar-duplications/src/main/java/org/sonar/duplications/cpd/CPD.java
index 31c3f37061a..9f204b07a3b 100644
--- a/sonar-duplications/src/main/java/org/sonar/duplications/cpd/CPD.java
+++ b/sonar-duplications/src/main/java/org/sonar/duplications/cpd/CPD.java
@@ -113,5 +113,4 @@ public class CPD {
source.put(sourceCode.getFileName(), sourceCode);
}
-
}
diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/cpd/Match.java b/sonar-duplications/src/main/java/org/sonar/duplications/cpd/Match.java
index 2541b814d2c..70292163575 100644
--- a/sonar-duplications/src/main/java/org/sonar/duplications/cpd/Match.java
+++ b/sonar-duplications/src/main/java/org/sonar/duplications/cpd/Match.java
@@ -23,13 +23,13 @@
*/
package org.sonar.duplications.cpd;
+import net.sourceforge.pmd.cpd.TokenEntry;
+
import java.util.Comparator;
import java.util.Iterator;
import java.util.Set;
import java.util.TreeSet;
-import net.sourceforge.pmd.cpd.TokenEntry;
-
public class Match implements Comparable<Match> {
public static final String EOL = System.getProperty("line.separator", "\n");
@@ -196,4 +196,4 @@ public class Match implements Comparable<Match> {
public String getLabel() {
return label;
}
-} \ No newline at end of file
+}
diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/cpd/MatchCollector.java b/sonar-duplications/src/main/java/org/sonar/duplications/cpd/MatchCollector.java
index 219d0b8bd71..0f2e1ddde66 100644
--- a/sonar-duplications/src/main/java/org/sonar/duplications/cpd/MatchCollector.java
+++ b/sonar-duplications/src/main/java/org/sonar/duplications/cpd/MatchCollector.java
@@ -23,17 +23,10 @@
*/
package org.sonar.duplications.cpd;
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.HashSet;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-
import net.sourceforge.pmd.cpd.TokenEntry;
+import java.util.*;
+
public class MatchCollector {
private MatchAlgorithm ma;
@@ -51,7 +44,7 @@ public class MatchCollector {
for (int j = i + 1; j < marks.size(); j++) {
TokenEntry mark2 = marks.get(j);
int diff = mark1.getIndex() - mark2.getIndex();
- if ( -diff < ma.getMinimumTileSize()) {
+ if (-diff < ma.getMinimumTileSize()) {
continue;
}
if (hasPreviousDupe(mark1, mark2)) {
@@ -118,7 +111,7 @@ public class MatchCollector {
TokenEntry cmark2 = a1.get(inner);
matchCode.setFirst(cmark1.getIndex());
matchCode.setSecond(cmark2.getIndex());
- if ( !matchSet.contains(matchCode)) {
+ if (!matchSet.contains(matchCode)) {
if (pruned.size() > 2) {
pruned.remove(cmark2);
}
@@ -149,7 +142,7 @@ public class MatchCollector {
if (other.getFirstMark().getIndex() + other.getTokenCount() - mark1.getIndex() > 0) {
boolean ordered = other.getSecondMark().getIndex() - mark2.getIndex() < 0;
if ((ordered && (other.getEndIndex() - mark2.getIndex() > 0))
- || ( !ordered && (match.getEndIndex() - other.getSecondMark().getIndex()) > 0)) {
+ || (!ordered && (match.getEndIndex() - other.getSecondMark().getIndex()) > 0)) {
if (other.getTokenCount() >= match.getTokenCount()) {
add = false;
break;
@@ -170,12 +163,12 @@ public class MatchCollector {
if (mark1.getIndex() == 0) {
return false;
}
- return !matchEnded(ma.tokenAt( -1, mark1), ma.tokenAt( -1, mark2));
+ return !matchEnded(ma.tokenAt(-1, mark1), ma.tokenAt(-1, mark2));
}
private int countDuplicateTokens(TokenEntry mark1, TokenEntry mark2) {
int index = 0;
- while ( !matchEnded(ma.tokenAt(index, mark1), ma.tokenAt(index, mark2))) {
+ while (!matchEnded(ma.tokenAt(index, mark1), ma.tokenAt(index, mark2))) {
index++;
}
return index;
@@ -184,4 +177,4 @@ public class MatchCollector {
private boolean matchEnded(TokenEntry token1, TokenEntry token2) {
return token1.getIdentifier() != token2.getIdentifier() || token1 == TokenEntry.EOF || token2 == TokenEntry.EOF;
}
-} \ No newline at end of file
+}
diff --git a/sonar-duplications/src/test/java/net/sourceforge/pmd/cpd/AbstractLanguageTest.java b/sonar-duplications/src/test/java/net/sourceforge/pmd/cpd/AbstractLanguageTest.java
new file mode 100644
index 00000000000..9a7b267033f
--- /dev/null
+++ b/sonar-duplications/src/test/java/net/sourceforge/pmd/cpd/AbstractLanguageTest.java
@@ -0,0 +1,62 @@
+/*
+ * Sonar, open source software quality management tool.
+ * Copyright (C) 2008-2011 SonarSource
+ * mailto:contact AT sonarsource DOT com
+ *
+ * Sonar is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or (at your option) any later version.
+ *
+ * Sonar is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with Sonar; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
+ */
+package net.sourceforge.pmd.cpd;
+
+import static org.hamcrest.Matchers.is;
+import static org.junit.Assert.*;
+import java.io.File;
+import java.io.FilenameFilter;
+import java.io.IOException;
+
+import org.junit.Test;
+
+/**
+ * We use modified version of {@link AbstractLanguage} in comparison with PMD - it doesn't use package "net.sourceforge.pmd.util.filter",
+ * so goal of this test is to verify that behavior wasn't changed:
+ * filter should always accept directories and files with a specified set of extensions (comparison is case insensitive).
+ */
+public class AbstractLanguageTest {
+
+ @Test
+ public void shouldCreateCorrectFilenameFilterForExtensions() throws IOException {
+ AbstractLanguage language = new AbstractLanguage(null, "java") {
+ };
+
+ FilenameFilter filter = language.getFileFilter();
+ assertThat(filter.accept(new File("test-resources"), "org"), is(true));
+ assertThat(filter.accept(new File("test-resources/org/sonar/duplications/cpd/CPDTest"), "CPDFile1.java"), is(true));
+ assertThat(filter.accept(new File("test-resources/org/sonar/duplications/cpd/CPDTest"), "CPDFile1.cpp"), is(false));
+
+ language = new AbstractLanguage(null, "Java") {
+ };
+ assertThat(filter.accept(new File("test-resources/org/sonar/duplications/cpd/CPDTest"), "CPDFile1.java"), is(true));
+
+ language = new AbstractLanguage(null, new String[] {}) {
+ };
+ assertThat(filter.accept(new File("test-resources/org/sonar/duplications/cpd/CPDTest"), "CPDFile1.java"), is(true));
+ }
+
+ @Test(expected = NullPointerException.class)
+ public void shouldThrowException() {
+ new AbstractLanguage(null, null) {
+ };
+ }
+
+}