NAME

XML::Filter::DataIndenter - SAX2 Indenter for data oriented XML

SYNOPSIS

use XML::Filter::DataIndenter;

use XML::SAX::Machines qw( Pipeline );

Pipeline( XML::Filter::DataIndenter => \*STDOUT );

DESCRIPTION

ALPHA CODE ALERT: This is the first release. Feedback and patches welcome.

In data oriented XML, leaf elements (those which contain no elements) contain only character content, all other elements contain only child elements and ignorable whitespace. This filter consumes all whitespace not in leaf nodes and replaces it with whitespace that indents all elements. Character data in leaf elements is left unmolested.

This filter assumes you're emitting data oriented XML. It will die if it sees non-whitespace character data outside of a leaf element. It also dies if it sees start-tag / end-tag mismatch, just as a service to the programmer.

Processing instructions and comments are indented as though they were leaf elements except when they occur in leaf elements.

Example:

This document:

<a><?A?>
<!--A--><b><?B?><!--B-->B</b>
    <!--A-->
    </a>

gets reindented as:

<a>
  <?A?>
  <!--A-->
  <b><?B?><!--B-->B</b>
  <!--A-->
</a>

(plus or minus a space in each PI, depending on your XML writer).

LIMITATIONS

Considers only [\r\n \t] to be whitespace; does not think about the broader Unicode definition of whitespace. This will be addressed when time and need permit.

COPYRIGHT

Copyright 2003, R. Barrie Slaymaker, Jr., All Rights Reserved

LICENSE

You may use this module under the terms of the BSD, Artistic, oir GPL licenses, any version.

AUTHOR

Barrie Slaymaker <barries@slaysys.com>