Package org.apache.tools.ant.filters
Class LineContains
java.lang.Object
java.io.Reader
java.io.FilterReader
org.apache.tools.ant.filters.BaseFilterReader
org.apache.tools.ant.filters.BaseParamFilterReader
org.apache.tools.ant.filters.LineContains
- All Implemented Interfaces:
Closeable
,AutoCloseable
,Readable
,ChainableReader
,Parameterizable
Filter which includes only those lines that contain the user-specified
strings.
Example:
<linecontains> <contains value="foo"> <contains value="bar"> </linecontains>Or:
<filterreader classname="org.apache.tools.ant.filters.LineContains"> <param type="contains" value="foo"/> <param type="contains" value="bar"/> </filterreader>This will include only those lines that contain
foo
and
bar
.
Starting Ant 1.10.4, the matchAny
attribute can be used to control whether any one
of the user-specified strings is expected to be contained in the line or all
of them are expected to be contained.
For example:
<linecontains matchAny="true"> * <contains value="foo"> * <contains value="bar"> * </linecontains>This will include only those lines that contain either
foo
or bar
.-
Nested Class Summary
-
Field Summary
Fields inherited from class java.io.FilterReader
in
-
Constructor Summary
ConstructorDescriptionConstructor for "dummy" instances.LineContains
(Reader in) Creates a new filtered reader. -
Method Summary
Modifier and TypeMethodDescriptionvoid
addConfiguredContains
(LineContains.Contains contains) Adds acontains
element.Creates a new LineContains using the passed in Reader for instantiation.boolean
boolean
Find out whether we have been negated.int
read()
Returns the next character in the filtered stream, only including lines from the original stream which contain all of the specified words.void
setMatchAny
(boolean matchAny) void
setNegate
(boolean b) Set the negation mode.Methods inherited from class org.apache.tools.ant.filters.BaseParamFilterReader
getParameters, setParameters
Methods inherited from class org.apache.tools.ant.filters.BaseFilterReader
getInitialized, getProject, read, readFully, readLine, setInitialized, setProject, skip
Methods inherited from class java.io.FilterReader
close, mark, markSupported, ready, reset
Methods inherited from class java.io.Reader
nullReader, read, read, transferTo
-
Constructor Details
-
LineContains
public LineContains()Constructor for "dummy" instances.- See Also:
-
LineContains
Creates a new filtered reader.- Parameters:
in
- A Reader object providing the underlying stream. Must not benull
.
-
-
Method Details
-
read
Returns the next character in the filtered stream, only including lines from the original stream which contain all of the specified words.- Overrides:
read
in classFilterReader
- Returns:
- the next character in the resulting stream, or -1 if the end of the resulting stream has been reached
- Throws:
IOException
- if the underlying stream throws an IOException during reading
-
addConfiguredContains
Adds acontains
element.- Parameters:
contains
- Thecontains
element to add. Must not benull
.
-
setNegate
public void setNegate(boolean b) Set the negation mode. Default false (no negation).- Parameters:
b
- the boolean negation mode to set.
-
isNegated
public boolean isNegated()Find out whether we have been negated.- Returns:
- boolean negation flag.
-
setMatchAny
public void setMatchAny(boolean matchAny) - Parameters:
matchAny
- True if thisLineContains
is considered a match, ifany
of thecontains
value match. False ifall
of thecontains
value are expected to match- Since:
- Ant 1.10.4
-
isMatchAny
public boolean isMatchAny()- Returns:
- Returns true if this
LineContains
is considered a match, ifany
of thecontains
value match. False ifall
of thecontains
value are expected to match - Since:
- Ant 1.10.4
-
chain
Creates a new LineContains using the passed in Reader for instantiation.- Specified by:
chain
in interfaceChainableReader
- Parameters:
rdr
- A Reader object providing the underlying stream. Must not benull
.- Returns:
- a new filter based on this configuration, but filtering the specified reader
-