A SymmetricFilter processes a character sequence fed to it incrementally in a user-supplied buffer and outputs a filtered sequence incrementally to a second user-supplied buffer. It is useful for defining filters based on C language APIs.
    SymmetricFilter does not refine Filter. Instead, the template symmetric_filter can used to generate a Filter from a SymmetricFilter. The Filters generated in this manner are DualUseFilters and are CopyConstructible regardless of whether the SymmetricFilters on which they are based are  CopyConstructible.
The concept SymmetricFilter is notable in that its definition does not involve the concept of a Source or Sink.
| Character type | The type of the characters in the filtered sequences | 
| F | - A type which is a model of SymmetricFilter | 
| Ch | - The character type of F | 
| f | - Object of type F | 
| i1, i2 | - Objects of type const Ch* | 
| o1, o2 | - Objects of type Ch* | 
| flush | - Object of type bool | 
| Expression | Expression Type | 
|---|---|
|  | typenameof the character type | 
| Expression | Expression Type | Semantics | Postcondition | 
|---|---|---|---|
|  | bool | Attempts to filter the sequence [i1, i2), storing the result in the sequence[o1, o2). Ifflushis true, writes as much output to[o1, o2)as possible. Ifflushisfalse, returnsfalseto indicate that a “natural” end of stream has been detected. Otherwise, returnstrueto indicate that additional characters, not yet stored in[o1, o2), are available for output. | 
 
 Either  | 
|  | void | - | fis ready to begin filtering a new sequence | 
    Errors which occur during the execution of filter or close are indicated by throwing exceptions.
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)