xml::grove::asstring(3)

NAME

XML::Grove::AsString - output content of XML objects as a
string

SYNOPSIS

use XML::Grove::AsString;
$string = $xml_object->as_string OPTIONS;
$string = $element->attr_as_string $attr, OPTIONS;
$writer = new XML::Grove::AsString OPTIONS;
# OPTIONS
$writer->filter([ callback ]);
$writer->entity_map([ callback ]);
$writer->entity_map([ $mapper ]);
$writer->entity_map_options([ options ]);
$writer->entity_map_filter([ $bool ]);
$string = $writer->as_string($xml_object);
$writer->as_string($xml_object, $file_handle);

DESCRIPTION

Calling `"as_string"' on an XML object returns the charac
ter data contents of that object as a string, including
all elements below that object. Calling
`"attr_as_string"' on an element returns the contents of
the named attribute as a string. Comments, processing
instructions, and, by default, entities all return an
empty string.

OPTIONS may either be a key-value list or a hash contain ing the options described below. The default options are
no filtering and entities are mapped to empty strings.

OPTIONS

This list summarizes the options available for
`"as_string"':
filter => sub to filter character data
entity_map => an object or sub to map character enti
ties
entity_map_options => options passed to entity_map
entity_map_filter => true to use filter on mapped en
tities
`"filter"' is an anonymous sub that gets called to process
character data before it is appended to the string to be
returned. This can be used, for example, to escape char
acters that are special in output formats.
`"entity_map_filter"' is a flag to indicate if mapped
entities should be filtered after mapping. `"filter"' is
called like this:

$string = &$filter ($character_data);
`"entity_map"' is an object that accepts `"lookup"' meth
ods or an anonymous sub that gets called with the entity
replacement text (data) and mapper options as arguments
and returns the corresponding character replacements. It
is called like this:

$replacement_text = $entity_map->lookup ($entity_data,
$enti
ty_map_options);
or this:

$replacement_text = &$entity_map ($entity_data,
$entity_map_op
tions);
`"entity_map_options"' is passed through to the `"lookup"'
method, the type of value is defined by the entity mapping
package or the anonymous sub.

EXAMPLES

Here is an example of entity mapping using the Text::Enti
tyMap module:
use Text::EntityMap;
use XML::Grove::AsString;
$html_iso_dia = Text::EntityMap->load ('ISO
dia.2html');
$html_iso_pub = Text::EntityMap->load ('ISOp
ub.2html');
$html_map = Text::EntityMap->group ($html_iso_dia,
$html_iso_pub);
$element->as_string (entity_map => $html_map);

AUTHOR

Ken MacLeod, ken@bitsko.slc.ut.us

SEE ALSO

perl(1), XML::Parser(3), XML::Parser::Grove(3).

Extensible Markup Language (XML) <http://www.w3c.org/XML>
Copyright © 2010-2025 Platon Technologies, s.r.o.           Index | Man stránky | tLDP | Dokumenty | Utilitky | O projekte
Design by styleshout