A SeekableFilter is a Filter whose mode_of refines seekable. 
A SeekableFilter operates on the character sequence controlled by a SeekableDevice, providing access to a filtered sequence having the same character type. It may expose the filtered sequence in two ways:
get, put and seek.
        read, write and seek.
        | Character type | The type of the characters in the filtered sequences | 
| Category | A type convertible to filter_tagand toseekable | 
| Mode | The unique most-derived mode tag to which Category is convertible | 
| F | - A type which is a model of SeekableFilter | 
| D | - A type which is a model of Device, with the same character type as Fand with mode convertible to the mode ofF | 
| Ch | - The character type of F | 
| Tr | - boost::iostreams::char_traits<Ch> | 
| f | - Object of type F | 
| d | - Object of type D | 
| c | - Object of type Ch | 
| s1 | - Object of type Ch* | 
| s2 | - Object of type const Ch* | 
| n | - Object of type std::streamsize | 
| off | - Object of type stream_offset | 
| way | - Object of type std::ios_base::seekdir | 
| which | - Object of type std::ios_base::openmode | 
| io | - Alias for namespace boost::iostreams | 
| Expression | Expression Type | Category Precondition | Semantics | 
|---|---|---|---|
|  | typenameof the character type | - | - | 
|  | typenameof the category | - | - | 
|  | Tr::int_type | Not convertible to multi_char_tag | Returns the next character in the sequence controlled by f, orTr::eof()if the end of the sequence has been reached. The sequence controlled bydmay be accessed usingio::readandio::putback. | 
|  | bool | Writes the character cto the sequence controlled byf. The sequence controlled bydmay be accessed usingio::write. | |
|  |  | Convertible to multi_char_tag | Reads up to characters from the sequence controlled byfinto the buffers1, returning the number of characters read. Returning a value less thannindicates end-of-sequence. The sequence controlled bydmay be accessed usingio::readandio::putback. | 
|  |  | Writes n characters from the buffer s2to the sequence controlled byf. The sequence controlled bydmay be accessed usingio::write. | |
|  | std::streampos | - | 
                Advances the read/write head by  
 
                The sequence controlled by  | 
    Errors which occur during the execution of get, put, read, write or seek are indicated by throwing exceptions. Reaching the end of the sequence is not an error, but attempting to write past the end of the sequence is.
After an exception is thrown, a SeekableFilter must be in a consistent state; further i/o operations may throw exceptions but must have well-defined behaviour. Furthermore, unless it is Closable, it must be ready to begin processing a new character sequence.
Revised 20 May, 2004
© Copyright Jonathan Turkanis, 2004
Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)