package Whatpm::HTML::Dumper;
use strict;
our $VERSION=do{my @r=(q$Revision: 1.3 $=~/\d+/g);sprintf "%d."."%02d" x $#r,@r};
require Exporter;
push our @ISA, 'Exporter';
our @EXPORT = qw(dumptree);
sub dumptree ($) {
my $node = shift;
my $r = '';
my $ns_id = {
q => 'html',
q => 'svg',
q => 'math',
q => 'xlink',
q => 'xml',
q => 'xmlns',
};
my @node = map { [$_, ''] } @{$node->child_nodes};
while (@node) {
my $child = shift @node;
my $nt = $child->[0]->node_type;
if ($nt == $child->[0]->ELEMENT_NODE) {
my $ns = $child->[0]->namespace_uri;
unless (defined $ns) {
$ns = '{} ';
} elsif ($ns eq q) {
$ns = '';
} elsif ($ns_id->{$ns}) {
$ns = $ns_id->{$ns} . ' ';
} else {
$ns = '{' . $ns . '} ';
}
$r .= $child->[1] . '<' . $ns . $child->[0]->manakai_local_name . ">\x0A";
for my $attr (sort {$a->[0] cmp $b->[0]} map { [do {
my $ns = $_->namespace_uri;
unless (defined $ns) {
$ns = '';
} elsif ($ns_id->{$ns}) {
$ns = $ns_id->{$ns} . ' ';
} else {
$ns = '{' . $ns . '} ';
}
$ns . $_->manakai_local_name;
}, $_->value] }
@{$child->[0]->attributes}) {
$r .= $child->[1] . ' ' . $attr->[0] . '="'; ## ISSUE: case?
$r .= $attr->[1] . '"' . "\x0A";
}
unshift @node,
map { [$_, $child->[1] . ' '] } @{$child->[0]->child_nodes};
} elsif ($nt == $child->[0]->TEXT_NODE) {
$r .= $child->[1] . '"' . $child->[0]->data . '"' . "\x0A";
} elsif ($nt == $child->[0]->COMMENT_NODE) {
$r .= $child->[1] . '\x0A";
} elsif ($nt == $child->[0]->DOCUMENT_TYPE_NODE) {
$r .= $child->[1] . '[0]->name;
my $pubid = $child->[0]->public_id;
my $sysid = $child->[0]->system_id;
if (length $pubid or length $sysid) {
$r .= ' "' . $pubid . '"';
$r .= ' "' . $sysid . '"';
}
$r .= ">\x0A";
unshift @node,
map { [$_, $child->[1] . ' '] }
sort { $a->node_name cmp $b->node_name }
values %{$child->[0]->element_types};
unshift @node,
map { [$_, $child->[1] . ' '] }
sort { $a->node_name cmp $b->node_name }
values %{$child->[0]->entities};
unshift @node,
map { [$_, $child->[1] . ' '] }
sort { $a->node_name cmp $b->node_name }
values %{$child->[0]->notations};
unshift @node,
map { [$_, $child->[1] . ' '] } @{$child->[0]->child_nodes};
} elsif ($nt == $child->[0]->PROCESSING_INSTRUCTION_NODE) {
$r .= $child->[1] . '' . $child->[0]->target . ' ';
$r .= $child->[0]->data . "?>\x0A";
} elsif ($nt == $child->[0]->ENTITY_NODE) {
$r .= $child->[1] . '[0]->node_name . ' "';
$r .= $child->[0]->public_id if defined $child->[0]->public_id;
$r .= '" "';
$r .= $child->[0]->system_id if defined $child->[0]->system_id;
$r .= '" ';
$r .= $child->[0]->notation_name if defined $child->[0]->notation_name;
$r .= ">\x0A";
unshift @node,
map { [$_, $child->[1] . ' '] } @{$child->[0]->child_nodes};
} elsif ($nt == $child->[0]->NOTATION_NODE) {
$r .= $child->[1] . '[0]->node_name . ' "';
$r .= $child->[0]->public_id if defined $child->[0]->public_id;
$r .= '" "';
$r .= $child->[0]->system_id if defined $child->[0]->system_id;
$r .= qq[">\x0A];
} elsif ($nt == $child->[0]->ELEMENT_TYPE_DEFINITION_NODE) {
$r .= $child->[1] . '[0]->node_name . ' ';
$r .= $child->[0]->content_model_text;
$r .= ">\x0A";
unshift @node,
map { [$_, $child->[1] . ' '] }
sort { $a->node_name cmp $b->node_name }
values %{$child->[0]->attribute_definitions};
} elsif ($nt == $child->[0]->ATTRIBUTE_DEFINITION_NODE) {
$r .= $child->[1] . $child->[0]->node_name . ' ';
$r .= [
0, 'CDATA', 'ID', 'IDREF', 'IDREFS', 'ENTITY', 'ENTITIES',
'NMTOKEN', 'NMTOKENS', 'NOTATION', 'ENUMERATION', 11,
]->[$child->[0]->declared_type] || $child->[0]->declared_type;
if ($child->[0]->declared_type == 9 or
$child->[0]->declared_type == 10) {
$r .= '(' . join ('|', @{$child->[0]->allowed_tokens}) . ')';
}
$r .= ' ';
$r .= [
0, 'FIXED', 'REQUIRED', 'IMPLIED', 'EXPLICIT',
]->[$child->[0]->default_type] || $child->[0]->default_type;
if ($child->[0]->default_type == 1 or
$child->[0]->default_type == 4) {
$r .= ' "' . $child->[0]->text_content . '"';
}
$r .= "\x0A";
} else {
$r .= $child->[1] . $child->[0]->node_type . "\x0A"; # error
}
}
return $r;
} # dumptree
## NOTE: Based on .
## TDOO: Document
1;
## $Date: 2008/10/17 07:14:29 $