Package org.jcsp.util.filter
Class FilteredChannelInputWrapper
java.lang.Object
org.jcsp.lang.ChannelInputWrapper
org.jcsp.util.filter.FilteredChannelInputWrapper
- All Implemented Interfaces:
ChannelInput,Poisonable,FilteredChannelInput,ReadFiltered
- Direct Known Subclasses:
FilteredSharedChannelInputWrapper
Wrapper for an input channel end to include read filtering functionality.
-
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionConstructs a newFilteredChannelInputWrapperaround the existing channel end. -
Method Summary
Modifier and TypeMethodDescriptionvoidaddReadFilter(Filter filter) Installs a read filter defining a transformation to be applied by thereadmethod of the channel end.voidaddReadFilter(Filter filter, int index) Installs a read filter defining a transformation to be applied by thereadmethod of the channel end at a specific index.getReadFilter(int index) Returns the read filter installed at the given index.intReturns the number of read filters currently installed.read()Reads a value from the channel.voidremoveReadFilter(int index) Removes the read filter installed at the given index.voidremoveReadFilter(Filter filter) Removes the first read filter (lowest index) matching the filter given as a parameter.Methods inherited from class org.jcsp.lang.ChannelInputWrapper
endRead, poison, startReadMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.jcsp.lang.ChannelInput
endRead, startReadMethods inherited from interface org.jcsp.lang.Poisonable
poison
-
Field Details
-
filters
Set of read filters installed.
-
-
Constructor Details
-
FilteredChannelInputWrapper
FilteredChannelInputWrapper(ChannelInput in) Constructs a newFilteredChannelInputWrapperaround the existing channel end.- Parameters:
in- channel end to create the wrapper around.
-
-
Method Details
-
read
Description copied from class:ChannelInputWrapperReads a value from the channel.- Specified by:
readin interfaceChannelInput- Overrides:
readin classChannelInputWrapper- Returns:
- the value read.
- See Also:
-
addReadFilter
Description copied from interface:ReadFilteredInstalls a read filter defining a transformation to be applied by thereadmethod of the channel end. The filter will be appended to the end of the current list, making it the last to be applied.- Specified by:
addReadFilterin interfaceReadFiltered- Parameters:
filter- the filter to be installed; may not be null.
-
addReadFilter
Description copied from interface:ReadFilteredInstalls a read filter defining a transformation to be applied by thereadmethod of the channel end at a specific index. If there is already a filter at that index position the existing filters are shifted to make room. If the index is greater than the number of filters already installed the filter is placed at the end.- Specified by:
addReadFilterin interfaceReadFiltered- Parameters:
filter- the filter to be installed; may not be null.index- the zero based index; may not be negative.
-
removeReadFilter
Description copied from interface:ReadFilteredRemoves the first read filter (lowest index) matching the filter given as a parameter. The filter removed,r, will satisfy the conditionr.equals (filter). The remaining filters are shifted to close the gap in the index allocation.- Specified by:
removeReadFilterin interfaceReadFiltered- Parameters:
filter- the filter to be removed; may not be null.
-
removeReadFilter
public void removeReadFilter(int index) Description copied from interface:ReadFilteredRemoves the read filter installed at the given index. The remaining filters are shifted to close the gap in the index allocation.- Specified by:
removeReadFilterin interfaceReadFiltered- Parameters:
index- zero-based index of the filter to be removed.
-
getReadFilter
Description copied from interface:ReadFilteredReturns the read filter installed at the given index.- Specified by:
getReadFilterin interfaceReadFiltered- Parameters:
index- zero-based index of the filter to return.- Returns:
- the filter at that position.
-
getReadFilterCount
public int getReadFilterCount()Description copied from interface:ReadFilteredReturns the number of read filters currently installed.- Specified by:
getReadFilterCountin interfaceReadFiltered
-