I have a question regarding unexpected leading spaces got injected into a parse tree node.
 
Here is my grammar:
 
Text = leaf_node_d[+digit_p] >> root_node_d[ch_p('=')] >> leaf_node_d[+digit_p];
 
If I parse "5=5", as expected no extra leading spaces added to the resulting tree nodes.
 
If I parse "5=     5" (read:5 followed by = followed by 4 spaces and followed by 5), given my grammar definition of leaf_node_d[+digit_p], I am expecting the parse tree node value should not contain any leading spaces.
Yet, I see that the extra 4 spaces is stored in the corresponding parse tree node as shown below.
 
<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE parsetree SYSTEM "parsetree.dtd">
<!-- 5=  5 -->
<parsetree version="1.0">
    <parsenode>
        <parsenode>
            <value>5</value>
        </parsenode>
        <parsenode>
            <value is_root="1">=</value>
        </parsenode>
        <parsenode>
==>       <value>     5</value>
        </parsenode>
    </parsenode>
</parsetree>

I am wondering if this is a by design or unexpected behavior. If it is a by design behavior, is there a way to trim leading/trailing spaces.
 
Thanks!
 
 


Your E-mail and More On-the-Go. Get Windows Live Hotmail Free. Sign up now.

Hotmail: Powerful Free email with security by Microsoft. Get it now.