3 <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
4 <title>Keyword List Operator</title>
5 <link rel="stylesheet" href="../../../../../../../../doc/src/boostbook.css" type="text/css">
6 <meta name="generator" content="DocBook XSL Stylesheets V1.78.1">
7 <link rel="home" href="../../../index.html" title="Spirit Repository 0.2">
8 <link rel="up" href="../operators.html" title="Qi Parser Operators">
9 <link rel="prev" href="../operators.html" title="Qi Parser Operators">
10 <link rel="next" href="../../karma_components.html" title="Karma Components">
12 <body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
13 <table cellpadding="2" width="100%"><tr>
14 <td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../../../../../boost.png"></td>
15 <td align="center"><a href="../../../../../../../../index.html">Home</a></td>
16 <td align="center"><a href="../../../../../../../../libs/libraries.htm">Libraries</a></td>
17 <td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
18 <td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
19 <td align="center"><a href="../../../../../../../../more/index.htm">More</a></td>
22 <div class="spirit-nav">
23 <a accesskey="p" href="../operators.html"><img src="../../../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../operators.html"><img src="../../../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../../index.html"><img src="../../../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="../../karma_components.html"><img src="../../../../../../../../doc/src/images/next.png" alt="Next"></a>
26 <div class="titlepage"><div><div><h4 class="title">
27 <a name="spirit_repository.qi_components.operators.keyword_list"></a><a class="link" href="keyword_list.html" title="Keyword List Operator">Keyword
29 </h4></div></div></div>
31 <a name="spirit_repository.qi_components.operators.keyword_list.h0"></a>
32 <span class="phrase"><a name="spirit_repository.qi_components.operators.keyword_list.description"></a></span><a class="link" href="keyword_list.html#spirit_repository.qi_components.operators.keyword_list.description">Description</a>
35 The keyword list operator, <code class="computeroutput"><span class="identifier">kwd</span><span class="special">(</span><span class="string">"k1"</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span>
36 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"k2"</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]</span></code>,
37 works tightly with the kwd, ikwd, dkwd and idkwd directives to effeciently
38 match keyword lists. As long as one of the keywords specified through the
39 kwd, ikwd, dkwd or idkwd directive matches, the keyword will be immediatly
40 followed by the keyword's associated subject parser. The parser will continue
41 parsing input as long as the one of the keywords and it's associated parser
42 succeed. Writing : (kwd("k1")[a] / kwd("k2")[b] / ...
43 ) is equivalent to: *( "k1" > a | "k2" > b ...
47 <a name="spirit_repository.qi_components.operators.keyword_list.h1"></a>
48 <span class="phrase"><a name="spirit_repository.qi_components.operators.keyword_list.header"></a></span><a class="link" href="keyword_list.html#spirit_repository.qi_components.operators.keyword_list.header">Header</a>
50 <pre class="programlisting"><span class="comment">// forwards to <boost/spirit/repository/home/qi/operator/keywords.hpp></span>
51 <span class="preprocessor">#include</span> <span class="special"><</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">spirit</span><span class="special">/</span><span class="identifier">repository</span><span class="special">/</span><span class="identifier">include</span><span class="special">/</span><span class="identifier">qi_keywords</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">></span>
54 <a name="spirit_repository.qi_components.operators.keyword_list.h2"></a>
55 <span class="phrase"><a name="spirit_repository.qi_components.operators.keyword_list.expression_semantics"></a></span><a class="link" href="keyword_list.html#spirit_repository.qi_components.operators.keyword_list.expression_semantics">Expression
58 <div class="informaltable"><table class="table">
78 <code class="computeroutput"><span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span>
79 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]</span></code>
84 Match <code class="computeroutput"><span class="identifier">lit</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)</span>
85 <span class="special">></span> <span class="identifier">a</span></code>
86 or <code class="computeroutput"><span class="identifier">lit</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)</span>
87 <span class="special">></span> <span class="identifier">b</span></code>,
88 equivalent to <code class="computeroutput"><span class="identifier">lit</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)</span> <span class="special">></span>
89 <span class="identifier">a</span> <span class="special">|</span>
90 <span class="identifier">lit</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)</span>
91 <span class="special">></span> <span class="identifier">b</span></code>
97 <a name="spirit_repository.qi_components.operators.keyword_list.h3"></a>
98 <span class="phrase"><a name="spirit_repository.qi_components.operators.keyword_list.attributes"></a></span><a class="link" href="keyword_list.html#spirit_repository.qi_components.operators.keyword_list.attributes">Attributes</a>
100 <div class="informaltable"><table class="table">
120 <code class="computeroutput"><span class="identifier">kwd</span><span class="special">(</span><span class="string">"k1"</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span>
121 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"k2"</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]</span></code>
127 <pre xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" class="table-programlisting"><span class="identifier">a</span><span class="special">:</span> <span class="identifier">A</span><span class="special">,</span> <span class="identifier">b</span><span class="special">:</span> <span class="identifier">B</span> <span class="special">--></span> <span class="special">(</span><span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span> <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]):</span> <span class="identifier">tuple</span><span class="special"><</span><span class="identifier">A</span><span class="special">,</span> <span class="identifier">B</span><span class="special">></span>
128 <span class="identifier">a</span><span class="special">:</span> <span class="identifier">A</span><span class="special">,</span> <span class="identifier">b</span><span class="special">:</span> <span class="identifier">Unused</span> <span class="special">--></span> <span class="special">(</span><span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span> <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]):</span> <span class="identifier">optional</span><span class="special"><</span><span class="identifier">A</span><span class="special">></span>
129 <span class="identifier">a</span><span class="special">:</span> <span class="identifier">Unused</span><span class="special">,</span> <span class="identifier">b</span><span class="special">:</span> <span class="identifier">B</span> <span class="special">--></span> <span class="special">(</span><span class="identifier">kwd</span><span class="special">(</span><span class="string">"k1"</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span> <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]):</span> <span class="identifier">optional</span><span class="special"><</span><span class="identifier">B</span><span class="special">></span>
130 <span class="identifier">a</span><span class="special">:</span> <span class="identifier">Unused</span><span class="special">,</span> <span class="identifier">b</span><span class="special">:</span> <span class="identifier">Unused</span> <span class="special">--></span> <span class="special">(</span><span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span> <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]):</span> <span class="identifier">Unused</span>
132 <span class="identifier">a</span><span class="special">:</span> <span class="identifier">A</span><span class="special">,</span> <span class="identifier">b</span><span class="special">:</span> <span class="identifier">A</span> <span class="special">-->(</span><span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k1</span><span class="special">)[</span><span class="identifier">a</span><span class="special">]</span> <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="identifier">k2</span><span class="special">)[</span><span class="identifier">b</span><span class="special">]):</span> <span class="identifier">tuple</span><span class="special"><</span><span class="identifier">A</span><span class="special">,</span> <span class="identifier">A</span><span class="special">></span></pre>
138 <div class="note"><table border="0" summary="Note">
140 <td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../images/note.png"></td>
141 <th align="left">Note</th>
143 <tr><td align="left" valign="top"><p>
144 The keyword list parser works tightly with the kwd, ikwd, dkwd and idkwd
145 directives and can't be used without it. A compile time error will warn
146 you of any mistakes. This parser collects all the kwd directives and
147 extracts the keyword literals or parsers from the directives to internaly
148 build a Ternary Search Tree (TST) and permutation loop (for complex parsers)
149 to effectively parse the keywords. Because you can't mix character types
150 inside a TST you must take care not to mix wide strings with normal strings
151 in the keywords you supply to a keyword list. Should it happen the compiler
152 will trap the mistake for you.
155 <div class="note"><table border="0" summary="Note">
157 <td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../images/note.png"></td>
158 <th align="left">Note</th>
160 <tr><td align="left" valign="top"><p>
161 The kwd directive also works a bit like the repeat directive and can
162 be used to formulate additional contraints on the number of times a keyword
163 can or must occur while parsing a keyword list.
166 <div class="note"><table border="0" summary="Note">
168 <td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../images/note.png"></td>
169 <th align="left">Note</th>
171 <tr><td align="left" valign="top"><p>
172 The kwd, dkwd and ikwd, idkwd directives can be mixed inside a keyword
173 list. This has however a small overhead and should be avoided when possible.
177 <a name="spirit_repository.qi_components.operators.keyword_list.h4"></a>
178 <span class="phrase"><a name="spirit_repository.qi_components.operators.keyword_list.complexity"></a></span><a class="link" href="keyword_list.html#spirit_repository.qi_components.operators.keyword_list.complexity">Complexity</a>
180 <div class="blockquote"><blockquote class="blockquote"><p>
181 The overall complexity of the keyword list parser is defined by the sum
182 of the complexities of its elements.
183 </p></blockquote></div>
185 <a name="spirit_repository.qi_components.operators.keyword_list.h5"></a>
186 <span class="phrase"><a name="spirit_repository.qi_components.operators.keyword_list.example"></a></span><a class="link" href="keyword_list.html#spirit_repository.qi_components.operators.keyword_list.example">Example</a>
188 <div class="note"><table border="0" summary="Note">
190 <td rowspan="2" align="center" valign="top" width="25"><img alt="[Note]" src="../../../images/note.png"></td>
191 <th align="left">Note</th>
193 <tr><td align="left" valign="top"><p>
194 The test harness for the example(s) below is presented in the <a href="../../../../../../doc/html/spirit/qi/reference/basics.html#spirit.qi.reference.basics.examples" target="_top">Basics
195 Examples</a> section.
199 Declare a small data structure representing a person:
203 <pre class="programlisting"><span class="comment">// Data structure definitions to test the kwd directive</span>
204 <span class="comment">// and the keywords list operator</span>
206 <span class="keyword">struct</span> <span class="identifier">person</span> <span class="special">{</span>
207 <span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span> <span class="identifier">name</span><span class="special">;</span>
208 <span class="keyword">int</span> <span class="identifier">age</span><span class="special">;</span>
209 <span class="keyword">double</span> <span class="identifier">size</span><span class="special">;</span>
210 <span class="identifier">std</span><span class="special">::</span><span class="identifier">vector</span><span class="special"><</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span><span class="special">></span> <span class="identifier">favorite_colors</span><span class="special">;</span>
212 <span class="special">};</span>
214 <span class="identifier">std</span><span class="special">::</span><span class="identifier">ostream</span> <span class="special">&</span><span class="keyword">operator</span><span class="special"><<(</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">ostream</span> <span class="special">&</span><span class="identifier">os</span><span class="special">,</span> <span class="keyword">const</span> <span class="identifier">person</span> <span class="special">&</span><span class="identifier">p</span><span class="special">)</span>
215 <span class="special">{</span>
216 <span class="identifier">os</span><span class="special"><<</span><span class="string">"Person : "</span><span class="special"><<</span><span class="identifier">p</span><span class="special">.</span><span class="identifier">name</span><span class="special"><<</span><span class="string">", "</span><span class="special"><<</span><span class="identifier">p</span><span class="special">.</span><span class="identifier">age</span><span class="special"><<</span><span class="string">", "</span><span class="special"><<</span><span class="identifier">p</span><span class="special">.</span><span class="identifier">size</span><span class="special"><<</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">endl</span><span class="special">;</span>
217 <span class="identifier">std</span><span class="special">::</span><span class="identifier">copy</span><span class="special">(</span><span class="identifier">p</span><span class="special">.</span><span class="identifier">favorite_colors</span><span class="special">.</span><span class="identifier">begin</span><span class="special">(),</span><span class="identifier">p</span><span class="special">.</span><span class="identifier">favorite_colors</span><span class="special">.</span><span class="identifier">end</span><span class="special">(),</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">ostream_iterator</span><span class="special"><</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span><span class="special">>(</span><span class="identifier">os</span><span class="special">,</span><span class="string">"\n"</span><span class="special">));</span>
218 <span class="keyword">return</span> <span class="identifier">os</span><span class="special">;</span>
219 <span class="special">}</span>
221 <span class="identifier">BOOST_FUSION_ADAPT_STRUCT</span><span class="special">(</span> <span class="identifier">person</span><span class="special">,</span>
222 <span class="special">(</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span><span class="special">,</span> <span class="identifier">name</span><span class="special">)</span>
223 <span class="special">(</span><span class="keyword">int</span><span class="special">,</span> <span class="identifier">age</span><span class="special">)</span>
224 <span class="special">(</span><span class="keyword">double</span><span class="special">,</span> <span class="identifier">size</span><span class="special">)</span>
225 <span class="special">(</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">vector</span><span class="special"><</span><span class="identifier">std</span><span class="special">::</span><span class="identifier">string</span><span class="special">>,</span> <span class="identifier">favorite_colors</span><span class="special">)</span>
226 <span class="special">)</span>
231 Some using declarations:
235 <pre class="programlisting"><span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">repository</span><span class="special">::</span><span class="identifier">qi</span><span class="special">::</span><span class="identifier">kwd</span><span class="special">;</span>
236 <span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">qi</span><span class="special">::</span><span class="identifier">inf</span><span class="special">;</span>
237 <span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">ascii</span><span class="special">::</span><span class="identifier">space_type</span><span class="special">;</span>
238 <span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">ascii</span><span class="special">::</span><span class="identifier">char_</span><span class="special">;</span>
239 <span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">qi</span><span class="special">::</span><span class="identifier">double_</span><span class="special">;</span>
240 <span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">qi</span><span class="special">::</span><span class="identifier">int_</span><span class="special">;</span>
241 <span class="keyword">using</span> <span class="identifier">boost</span><span class="special">::</span><span class="identifier">spirit</span><span class="special">::</span><span class="identifier">qi</span><span class="special">::</span><span class="identifier">rule</span><span class="special">;</span>
246 Now let's declare a keyword parser:
250 <pre class="programlisting"><span class="identifier">no_constraint_person_rule</span> <span class="special">%=</span>
251 <span class="identifier">kwd</span><span class="special">(</span><span class="string">"name"</span><span class="special">)[</span><span class="char">'='</span> <span class="special">></span> <span class="identifier">parse_string</span> <span class="special">]</span>
252 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"age"</span><span class="special">)</span> <span class="special">[</span><span class="char">'='</span> <span class="special">></span> <span class="identifier">int_</span><span class="special">]</span>
253 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"size"</span><span class="special">)</span> <span class="special">[</span><span class="char">'='</span> <span class="special">></span> <span class="identifier">double_</span> <span class="special">></span> <span class="char">'m'</span><span class="special">]</span>
254 <span class="special">;</span>
259 A couple of input string variations run on the same parser:
262 Parsing a keyword list:
266 <pre class="programlisting"><span class="comment">// Let's declare a small list of people for which we want to collect information.</span>
267 <span class="identifier">person</span> <span class="identifier">John</span><span class="special">,</span><span class="identifier">Mary</span><span class="special">,</span><span class="identifier">Mike</span><span class="special">,</span><span class="identifier">Hellen</span><span class="special">,</span><span class="identifier">Johny</span><span class="special">;</span>
268 <span class="identifier">test_phrase_parser_attr</span><span class="special">(</span>
269 <span class="string">"name = \"John\" \n age = 10 \n size = 1.69m "</span>
270 <span class="special">,</span><span class="identifier">no_constraint_person_rule</span>
271 <span class="special">,</span><span class="identifier">John</span><span class="special">);</span> <span class="comment">// full in orginal order</span>
272 <span class="identifier">std</span><span class="special">::</span><span class="identifier">cout</span><span class="special"><<</span><span class="identifier">John</span><span class="special">;</span>
274 <span class="identifier">test_phrase_parser_attr</span><span class="special">(</span>
275 <span class="string">"age = 10 \n size = 1.69m \n name = \"Mary\""</span>
276 <span class="special">,</span><span class="identifier">no_constraint_person_rule</span>
277 <span class="special">,</span><span class="identifier">Mary</span><span class="special">);</span> <span class="comment">// keyword oder doesn't matter</span>
278 <span class="identifier">std</span><span class="special">::</span><span class="identifier">cout</span><span class="special"><<</span><span class="identifier">Mary</span><span class="special">;</span>
280 <span class="identifier">test_phrase_parser_attr</span><span class="special">(</span>
281 <span class="string">"size = 1.69m \n name = \"Mike\" \n age = 10 "</span>
282 <span class="special">,</span><span class="identifier">no_constraint_person_rule</span>
283 <span class="special">,</span><span class="identifier">Mike</span><span class="special">);</span> <span class="comment">// still the same result</span>
285 <span class="identifier">std</span><span class="special">::</span><span class="identifier">cout</span><span class="special"><<</span><span class="identifier">Mike</span><span class="special">;</span>
290 The code above will print:
292 <pre class="programlisting">Person : John, 10, 1.69
293 Person : Mary, 10, 1.69
294 Person : Mike, 10, 1.69
297 Now let's delcare a parser with some occurence constraints:
300 The parser definition below uses the kwd directive occurence constraint
301 variants to make sure that the name and age keyword occur only once and
302 allows the favorite color entry to appear 0 or more times.
306 <pre class="programlisting"><span class="identifier">constraint_person_rule</span> <span class="special">%=</span>
307 <span class="identifier">kwd</span><span class="special">(</span><span class="string">"name"</span><span class="special">,</span><span class="number">1</span><span class="special">)</span> <span class="special">[</span><span class="char">'='</span> <span class="special">></span> <span class="identifier">parse_string</span> <span class="special">]</span>
308 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"age"</span> <span class="special">,</span><span class="number">1</span><span class="special">)</span> <span class="special">[</span><span class="char">'='</span> <span class="special">></span> <span class="identifier">int_</span><span class="special">]</span>
309 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"size"</span> <span class="special">,</span><span class="number">1</span><span class="special">)</span> <span class="special">[</span><span class="char">'='</span> <span class="special">></span> <span class="identifier">double_</span> <span class="special">></span> <span class="char">'m'</span><span class="special">]</span>
310 <span class="special">/</span> <span class="identifier">kwd</span><span class="special">(</span><span class="string">"favorite color"</span><span class="special">,</span><span class="number">0</span><span class="special">,</span><span class="identifier">inf</span><span class="special">)</span> <span class="special">[</span> <span class="char">'='</span> <span class="special">></span> <span class="identifier">parse_string</span> <span class="special">]</span>
311 <span class="special">;</span>
316 And see how it works in these two cases:
320 <pre class="programlisting"> <span class="comment">// Here all the give constraint are resepected : parsing will succeed.</span>
321 <span class="identifier">test_phrase_parser_attr</span><span class="special">(</span>
322 <span class="string">"name = \"Hellen\" \n age = 10 \n size = 1.80m \n favorite color = \"blue\" \n favorite color = \"green\" "</span>
323 <span class="special">,</span><span class="identifier">constraint_person_rule</span>
324 <span class="special">,</span><span class="identifier">Hellen</span><span class="special">);</span>
325 <span class="identifier">std</span><span class="special">::</span><span class="identifier">cout</span><span class="special"><<</span><span class="identifier">Hellen</span><span class="special">;</span>
327 <span class="comment">// Parsing this string will fail because the age and size minimum occurence requirements aren't met.</span>
328 <span class="identifier">test_phrase_parser_attr</span><span class="special">(</span>
329 <span class="string">"name = \"Johny\" \n favorite color = \"blue\" \n favorite color = \"green\" "</span>
330 <span class="special">,</span><span class="identifier">constraint_person_rule</span>
331 <span class="special">,</span><span class="identifier">Johny</span> <span class="special">);</span>
336 Parsing the first string will succeed but fail for the second string as
337 the occurence constraints aren't met. This code should print:
339 <pre class="programlisting">Person : Hellen, 10, 1.8
344 <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
345 <td align="left"></td>
346 <td align="right"><div class="copyright-footer">Copyright © 2001-2011 Joel de Guzman, Hartmut Kaiser<p>
347 Distributed under the Boost Software License, Version 1.0. (See accompanying
348 file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
353 <div class="spirit-nav">
354 <a accesskey="p" href="../operators.html"><img src="../../../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../operators.html"><img src="../../../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../../index.html"><img src="../../../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="../../karma_components.html"><img src="../../../../../../../../doc/src/images/next.png" alt="Next"></a>