Author: buildbot
Date: Thu Apr 24 16:17:58 2014
New Revision: 906741

Log:
Production update by buildbot for camel

Modified:
    websites/production/camel/content/cache/main.pageCache
    websites/production/camel/content/splitter.html

Modified: websites/production/camel/content/cache/main.pageCache
==============================================================================
Binary files - no diff available.

Modified: websites/production/camel/content/splitter.html
==============================================================================
--- websites/production/camel/content/splitter.html (original)
+++ websites/production/camel/content/splitter.html Thu Apr 24 16:17:58 2014
@@ -86,32 +86,9 @@
        <tbody>
         <tr>
         <td valign="top" width="100%">
-<div class="wiki-content maincontent"><h3 id="Splitter-Splitter">Splitter</h3>
-
-<p>The <a shape="rect" class="external-link" 
href="http://www.enterpriseintegrationpatterns.com/Sequencer.html"; 
rel="nofollow">Splitter</a> from the <a shape="rect" 
href="enterprise-integration-patterns.html">EIP patterns</a> allows you split a 
message into a number of pieces and process them individually</p>
-
-<p><img class="confluence-embedded-image confluence-external-resource" 
src="http://www.enterpriseintegrationpatterns.com/img/Sequencer.gif"; 
data-image-src="http://www.enterpriseintegrationpatterns.com/img/Sequencer.gif";></p>
-
-<p>You need to specify a Splitter as <code>split()</code>. In earlier versions 
of Camel, you need to use <code>splitter()</code>.</p>
-
-
-<h3 id="Splitter-Options">Options</h3>
-
-<div class="confluenceTableSmall">
+<div class="wiki-content maincontent"><h3 
id="Splitter-Splitter">Splitter</h3><p>The <a shape="rect" 
class="external-link" 
href="http://www.enterpriseintegrationpatterns.com/Sequencer.html"; 
rel="nofollow">Splitter</a> from the <a shape="rect" 
href="enterprise-integration-patterns.html">EIP patterns</a> allows you split a 
message into a number of pieces and process them individually</p><p><img 
class="confluence-embedded-image confluence-external-resource" 
src="http://www.enterpriseintegrationpatterns.com/img/Sequencer.gif"; 
data-image-src="http://www.enterpriseintegrationpatterns.com/img/Sequencer.gif";></p><p>You
 need to specify a Splitter as <code>split()</code>. In earlier versions of 
Camel, you need to use <code>splitter()</code>.</p><h3 
id="Splitter-Options">Options</h3><div class="confluenceTableSmall">
 <table class="confluenceTable"><tbody><tr><th colspan="1" rowspan="1" 
class="confluenceTh"><p> Name </p></th><th colspan="1" rowspan="1" 
class="confluenceTh"><p> Default Value </p></th><th colspan="1" rowspan="1" 
class="confluenceTh"><p> Description </p></th></tr><tr><td colspan="1" 
rowspan="1" class="confluenceTd"><p> <code>strategyRef</code> </p></td><td 
colspan="1" rowspan="1" class="confluenceTd"><p>&#160;</p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p> Refers to an <a shape="rect" 
class="external-link" 
href="http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/processor/aggregate/AggregationStrategy.html";>AggregationStrategy</a>
 to be used to assemble the replies from the sub-messages, into a single 
outgoing message from the <a shape="rect" href="splitter.html" 
title="Splitter">Splitter</a>. See the defaults described below in <em><a 
shape="rect" href="#Splitter-WhattheSplitterreturns">What the Splitter 
returns</a></em>. From <strong>Camel 2.12
 </strong> onwards you can also use a POJO as the 
<code>AggregationStrategy</code>, see the <a shape="rect" 
href="aggregator2.html" title="Aggregator2">Aggregate</a> page for more 
details. </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>strategyMethodName</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p>&#160;</p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> <strong>Camel 2.12:</strong> This option can be used 
to explicit declare the method name to use, when using POJOs as the 
<code>AggregationStrategy</code>. See the <a shape="rect" 
href="aggregator2.html" title="Aggregator2">Aggregate</a> page for more 
details. </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>strategyMethodAllowNull</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> <code>false</code> </p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p> <strong>Camel 2.12:</strong> If this 
option is <code>false</code> 
 then the aggregate method is not used for the very first splitted message. If 
this option is <code>true</code> then <code>null</code> values is used as the 
<code>oldExchange</code> (for the very first message splitted), when using 
POJOs as the <code>AggregationStrategy</code>. See the <a shape="rect" 
href="aggregator2.html" title="Aggregator2">Aggregate</a> page for more 
details. </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>parallelProcessing</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> <code>false</code> </p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p> If enabled then processing the 
sub-messages occurs concurrently. Note the caller thread will still wait until 
all sub-messages has been fully processed, before it continues. 
</p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>executorServiceRef</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p>&#160;</p></td><td colspan="1"
  rowspan="1" class="confluenceTd"><p> Refers to a custom <a shape="rect" 
href="threading-model.html" title="Threading Model">Thread Pool</a> to be used 
for parallel processing. Notice if you set this option, then parallel 
processing is automatically implied, and you do not have to enable that option 
as well. </p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>stopOnException</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> <code>false</code> </p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p> <strong>Camel 2.2:</strong> Whether or not 
to stop continue processing immediately when an exception occurred. If disable, 
then Camel continue splitting and process the sub-messages regardless if one of 
them failed. You can deal with exceptions in the <a shape="rect" 
class="external-link" 
href="http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/processor/aggregate/AggregationStrategy.html";>AggregationStrategy</a>
 clas
 s where you have full control how to handle that. </p></td></tr><tr><td 
colspan="1" rowspan="1" class="confluenceTd"><p> <code>streaming</code> 
</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>false</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> If enabled then Camel will split in a streaming 
fashion, which means it will split the input message in chunks. This reduces 
the memory overhead. For example if you split big messages its recommended to 
enable streaming. If streaming is enabled then the sub-message replies will be 
aggregated out-of-order, eg in the order they come back. If disabled, Camel 
will process sub-message replies in the same order as they where splitted. 
</p></td></tr><tr><td colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>timeout</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p>&#160;</p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> <strong>Camel 2.5:</strong> Sets a total timeout 
specifi
 ed in millis. If the <a shape="rect" href="recipient-list.html" 
title="Recipient List">Recipient List</a> hasn't been able to split and process 
all replies within the given timeframe, then the timeout triggers and the <a 
shape="rect" href="splitter.html" title="Splitter">Splitter</a> breaks out and 
continues. Notice if you provide a <a shape="rect" class="external-link" 
href="http://camel.apache.org/maven/current/camel-core/apidocs/org/apache/camel/processor/aggregate/TimeoutAwareAggregationStrategy.html";>TimeoutAwareAggregationStrategy</a>
 then the <code>timeout</code> method is invoked before breaking out. If the 
timeout is reached with running tasks still remaining, certain tasks for which 
it is difficult for Camel to shut down in a graceful manner may continue to 
run.  So use this option with a bit of care.  We may be able to improve this 
functionality in future Camel releases. </p></td></tr><tr><td colspan="1" 
rowspan="1" class="confluenceTd"><p> <code>onPrepareRef</code> </p><
 /td><td colspan="1" rowspan="1" class="confluenceTd"><p>&#160;</p></td><td 
colspan="1" rowspan="1" class="confluenceTd"><p> <strong>Camel 2.8:</strong> 
Refers to a custom <a shape="rect" href="processor.html" 
title="Processor">Processor</a> to prepare the sub-message of the <a 
shape="rect" href="exchange.html" title="Exchange">Exchange</a>, before its 
processed. This allows you to do any custom logic, such as deep-cloning the 
message payload if that's needed etc. </p></td></tr><tr><td colspan="1" 
rowspan="1" class="confluenceTd"><p> <code>shareUnitOfWork</code> </p></td><td 
colspan="1" rowspan="1" class="confluenceTd"><p> <code>false</code> 
</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> <strong>Camel 
2.8:</strong> Whether the unit of work should be shared. See further below for 
more details. </p></td></tr></tbody></table>
-</div>
-
-<h3 id="Splitter-Exchangeproperties">Exchange properties</h3>
-<p>The following properties are set on each Exchange that are split:</p>
-<div class="table-wrap"><table class="confluenceTable"><tbody><tr><th 
colspan="1" rowspan="1" class="confluenceTh"><p> property </p></th><th 
colspan="1" rowspan="1" class="confluenceTh"><p> type </p></th><th colspan="1" 
rowspan="1" class="confluenceTh"><p> description </p></th></tr><tr><td 
colspan="1" rowspan="1" class="confluenceTd"><p> <code>CamelSplitIndex</code> 
</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> int </p></td><td 
colspan="1" rowspan="1" class="confluenceTd"><p> A split counter that increases 
for each Exchange being split. The counter starts from 0. </p></td></tr><tr><td 
colspan="1" rowspan="1" class="confluenceTd"><p> <code>CamelSplitSize</code> 
</p></td><td colspan="1" rowspan="1" class="confluenceTd"><p> int </p></td><td 
colspan="1" rowspan="1" class="confluenceTd"><p> The total number of Exchanges 
that was splitted. This header is not applied for stream based splitting. From 
<strong>Camel 2.9</strong> onwards this header is also set in stream based 
 splitting, but only on the completed Exchange. </p></td></tr><tr><td 
colspan="1" rowspan="1" class="confluenceTd"><p> 
<code>CamelSplitComplete</code> </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> boolean </p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p> <strong>Camel 2.4:</strong> Whether or not this 
Exchange is the last. </p></td></tr></tbody></table></div>
-
-
-<h3 id="Splitter-Examples">Examples</h3>
-
-<p>The following example shows how to take a request from the 
<strong>queue:a</strong> endpoint the split it into pieces using an <a 
shape="rect" href="expression.html">Expression</a>, then forward each piece to 
<strong>queue:b</strong></p>
-
-<p><strong>Using the <a shape="rect" href="fluent-builders.html">Fluent 
Builders</a></strong></p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div><h3 id="Splitter-Exchangeproperties">Exchange properties</h3><p>The 
following properties are set on each Exchange that are split:</p><div 
class="table-wrap"><table class="confluenceTable"><tbody><tr><th colspan="1" 
rowspan="1" class="confluenceTh"><p>property</p></th><th colspan="1" 
rowspan="1" class="confluenceTh"><p>type</p></th><th colspan="1" rowspan="1" 
class="confluenceTh"><p>description</p></th></tr><tr><td colspan="1" 
rowspan="1" class="confluenceTd"><p><code>CamelSplitIndex</code></p></td><td 
colspan="1" rowspan="1" class="confluenceTd"><p>int</p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p>A split counter that increases for each 
Exchange being split. The counter starts from 0.</p></td></tr><tr><td 
colspan="1" rowspan="1" 
class="confluenceTd"><p><code>CamelSplitSize</code></p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p>int</p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p>The total number of Exchanges that was splitted. This 
header i
 s not applied for stream based splitting. From <strong>Camel 2.9</strong> 
onwards this header is also set in stream based splitting, but only on the 
completed Exchange.</p></td></tr><tr><td colspan="1" rowspan="1" 
class="confluenceTd"><p><code>CamelSplitComplete</code></p></td><td colspan="1" 
rowspan="1" class="confluenceTd"><p>boolean</p></td><td colspan="1" rowspan="1" 
class="confluenceTd"><p><strong>Camel 2.4:</strong> Whether or not this 
Exchange is the last.</p></td></tr></tbody></table></div><h3 
id="Splitter-Examples">Examples</h3><p>The following example shows how to take 
a request from the <strong>queue:a</strong> endpoint the split it into pieces 
using an <a shape="rect" href="expression.html">Expression</a>, then forward 
each piece to <strong>queue:b</strong></p><p><strong>Using the <a shape="rect" 
href="fluent-builders.html">Fluent Builders</a></strong></p><div class="code 
panel pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 RouteBuilder builder = new RouteBuilder() {
     public void configure() {
@@ -123,18 +100,10 @@ RouteBuilder builder = new RouteBuilder(
     }
 };
 ]]></script>
-</div></div>
-
-<p>The splitter can use any <a shape="rect" 
href="expression.html">Expression</a> language so you could use any of the <a 
shape="rect" href="languages-supported.html">Languages Supported</a> such as <a 
shape="rect" href="xpath.html">XPath</a>, <a shape="rect" 
href="xquery.html">XQuery</a>, <a shape="rect" href="sql.html">SQL</a> or one 
of the <a shape="rect" href="scripting-languages.html">Scripting Languages</a> 
to perform the split. e.g.</p>
-
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-from(&quot;activemq:my.queue&quot;).split(xpath(&quot;//foo/bar&quot;)).convertBodyTo(String.class).to(&quot;file://some/directory&quot;)
+</div></div><p>The splitter can use any <a shape="rect" 
href="expression.html">Expression</a> language so you could use any of the <a 
shape="rect" href="languages-supported.html">Languages Supported</a> such as <a 
shape="rect" href="xpath.html">XPath</a>, <a shape="rect" 
href="xquery.html">XQuery</a>, <a shape="rect" href="sql.html">SQL</a> or one 
of the <a shape="rect" href="scripting-languages.html">Scripting Languages</a> 
to perform the split. e.g.</p><div class="code panel pdl" style="border-width: 
1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[from(&quot;activemq:my.queue&quot;).split(xpath(&quot;//foo/bar&quot;)).convertBodyTo(String.class).to(&quot;file://some/directory&quot;)
 ]]></script>
-</div></div>
-
-<p><strong>Using the <a shape="rect" href="spring-xml-extensions.html">Spring 
XML Extensions</a></strong></p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><p><strong>Using the <a shape="rect" 
href="spring-xml-extensions.html">Spring XML Extensions</a></strong></p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
 <script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 &lt;camelContext errorHandlerRef=&quot;errorHandler&quot; 
xmlns=&quot;http://camel.apache.org/schema/spring&quot;&gt;
     &lt;route&gt;
@@ -146,15 +115,7 @@ from(&quot;activemq:my.queue&quot;).spli
     &lt;/route&gt;
 &lt;/camelContext&gt;
 ]]></script>
-</div></div>
-
-<p>For further examples of this pattern in use you could look at one of the <a 
shape="rect" class="external-link" 
href="http://svn.apache.org/viewvc/camel/trunk/camel-core/src/test/java/org/apache/camel/processor/SplitterTest.java?view=markup";>junit
 test case</a></p>
-
-<h3 id="Splitter-UsingTokenizerfrom*">Using Tokenizer from <a shape="rect" 
href="spring-xml-extensions.html">Spring XML Extensions</a>*</h3>
-
-<p>You can use the tokenizer expression in the Spring DSL to split bodies or 
headers using a token. This is a common use-case, so we provided a special 
<strong>tokenizer</strong> tag for this.<br clear="none">
-In the sample below we split the body using a @ as separator. You can of 
course use comma or space or even a regex pattern, also set regex=true.</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><p>For further examples of this pattern in use you could look at 
one of the <a shape="rect" class="external-link" 
href="http://svn.apache.org/viewvc/camel/trunk/camel-core/src/test/java/org/apache/camel/processor/SplitterTest.java?view=markup";>junit
 test case</a></p><h3 id="Splitter-UsingTokenizerfrom*">Using Tokenizer from <a 
shape="rect" href="spring-xml-extensions.html">Spring XML 
Extensions</a>*</h3><p>You can use the tokenizer expression in the Spring DSL 
to split bodies or headers using a token. This is a common use-case, so we 
provided a special <strong>tokenizer</strong> tag for this.<br clear="none"> In 
the sample below we split the body using a @ as separator. You can of course 
use comma or space or even a regex pattern, also set regex=true.</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
 <script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 &lt;camelContext xmlns=&quot;http://camel.apache.org/schema/spring&quot;&gt;
     &lt;route&gt;
@@ -166,94 +127,45 @@ In the sample below we split the body us
     &lt;/route&gt;
 &lt;/camelContext&gt;
 ]]></script>
-</div></div>
-
-<p>Splitting the body in Spring XML is a bit harder as you need to use the <a 
shape="rect" href="simple.html">Simple</a> language to dictate this</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-&lt;split&gt;
+</div></div><p>Splitting the body in Spring XML is a bit harder as you need to 
use the <a shape="rect" href="simple.html">Simple</a> language to dictate 
this</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[&lt;split&gt;
    &lt;simple&gt;${body}&lt;/simple&gt;
    &lt;to uri=&quot;mock:result&quot;/&gt;
 &lt;/split&gt;
 ]]></script>
-</div></div>
-
-<h3 id="Splitter-WhattheSplitterreturns">What the Splitter returns</h3>
-<p><strong>Camel 2.2 or older:</strong><br clear="none">
-The <a shape="rect" href="splitter.html">Splitter</a> will by default return 
the <strong>last</strong> splitted message.</p>
-
-<p><strong>Camel 2.3 and newer</strong><br clear="none">
-The <a shape="rect" href="splitter.html">Splitter</a> will by default return 
the original input message.</p>
-
-<p><strong>For all versions</strong><br clear="none">
-You can override this by suppling your own strategy as an 
<code>AggregationStrategy</code>. There is a sample on this page (Split 
aggregate request/reply sample). Notice its the same strategy as the <a 
shape="rect" href="aggregator.html">Aggregator</a> supports. This <a 
shape="rect" href="splitter.html">Splitter</a> can be viewed as having a build 
in light weight <a shape="rect" href="aggregator.html">Aggregator</a>.</p>
-
-<h3 id="Splitter-Parallelexecutionofdistinct'parts'">Parallel execution of 
distinct 'parts'</h3>
-<p>If you want to execute all parts in parallel you can use special notation 
of <code>split()</code> with two arguments, where the second one is a 
<strong>boolean</strong> flag if processing should be parallel. e.g.</p>
-
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-XPathBuilder xPathBuilder = new XPathBuilder(&quot;//foo/bar&quot;); 
+</div></div><h3 id="Splitter-WhattheSplitterreturns">What the Splitter 
returns</h3><p><strong>Camel 2.2 or older:</strong><br clear="none"> The <a 
shape="rect" href="splitter.html">Splitter</a> will by default return the 
<strong>last</strong> splitted message.</p><p><strong>Camel 2.3 and 
newer</strong><br clear="none"> The <a shape="rect" 
href="splitter.html">Splitter</a> will by default return the original input 
message.</p><p><strong>For all versions</strong><br clear="none"> You can 
override this by suppling your own strategy as an 
<code>AggregationStrategy</code>. There is a sample on this page (Split 
aggregate request/reply sample). Notice its the same strategy as the <a 
shape="rect" href="aggregator.html">Aggregator</a> supports. This <a 
shape="rect" href="splitter.html">Splitter</a> can be viewed as having a build 
in light weight <a shape="rect" href="aggregator.html">Aggregator</a>.</p><h3 
id="Splitter-Parallelexecutionofdistinct'parts'">Parallel execution of distinct 
'parts
 '</h3><p>If you want to execute all parts in parallel you can use special 
notation of <code>split()</code> with two arguments, where the second one is a 
<strong>boolean</strong> flag if processing should be parallel. e.g.</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[XPathBuilder xPathBuilder = new 
XPathBuilder(&quot;//foo/bar&quot;); 
 from(&quot;activemq:my.queue&quot;).split(xPathBuilder, 
true).to(&quot;activemq:my.parts&quot;);
 ]]></script>
-</div></div>
-
-<p>The boolean option has been refactored into a builder method 
<code>parallelProcessing</code> so its easier to understand what the route does 
when we use a method instead of true|false.</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-XPathBuilder xPathBuilder = new XPathBuilder(&quot;//foo/bar&quot;); 
+</div></div><p>The boolean option has been refactored into a builder method 
<code>parallelProcessing</code> so its easier to understand what the route does 
when we use a method instead of true|false.</p><div class="code panel pdl" 
style="border-width: 1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[XPathBuilder xPathBuilder = new 
XPathBuilder(&quot;//foo/bar&quot;); 
 
from(&quot;activemq:my.queue&quot;).split(xPathBuilder).parallelProcessing().to(&quot;activemq:my.parts&quot;);
 ]]></script>
-</div></div>
-
-<h3 id="Splitter-Streambased">Stream based</h3>
-    <div class="aui-message hint shadowed information-macro">
+</div></div><h3 id="Splitter-Streambased">Stream based</h3>    <div 
class="aui-message hint shadowed information-macro">
                     <p class="title">Splitting big XML payloads</p>
                             <span class="aui-icon icon-hint">Icon</span>
                 <div class="message-content">
-                            
-<p>The XPath engine in Java and <a shape="rect" href="xquery.html">saxon</a> 
will load the entire XML content into memory. And thus they are not well suited 
for very big XML payloads.<br clear="none">
-Instead you can use a custom <a shape="rect" 
href="expression.html">Expression</a> which will iterate the XML payload in a 
streamed fashion. From Camel 2.9 onwards you can use the Tokenizer language<br 
clear="none">
-which supports this when you supply the start and end tokens.</p>
+                            <p>The XPath engine in Java and <a shape="rect" 
href="xquery.html">saxon</a> will load the entire XML content into memory. And 
thus they are not well suited for very big XML payloads.<br clear="none"> 
Instead you can use a custom <a shape="rect" 
href="expression.html">Expression</a> which will iterate the XML payload in a 
streamed fashion. From Camel 2.9 onwards you can use the Tokenizer language<br 
clear="none"> which supports this when you supply the start and end tokens.</p>
                     </div>
     </div>
-
-
-<p>You can split streams by enabling the streaming mode using the 
<code>streaming</code> builder method.</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-    
from(&quot;direct:streaming&quot;).split(body().tokenize(&quot;,&quot;)).streaming().to(&quot;activemq:my.parts&quot;);
+<p>You can split streams by enabling the streaming mode using the 
<code>streaming</code> builder method.</p><div class="code panel pdl" 
style="border-width: 1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[    
from(&quot;direct:streaming&quot;).split(body().tokenize(&quot;,&quot;)).streaming().to(&quot;activemq:my.parts&quot;);
 ]]></script>
-</div></div>
-
-<p>You can also supply your custom splitter to use with streaming like 
this:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-import static org.apache.camel.builder.ExpressionBuilder.beanExpression;
+</div></div><p>You can also supply your custom splitter to use with streaming 
like this:</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[import static 
org.apache.camel.builder.ExpressionBuilder.beanExpression;
 from(&quot;direct:streaming&quot;)
      .split(beanExpression(new MyCustomIteratorFactory(),  
&quot;iterator&quot;))
      .streaming().to(&quot;activemq:my.parts&quot;)
 ]]></script>
-</div></div>
-
-<h4 id="Splitter-StreamingbigXMLpayloadsusingTokenizerlanguage">Streaming big 
XML payloads using Tokenizer language</h4>
-<p><strong>Available as of Camel 2.9</strong><br clear="none">
-If you have a big XML payload, from a file source, and want to split it in 
streaming mode, then you can use the Tokenizer language with start/end tokens 
to do this with low memory footprint.</p>
-
-    <div class="aui-message success shadowed information-macro">
+</div></div><h4 
id="Splitter-StreamingbigXMLpayloadsusingTokenizerlanguage">Streaming big XML 
payloads using Tokenizer language</h4><p><strong>Available as of Camel 
2.9</strong><br clear="none"> If you have a big XML payload, from a file 
source, and want to split it in streaming mode, then you can use the Tokenizer 
language with start/end tokens to do this with low memory footprint.</p>    
<div class="aui-message success shadowed information-macro">
                     <p class="title">StAX component</p>
                             <span class="aui-icon icon-success">Icon</span>
                 <div class="message-content">
-                            
-<p>The Camel <a shape="rect" href="stax.html">StAX</a> component can also be 
used to split big XML files in a streaming mode. See more details at <a 
shape="rect" href="stax.html">StAX</a>.</p>
+                            <p>The Camel <a shape="rect" 
href="stax.html">StAX</a> component can also be used to split big XML files in 
a streaming mode. See more details at <a shape="rect" 
href="stax.html">StAX</a>.</p>
                     </div>
     </div>
-
-
-<p>For example you may have a XML payload structured as follows</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-&lt;orders&gt;
+<p>For example you may have a XML payload structured as follows</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[&lt;orders&gt;
   &lt;order&gt;
     &lt;!-- order stuff here --&gt;
   &lt;/order&gt;
@@ -266,21 +178,13 @@ If you have a big XML payload, from a fi
   &lt;/order&gt;
 &lt;/orders&gt;
 ]]></script>
-</div></div>
-
-<p>Now to split this big file using <a shape="rect" 
href="xpath.html">XPath</a> would cause the entire content to be loaded into 
memory. So instead we can use the Tokenizer language to do this as follows:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-  from(&quot;file:inbox&quot;)
+</div></div><p>Now to split this big file using <a shape="rect" 
href="xpath.html">XPath</a> would cause the entire content to be loaded into 
memory. So instead we can use the Tokenizer language to do this as 
follows:</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[  from(&quot;file:inbox&quot;)
     .split().tokenizeXML(&quot;order&quot;).streaming()
        .to(&quot;activemq:queue:order&quot;);
 ]]></script>
-</div></div>
-
-<p>In XML DSL the route would be as follows:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-&lt;route&gt;
+</div></div><p>In XML DSL the route would be as follows:</p><div class="code 
panel pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[&lt;route&gt;
   &lt;from uri=&quot;file:inbox&quot;/&gt;
   &lt;split streaming=&quot;true&quot;&gt;
     &lt;tokenize token=&quot;order&quot; xml=&quot;true&quot;/&gt;
@@ -288,21 +192,13 @@ If you have a big XML payload, from a fi
   &lt;/split&gt;
 &lt;/route&gt;
 ]]></script>
-</div></div>
-
-<p>Notice the <code>tokenizeXML</code> method which will split the file using 
the tag name of the child node, which mean it will grab the content between the 
<code>&lt;order&gt;</code> and <code>&lt;/order&gt;</code> tags (incl. the 
tokens). So for example a splitted message would be as follows:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-  &lt;order&gt;
+</div></div><p>Notice the <code>tokenizeXML</code> method which will split the 
file using the tag name of the child node, which mean it will grab the content 
between the <code>&lt;order&gt;</code> and <code>&lt;/order&gt;</code> tags 
(incl. the tokens). So for example a splitted message would be as 
follows:</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[  &lt;order&gt;
     &lt;!-- order stuff here --&gt;
   &lt;/order&gt;
 ]]></script>
-</div></div>
-
-<p>If you want to inherit namespaces from a root/parent tag, then you can do 
this as well by providing the name of the root/parent tag:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-&lt;route&gt;
+</div></div><p>If you want to inherit namespaces from a root/parent tag, then 
you can do this as well by providing the name of the root/parent tag:</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[&lt;route&gt;
   &lt;from uri=&quot;file:inbox&quot;/&gt;
   &lt;split streaming=&quot;true&quot;&gt;
     &lt;tokenize token=&quot;order&quot; 
inheritNamespaceTagName=&quot;orders&quot; xml=&quot;true&quot;/&gt;
@@ -310,34 +206,18 @@ If you have a big XML payload, from a fi
   &lt;/split&gt;
 &lt;/route&gt;
 ]]></script>
-</div></div>
-
-<p>And in Java DSL its as follows:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-  from(&quot;file:inbox&quot;)
+</div></div><p>And in Java DSL its as follows:</p><div class="code panel pdl" 
style="border-width: 1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[  from(&quot;file:inbox&quot;)
     .split().tokenizeXML(&quot;order&quot;, &quot;orders&quot;).streaming()
        .to(&quot;activemq:queue:order&quot;);
 ]]></script>
-</div></div>
-
-
-<h4 id="Splitter-SplittingfilesbygroupingNlinestogether">Splitting files by 
grouping N lines together</h4>
-<p><strong>Available as of Camel 2.10</strong></p>
-
-<p>The <a shape="rect" href="tokenizer.html">Tokenizer</a> language has a new 
option <code>group</code> that allows you to group N parts together, for 
example to split big files into chunks of 1000 lines.</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-  from(&quot;file:inbox&quot;)
+</div></div><p><span style="line-height: 1.4285715;">Available as of Camel 
2.13.1, you can set the above inheritNamsepaceTagName property to "*" 
to&#160;include the preceding context in each token (i.e., generating each 
token enclosed in its ancestor elements).</span></p><h4 
id="Splitter-SplittingfilesbygroupingNlinestogether">Splitting files by 
grouping N lines together</h4><p><strong>Available as of Camel 
2.10</strong></p><p>The <a shape="rect" href="tokenizer.html">Tokenizer</a> 
language has a new option <code>group</code> that allows you to group N parts 
together, for example to split big files into chunks of 1000 lines.</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[  from(&quot;file:inbox&quot;)
     .split().tokenize(&quot;\n&quot;, 1000).streaming()
        .to(&quot;activemq:queue:order&quot;);
 ]]></script>
-</div></div>
-
-<p>And in XML DSL</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-&lt;route&gt;
+</div></div><p>And in XML DSL</p><div class="code panel pdl" 
style="border-width: 1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[&lt;route&gt;
   &lt;from uri=&quot;file:inbox&quot;/&gt;
   &lt;split streaming=&quot;true&quot;&gt;
     &lt;tokenize token=&quot;\n&quot; group=&quot;1000&quot;/&gt;
@@ -345,24 +225,8 @@ If you have a big XML payload, from a fi
   &lt;/split&gt;
 &lt;/route&gt;
 ]]></script>
-</div></div>
-
-<p>The <code>group</code> option is a number that must be a positive number 
that dictates how many groups to combine together. Each part will be combined 
using the token.<br clear="none">
-So in the example above the message being sent to the activemq order queue, 
will contain 1000 lines, and each line separated by the token (which is a new 
line token).<br clear="none">
-The output when using the <code>group</code> option is always a 
<code>java.lang.String</code> type. </p>
-
-
-
-<h4 id="Splitter-Specifyingacustomaggregationstrategy">Specifying a custom 
aggregation strategy </h4>
-
-<p>This is specified similar to the <a shape="rect" 
href="aggregator.html">Aggregator</a>.</p>
-
-<h4 id="Splitter-SpecifyingacustomThreadPoolExecutor">Specifying a custom 
ThreadPoolExecutor</h4>
-<p>You can customize the underlying ThreadPoolExecutor used in the parallel 
splitter. In the Java DSL try something like this:</p>
-
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-XPathBuilder xPathBuilder = new XPathBuilder(&quot;//foo/bar&quot;); 
+</div></div><p>The <code>group</code> option is a number that must be a 
positive number that dictates how many groups to combine together. Each part 
will be combined using the token.<br clear="none"> So in the example above the 
message being sent to the activemq order queue, will contain 1000 lines, and 
each line separated by the token (which is a new line token).<br clear="none"> 
The output when using the <code>group</code> option is always a 
<code>java.lang.String</code> type.</p><h4 
id="Splitter-Specifyingacustomaggregationstrategy">Specifying a custom 
aggregation strategy</h4><p>This is specified similar to the <a shape="rect" 
href="aggregator.html">Aggregator</a>.</p><h4 
id="Splitter-SpecifyingacustomThreadPoolExecutor">Specifying a custom 
ThreadPoolExecutor</h4><p>You can customize the underlying ThreadPoolExecutor 
used in the parallel splitter. In the Java DSL try something like this:</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelConte
 nt pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[XPathBuilder xPathBuilder = new 
XPathBuilder(&quot;//foo/bar&quot;); 
 
 ExecutorService pool = ...
 
@@ -370,25 +234,14 @@ from(&quot;activemq:my.queue&quot;)
     .split(xPathBuilder).parallelProcessing().executorService(pool)
         .to(&quot;activemq:my.parts&quot;);
 ]]></script>
-</div></div>
-
-<h4 id="Splitter-UsingaPojotodothesplitting">Using a Pojo to do the 
splitting</h4>
-<p>As the <a shape="rect" href="splitter.html">Splitter</a> can use any <a 
shape="rect" href="expression.html">Expression</a> to do the actual splitting 
we leverage this fact and use a <strong>method</strong> expression to invoke a 
<a shape="rect" href="bean.html">Bean</a> to get the splitted parts.<br 
clear="none">
-The <a shape="rect" href="bean.html">Bean</a> should return a value that is 
iterable such as: <code>java.util.Collection, java.util.Iterator</code> or an 
array. <br clear="none">
-So the returned value, will then be used by Camel at runtime, to split the 
message. </p>
-
-    <div class="aui-message success shadowed information-macro">
+</div></div><h4 id="Splitter-UsingaPojotodothesplitting">Using a Pojo to do 
the splitting</h4><p>As the <a shape="rect" href="splitter.html">Splitter</a> 
can use any <a shape="rect" href="expression.html">Expression</a> to do the 
actual splitting we leverage this fact and use a <strong>method</strong> 
expression to invoke a <a shape="rect" href="bean.html">Bean</a> to get the 
splitted parts.<br clear="none"> The <a shape="rect" href="bean.html">Bean</a> 
should return a value that is iterable such as: <code>java.util.Collection, 
java.util.Iterator</code> or an array. <br clear="none"> So the returned value, 
will then be used by Camel at runtime, to split the message.</p>    <div 
class="aui-message success shadowed information-macro">
                     <p class="title">Streaming mode and using pojo</p>
                             <span class="aui-icon icon-success">Icon</span>
                 <div class="message-content">
-                            
-<p>When you have enabled the streaming mode, then you should return a 
<code>Iterator</code> to ensure streamish fashion. For example if the message 
is a big file, then by using an iterator, that returns a piece of the file in 
chunks, in the <code>next</code> method of the <code>Iterator</code> ensures 
low memory footprint. This avoids the need for reading the entire content into 
memory. For an example see the source code for the <a shape="rect" 
class="external-link" 
href="https://svn.apache.org/repos/asf/camel/trunk/camel-core/src/main/java/org/apache/camel/support/TokenPairExpressionIterator.java";>TokenizePair</a>
 implementation.</p>
+                            <p>When you have enabled the streaming mode, then 
you should return a <code>Iterator</code> to ensure streamish fashion. For 
example if the message is a big file, then by using an iterator, that returns a 
piece of the file in chunks, in the <code>next</code> method of the 
<code>Iterator</code> ensures low memory footprint. This avoids the need for 
reading the entire content into memory. For an example see the source code for 
the <a shape="rect" class="external-link" 
href="https://svn.apache.org/repos/asf/camel/trunk/camel-core/src/main/java/org/apache/camel/support/TokenPairExpressionIterator.java";>TokenizePair</a>
 implementation.</p>
                     </div>
     </div>
-
-
-<p>In the route we define the <a shape="rect" 
href="expression.html">Expression</a> as a method call to invoke our <a 
shape="rect" href="bean.html">Bean</a> that we have registered with the id 
mySplitterBean in the <a shape="rect" href="registry.html">Registry</a>.</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+<p>In the route we define the <a shape="rect" 
href="expression.html">Expression</a> as a method call to invoke our <a 
shape="rect" href="bean.html">Bean</a> that we have registered with the id 
mySplitterBean in the <a shape="rect" 
href="registry.html">Registry</a>.</p><div class="code panel pdl" 
style="border-width: 1px;"><div class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 from(&quot;direct:body&quot;)
         // here we use a POJO bean mySplitterBean to do the split of the 
payload
@@ -400,10 +253,7 @@ from(&quot;direct:message&quot;)
         .split().method(&quot;mySplitterBean&quot;, &quot;splitMessage&quot;)
         .to(&quot;mock:result&quot;);
 ]]></script>
-</div></div>
-
-<p>And the logic for our <a shape="rect" href="bean.html">Bean</a> is as 
simple as. Notice we use Camel <a shape="rect" href="bean-binding.html">Bean 
Binding</a> to pass in the message body as a String object. </p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><p>And the logic for our <a shape="rect" href="bean.html">Bean</a> 
is as simple as. Notice we use Camel <a shape="rect" 
href="bean-binding.html">Bean Binding</a> to pass in the message body as a 
String object.</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 public class MySplitterBean {
 
@@ -453,13 +303,7 @@ public class MySplitterBean {
     }
 }
 ]]></script>
-</div></div>
-
-<h4 id="Splitter-Splitaggregaterequest/replysample">Split aggregate 
request/reply sample</h4>
-<p>This sample shows how you can split an <a shape="rect" 
href="exchange.html">Exchange</a>, process each splitted message, aggregate and 
return a combined response to the original caller using request/reply.</p>
-
-<p>The route below illustrates this and how the split supports a 
<strong>aggregationStrategy</strong> to hold the in progress processed 
messages:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><h4 id="Splitter-Splitaggregaterequest/replysample">Split 
aggregate request/reply sample</h4><p>This sample shows how you can split an <a 
shape="rect" href="exchange.html">Exchange</a>, process each splitted message, 
aggregate and return a combined response to the original caller using 
request/reply.</p><p>The route below illustrates this and how the split 
supports a <strong>aggregationStrategy</strong> to hold the in progress 
processed messages:</p><div class="code panel pdl" style="border-width: 
1px;"><div class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 // this routes starts from the direct:start endpoint
 // the body is then splitted based on @ separator
@@ -478,10 +322,7 @@ from(&quot;direct:start&quot;)
     // this bean will receive the result of the aggregate strategy: 
MyOrderStrategy
     .to(&quot;bean:MyOrderService?method=buildCombinedResponse&quot;)
 ]]></script>
-</div></div>
-
-<p>And the OrderService bean is as follows:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><p>And the OrderService bean is as follows:</p><div class="code 
panel pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 public static class MyOrderService {
 
@@ -505,10 +346,7 @@ public static class MyOrderService {
     }
 }
 ]]></script>
-</div></div>
-
-<p>And our custom <strong>aggregationStrategy</strong> that is responsible for 
holding the in progress aggregated message that after the splitter is ended 
will be sent to the <strong>buildCombinedResponse</strong> method for final 
processing before the combined response can be returned to the waiting 
caller.</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><p>And our custom <strong>aggregationStrategy</strong> that is 
responsible for holding the in progress aggregated message that after the 
splitter is ended will be sent to the <strong>buildCombinedResponse</strong> 
method for final processing before the combined response can be returned to the 
waiting caller.</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 /**
  * This is our own order aggregation strategy where we can control
@@ -543,13 +381,8 @@ public static class MyOrderStrategy impl
     }
 }
 ]]></script>
-</div></div>
-
-<p>So lets run the sample and see how it works.<br clear="none">
-We send an <a shape="rect" href="exchange.html">Exchange</a> to the 
<strong>direct:start</strong> endpoint containing a IN body with the String 
value: <code>A@B@C</code>. The flow is:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-HandleOrder: A
+</div></div><p>So lets run the sample and see how it works.<br clear="none"> 
We send an <a shape="rect" href="exchange.html">Exchange</a> to the 
<strong>direct:start</strong> endpoint containing a IN body with the String 
value: <code>A@B@C</code>. The flow is:</p><div class="code panel pdl" 
style="border-width: 1px;"><div class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[HandleOrder: A
 HandleOrder: B
 Aggregate old orders: (id=1,item=A)
 Aggregate new order: (id=2,item=B)
@@ -559,29 +392,14 @@ Aggregate new order: (id=3,item=C)
 BuildCombinedResponse: (id=1,item=A);(id=2,item=B);(id=3,item=C)
 Response to caller: Response[(id=1,item=A);(id=2,item=B);(id=3,item=C)]
 ]]></script>
-</div></div>
-
-<h3 id="Splitter-Stopprocessingincaseofexception">Stop processing in case of 
exception</h3>
-<p><strong>Available as of Camel 2.1</strong></p>
-
-<p>The <a shape="rect" href="splitter.html">Splitter</a> will by default 
continue to process the entire <a shape="rect" 
href="exchange.html">Exchange</a> even in case of one of the splitted message 
will thrown an exception during routing.<br clear="none">
-For example if you have an <a shape="rect" href="exchange.html">Exchange</a> 
with 1000 rows that you split and route each sub message. During processing of 
these sub messages an exception is thrown at the 17th. What Camel does by 
default is to process the remainder 983 messages. You have the chance to remedy 
or handle this in the <code>AggregationStrategy</code>.</p>
-
-<p>But sometimes you just want Camel to stop and let the exception be 
propagated back, and let the Camel error handler handle it. You can do this in 
Camel 2.1 by specifying that it should stop in case of an exception occurred. 
This is done by the <code>stopOnException</code> option as shown below:</p>
-
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-    from(&quot;direct:start&quot;)
+</div></div><h3 id="Splitter-Stopprocessingincaseofexception">Stop processing 
in case of exception</h3><p><strong>Available as of Camel 
2.1</strong></p><p>The <a shape="rect" href="splitter.html">Splitter</a> will 
by default continue to process the entire <a shape="rect" 
href="exchange.html">Exchange</a> even in case of one of the splitted message 
will thrown an exception during routing.<br clear="none"> For example if you 
have an <a shape="rect" href="exchange.html">Exchange</a> with 1000 rows that 
you split and route each sub message. During processing of these sub messages 
an exception is thrown at the 17th. What Camel does by default is to process 
the remainder 983 messages. You have the chance to remedy or handle this in the 
<code>AggregationStrategy</code>.</p><p>But sometimes you just want Camel to 
stop and let the exception be propagated back, and let the Camel error handler 
handle it. You can do this in Camel 2.1 by specifying that it should stop in 
case of an exception occ
 urred. This is done by the <code>stopOnException</code> option as shown 
below:</p><div class="code panel pdl" style="border-width: 1px;"><div 
class="codeContent panelContent pdl">
+<script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[    from(&quot;direct:start&quot;)
         .split(body().tokenize(&quot;,&quot;)).stopOnException()
             .process(new MyProcessor())
             .to(&quot;mock:split&quot;);
 ]]></script>
-</div></div>
-
-<p>And using XML DSL you specify it as follows:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
-<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
-        &lt;route&gt;
+</div></div><p>And using XML DSL you specify it as follows:</p><div 
class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+<script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[        &lt;route&gt;
             &lt;from uri=&quot;direct:start&quot;/&gt;
             &lt;split stopOnException=&quot;true&quot;&gt;
                 &lt;tokenize token=&quot;,&quot;/&gt;
@@ -590,23 +408,7 @@ For example if you have an <a shape="rec
             &lt;/split&gt;
         &lt;/route&gt;
 ]]></script>
-</div></div>
-
-<h3 
id="Splitter-UsingonPreparetoexecutecustomlogicwhenpreparingmessages">Using 
onPrepare to execute custom logic when preparing messages</h3>
-<p><strong>Available as of Camel 2.8</strong></p>
-
-<p>See details at <a shape="rect" href="multicast.html">Multicast</a></p>
-
-
-<h3 id="Splitter-Sharingunitofwork">Sharing unit of work</h3>
-<p><strong>Available as of Camel 2.8</strong></p>
-
-<p>The <a shape="rect" href="splitter.html">Splitter</a> will by default not 
share unit of work between the parent exchange and each splitted exchange. This 
means each sub exchange has its own individual unit of work.</p>
-
-<p>For example you may have an use case, where you want to split a big 
message. And you want to regard that process as an atomic isolated operation 
that either is a success or failure. In case of a failure you want that big 
message to be moved into a <a shape="rect" href="dead-letter-channel.html">dead 
letter queue</a>. To support this use case, you would have to share the unit of 
work on the <a shape="rect" href="splitter.html">Splitter</a>.</p>
-
-<p>Here is an example in Java DSL</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><h3 
id="Splitter-UsingonPreparetoexecutecustomlogicwhenpreparingmessages">Using 
onPrepare to execute custom logic when preparing 
messages</h3><p><strong>Available as of Camel 2.8</strong></p><p>See details at 
<a shape="rect" href="multicast.html">Multicast</a></p><h3 
id="Splitter-Sharingunitofwork">Sharing unit of work</h3><p><strong>Available 
as of Camel 2.8</strong></p><p>The <a shape="rect" 
href="splitter.html">Splitter</a> will by default not share unit of work 
between the parent exchange and each splitted exchange. This means each sub 
exchange has its own individual unit of work.</p><p>For example you may have an 
use case, where you want to split a big message. And you want to regard that 
process as an atomic isolated operation that either is a success or failure. In 
case of a failure you want that big message to be moved into a <a shape="rect" 
href="dead-letter-channel.html">dead letter queue</a>. To support this use 
case, you would have to share the unit of work o
 n the <a shape="rect" href="splitter.html">Splitter</a>.</p><p>Here is an 
example in Java DSL</p><div class="code panel pdl" style="border-width: 
1px;"><div class="codeContent panelContent pdl">
 <script class="theme: Default; brush: java; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 errorHandler(deadLetterChannel(&quot;mock:dead&quot;).useOriginalMessage()
         .maximumRedeliveries(3).redeliveryDelay(0));
@@ -627,12 +429,7 @@ from(&quot;direct:line&quot;)
     .process(new MyProcessor())
     .to(&quot;mock:line&quot;);
 ]]></script>
-</div></div>
-
-<p>Now in this example what would happen is that in case there is a problem 
processing each sub message, the error handler will kick in (yes error handling 
still applies for the sub messages). <strong>But</strong> what doesn't happen 
is that if a sub message fails all redelivery attempts (its exhausted), then 
its <strong>not</strong> moved into that dead letter queue. The reason is that 
we have shared the unit of work, so the sub message will report the error on 
the shared unit of work. When the <a shape="rect" 
href="splitter.html">Splitter</a> is done, it checks the state of the shared 
unit of work and checks if any errors occurred. And if an error occurred it 
will set the exception on the <a shape="rect" href="exchange.html">Exchange</a> 
and mark it for rollback. The error handler will yet again kick in, as the <a 
shape="rect" href="exchange.html">Exchange</a> has been marked as rollback and 
it had an exception as well. No redelivery attempts is performed (as it was 
marked for rol
 lback) and the <a shape="rect" href="exchange.html">Exchange</a> will be moved 
into the <a shape="rect" href="dead-letter-channel.html">dead letter 
queue</a>.</p>
-
-<p>Using this from XML DSL is just as easy as you just have to set the 
shareUnitOfWork attribute to true:</p>
-<div class="code panel pdl" style="border-width: 1px;"><div class="codeContent 
panelContent pdl">
+</div></div><p>Now in this example what would happen is that in case there is 
a problem processing each sub message, the error handler will kick in (yes 
error handling still applies for the sub messages). <strong>But</strong> what 
doesn't happen is that if a sub message fails all redelivery attempts (its 
exhausted), then its <strong>not</strong> moved into that dead letter queue. 
The reason is that we have shared the unit of work, so the sub message will 
report the error on the shared unit of work. When the <a shape="rect" 
href="splitter.html">Splitter</a> is done, it checks the state of the shared 
unit of work and checks if any errors occurred. And if an error occurred it 
will set the exception on the <a shape="rect" href="exchange.html">Exchange</a> 
and mark it for rollback. The error handler will yet again kick in, as the <a 
shape="rect" href="exchange.html">Exchange</a> has been marked as rollback and 
it had an exception as well. No redelivery attempts is performed (as it was ma
 rked for rollback) and the <a shape="rect" href="exchange.html">Exchange</a> 
will be moved into the <a shape="rect" href="dead-letter-channel.html">dead 
letter queue</a>.</p><p>Using this from XML DSL is just as easy as you just 
have to set the shareUnitOfWork attribute to true:</p><div class="code panel 
pdl" style="border-width: 1px;"><div class="codeContent panelContent pdl">
 <script class="theme: Default; brush: xml; gutter: false" 
type="syntaxhighlighter"><![CDATA[
 &lt;camelContext errorHandlerRef=&quot;dlc&quot; 
xmlns=&quot;http://camel.apache.org/schema/spring&quot;&gt;
 
@@ -665,19 +462,14 @@ from(&quot;direct:line&quot;)
 
 &lt;/camelContext&gt;
 ]]></script>
-</div></div>
-
-    <div class="aui-message hint shadowed information-macro">
+</div></div>    <div class="aui-message hint shadowed information-macro">
                     <p class="title">Implementation of shared unit of work</p>
                             <span class="aui-icon icon-hint">Icon</span>
                 <div class="message-content">
-                            
-<p>So in reality the unit of work is not shared as a single object instance. 
Instead <code>SubUnitOfWork</code> is attached to their parent, and issues 
callback to the parent about their status (commit or rollback). This may be 
refactored in Camel 3.0 where larger API changes can be done.</p>
+                            <p>So in reality the unit of work is not shared as 
a single object instance. Instead <code>SubUnitOfWork</code> is attached to 
their parent, and issues callback to the parent about their status (commit or 
rollback). This may be refactored in Camel 3.0 where larger API changes can be 
done.</p>
                     </div>
     </div>
-
-
-<h4 id="Splitter-UsingThisPattern">Using This Pattern</h4>
+<p></p><h4 id="Splitter-UsingThisPattern">Using This Pattern</h4>
 
 <p>If you would like to use this EIP Pattern then please read the <a 
shape="rect" href="getting-started.html">Getting Started</a>, you may also find 
the <a shape="rect" href="architecture.html">Architecture</a> useful 
particularly the description of <a shape="rect" 
href="endpoint.html">Endpoint</a> and <a shape="rect" 
href="uris.html">URIs</a>. Then you could try out some of the <a shape="rect" 
href="examples.html">Examples</a> first before trying this pattern 
out.</p></div>
         </td>


Reply via email to