Package org.apache.http.message
Class BasicListHeaderIterator
java.lang.Object
org.apache.http.message.BasicListHeaderIterator
- All Implemented Interfaces:
Iterator<Object>,HeaderIterator
- Since:
- 4.0
-
Field Summary
FieldsModifier and TypeFieldDescriptionA list of headers to iterate over.protected intThe position of the next header inallHeaders.protected StringThe header name to filter by.protected intThe position of the last returned header. -
Constructor Summary
ConstructorsConstructorDescriptionBasicListHeaderIterator(List<Header> headers, String name) Creates a new header iterator. -
Method Summary
Modifier and TypeMethodDescriptionprotected booleanfilterHeader(int index) Checks whether a header is part of the iteration.protected intfindNext(int pos) Determines the index of the next header.booleanhasNext()Indicates whether there is another header in this iteration.final Objectnext()Returns the next header.Obtains the next header from this iteration.voidremove()Removes the header that was returned last.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.util.Iterator
forEachRemaining
-
Field Details
-
allHeaders
A list of headers to iterate over. Not all elements of this array are necessarily part of the iteration. -
currentIndex
protected int currentIndexThe position of the next header inallHeaders. Negative if the iteration is over. -
lastIndex
protected int lastIndexThe position of the last returned header. Negative if none has been returned so far. -
headerName
The header name to filter by.nullto iterate over all headers in the array.
-
-
Constructor Details
-
BasicListHeaderIterator
Creates a new header iterator.- Parameters:
headers- a list of headers over which to iteratename- the name of the headers over which to iterate, ornullfor any
-
-
Method Details
-
findNext
protected int findNext(int pos) Determines the index of the next header.- Parameters:
pos- one less than the index to consider first, -1 to search for the first header- Returns:
- the index of the next header that matches the filter name, or negative if there are no more headers
-
filterHeader
protected boolean filterHeader(int index) Checks whether a header is part of the iteration.- Parameters:
index- the index of the header to check- Returns:
trueif the header should be part of the iteration,falseto skip
-
hasNext
public boolean hasNext()Description copied from interface:HeaderIteratorIndicates whether there is another header in this iteration.- Specified by:
hasNextin interfaceHeaderIterator- Specified by:
hasNextin interfaceIterator<Object>- Returns:
trueif there is another header,falseotherwise
-
nextHeader
Obtains the next header from this iteration.- Specified by:
nextHeaderin interfaceHeaderIterator- Returns:
- the next header in this iteration
- Throws:
NoSuchElementException- if there are no more headers
-
next
Returns the next header. Same asnextHeader, but not type-safe.- Specified by:
nextin interfaceIterator<Object>- Returns:
- the next header in this iteration
- Throws:
NoSuchElementException- if there are no more headers
-
remove
Removes the header that was returned last.- Specified by:
removein interfaceIterator<Object>- Throws:
UnsupportedOperationException
-