Class AbstractScanner
- All Implemented Interfaces:
Scanner
- Direct Known Subclasses:
DirectoryScanner
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final String[]Patterns which should be excluded by default, like SCM files Misc: **/*~, **/#*#, **/.#*, **/%*%, **/._* CVS: **/CVS, **/CVS/**, **/.cvsignore RCS: **/RCS, **/RCS/** SCCS: **/SCCS, **/SCCS/** VSSercer: **/vssver.scc MKS: **/project.pj SVN: **/.svn, **/.svn/** GNU: **/.arch-ids, **/.arch-ids/** Bazaar: **/.bzr, **/.bzr/** SurroundSCM: **/.MySCMServerInfo Mac: **/.DS_Store Serena Dimension: **/.metadata, **/.metadata/** Mercurial: **/.hg, **/.hg/** Git: **/.git, **/.git/**, **/.gitignore Bitkeeper: **/BitKeeper, **/BitKeeper/**, **/ChangeSet, **/ChangeSet/** Darcs: **/_darcs, **/_darcs/**, **/.darcsrepo, **/.darcsrepo/****/-darcs-backup*, **/.darcs-temp-mailprotected String[]The patterns for the files to be excluded.protected Comparator<String> protected String[]The patterns for the files to be included.protected booleanWhether or not the file system should be treated as a case sensitive one. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidAdds default exclusions to the current exclusions set.protected booleancouldHoldIncluded(String name) Tests whether or not a name matches the start of at least one include pattern.protected booleanisExcluded(String name) Tests whether or not a name matches against at least one exclude pattern.protected booleanisExcluded(String name, char[][] tokenizedName) protected booleanisExcluded(String name, String[] tokenizedName) protected booleanisIncluded(String name) Tests whether or not a name matches against at least one include pattern.protected booleanisIncluded(String name, char[][] tokenizedName) protected booleanisIncluded(String name, String[] tokenizedName) static booleanTests whether or not a string matches against a pattern.protected static booleanTests whether or not a string matches against a pattern.protected static booleanTests whether or not a given path matches a given pattern.protected static booleanTests whether or not a given path matches a given pattern.protected static booleanmatchPatternStart(String pattern, String str) Tests whether or not a given path matches the start of a given pattern up to the first "**".protected static booleanmatchPatternStart(String pattern, String str, boolean isCaseSensitive) Tests whether or not a given path matches the start of a given pattern up to the first "**".voidsetCaseSensitive(boolean isCaseSensitive) Sets whether or not the file system should be regarded as case sensitive.voidsetExcludes(String[] excludes) Sets the list of exclude patterns to use.voidsetFilenameComparator(Comparator<String> filenameComparator) Use a filename comparator in each directory when scanning.voidsetIncludes(String[] includes) Sets the list of include patterns to use.protected voidprotected voidMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.codehaus.plexus.util.Scanner
getBasedir, getIncludedDirectories, getIncludedFiles, scan
-
Field Details
-
DEFAULTEXCLUDES
Patterns which should be excluded by default, like SCM files- Misc: **/*~, **/#*#, **/.#*, **/%*%, **/._*
- CVS: **/CVS, **/CVS/**, **/.cvsignore
- RCS: **/RCS, **/RCS/**
- SCCS: **/SCCS, **/SCCS/**
- VSSercer: **/vssver.scc
- MKS: **/project.pj
- SVN: **/.svn, **/.svn/**
- GNU: **/.arch-ids, **/.arch-ids/**
- Bazaar: **/.bzr, **/.bzr/**
- SurroundSCM: **/.MySCMServerInfo
- Mac: **/.DS_Store
- Serena Dimension: **/.metadata, **/.metadata/**
- Mercurial: **/.hg, **/.hg/**
- Git: **/.git, **/.git/**, **/.gitignore
- Bitkeeper: **/BitKeeper, **/BitKeeper/**, **/ChangeSet, **/ChangeSet/**
- Darcs: **/_darcs, **/_darcs/**, **/.darcsrepo, **/.darcsrepo/****/-darcs-backup*, **/.darcs-temp-mail
- See Also:
-
includes
The patterns for the files to be included. -
excludes
The patterns for the files to be excluded. -
isCaseSensitive
protected boolean isCaseSensitiveWhether or not the file system should be treated as a case sensitive one. -
filenameComparator
- Since:
- 3.3.0
-
-
Constructor Details
-
AbstractScanner
public AbstractScanner()
-
-
Method Details
-
setCaseSensitive
public void setCaseSensitive(boolean isCaseSensitive) Sets whether or not the file system should be regarded as case sensitive.- Parameters:
isCaseSensitive- whether or not the file system should be regarded as a case sensitive one
-
matchPatternStart
Tests whether or not a given path matches the start of a given pattern up to the first "**".
This is not a general purpose test and should only be used if you can live with false positives. For example,
pattern=**\aandstr=bwill yieldtrue.- Parameters:
pattern- The pattern to match against. Must not benull.str- The path to match, as a String. Must not benull.- Returns:
- whether or not a given path matches the start of a given pattern up to the first "**".
-
matchPatternStart
Tests whether or not a given path matches the start of a given pattern up to the first "**".
This is not a general purpose test and should only be used if you can live with false positives. For example,
pattern=**\aandstr=bwill yieldtrue.- Parameters:
pattern- The pattern to match against. Must not benull.str- The path to match, as a String. Must not benull.isCaseSensitive- Whether or not matching should be performed case sensitively.- Returns:
- whether or not a given path matches the start of a given pattern up to the first "**".
-
matchPath
Tests whether or not a given path matches a given pattern.- Parameters:
pattern- The pattern to match against. Must not benull.str- The path to match, as a String. Must not benull.- Returns:
trueif the pattern matches against the string, orfalseotherwise.
-
matchPath
Tests whether or not a given path matches a given pattern.- Parameters:
pattern- The pattern to match against. Must not benull.str- The path to match, as a String. Must not benull.isCaseSensitive- Whether or not matching should be performed case sensitively.- Returns:
trueif the pattern matches against the string, orfalseotherwise.
-
match
Tests whether or not a string matches against a pattern. The pattern may contain two special characters:
'*' means zero or more characters
'?' means one and only one character- Parameters:
pattern- The pattern to match against. Must not benull.str- The string which must be matched against the pattern. Must not benull.- Returns:
trueif the string matches against the pattern, orfalseotherwise.
-
match
Tests whether or not a string matches against a pattern. The pattern may contain two special characters:
'*' means zero or more characters
'?' means one and only one character- Parameters:
pattern- The pattern to match against. Must not benull.str- The string which must be matched against the pattern. Must not benull.isCaseSensitive- Whether or not matching should be performed case sensitively.- Returns:
trueif the string matches against the pattern, orfalseotherwise.
-
setIncludes
Sets the list of include patterns to use. All '/' and '\' characters are replaced by
File.separatorChar, so the separator used need not matchFile.separatorChar.When a pattern ends with a '/' or '\', "**" is appended.
- Specified by:
setIncludesin interfaceScanner- Parameters:
includes- A list of include patterns. May benull, indicating that all files should be included. If a non-nulllist is given, all elements must be non-null.
-
setExcludes
Sets the list of exclude patterns to use. All '/' and '\' characters are replaced by
File.separatorChar, so the separator used need not matchFile.separatorChar.When a pattern ends with a '/' or '\', "**" is appended.
- Specified by:
setExcludesin interfaceScanner- Parameters:
excludes- A list of exclude patterns. May benull, indicating that no files should be excluded. If a non-nulllist is given, all elements must be non-null.
-
isIncluded
Tests whether or not a name matches against at least one include pattern.- Parameters:
name- The name to match. Must not benull.- Returns:
truewhen the name matches against at least one include pattern, orfalseotherwise.
-
isIncluded
-
isIncluded
-
couldHoldIncluded
Tests whether or not a name matches the start of at least one include pattern.- Parameters:
name- The name to match. Must not benull.- Returns:
truewhen the name matches against the start of at least one include pattern, orfalseotherwise.
-
isExcluded
Tests whether or not a name matches against at least one exclude pattern.- Parameters:
name- The name to match. Must not benull.- Returns:
truewhen the name matches against at least one exclude pattern, orfalseotherwise.
-
isExcluded
-
isExcluded
-
addDefaultExcludes
public void addDefaultExcludes()Adds default exclusions to the current exclusions set.- Specified by:
addDefaultExcludesin interfaceScanner
-
setupDefaultFilters
protected void setupDefaultFilters() -
setupMatchPatterns
protected void setupMatchPatterns() -
setFilenameComparator
Description copied from interface:ScannerUse a filename comparator in each directory when scanning.- Specified by:
setFilenameComparatorin interfaceScanner- Parameters:
filenameComparator- the Comparator instance to use
-