@@ -804,7 +1093,7 @@
my $euri = htescape ($input->{uri});
print STDOUT qq[
-
+
];
- push @nav, ['#parse-errors' => 'Errors'];
+ push @nav, [qq[#$input->{id_prefix}parse-errors] => 'Errors']
+ unless $input->{nested};
add_error (char => {level => 'u'} => $result);
add_error (syntax => {level => 'u'} => $result);
add_error (structure => {level => 'u'} => $result);
@@ -836,23 +1126,56 @@
my $r = '';
- if (defined $err->{line}) {
- if ($err->{column} > 0) {
- $r = qq[
Line $err->{line} column $err->{column}];
+ my $line;
+ my $column;
+
+ if (defined $err->{node}) {
+ $line = $err->{node}->get_user_data ('manakai_source_line');
+ if (defined $line) {
+ $column = $err->{node}->get_user_data ('manakai_source_column');
} else {
- $err->{line} = $err->{line} - 1 || 1;
- $r = qq[
Line $err->{line}];
+ if ($err->{node}->node_type == $err->{node}->ATTRIBUTE_NODE) {
+ my $owner = $err->{node}->owner_element;
+ $line = $owner->get_user_data ('manakai_source_line');
+ $column = $owner->get_user_data ('manakai_source_column');
+ } else {
+ my $parent = $err->{node}->parent_node;
+ $line = $parent->get_user_data ('manakai_source_line');
+ $column = $parent->get_user_data ('manakai_source_column');
+ }
+ }
+ }
+ unless (defined $line) {
+ if (defined $err->{token} and defined $err->{token}->{line}) {
+ $line = $err->{token}->{line};
+ $column = $err->{token}->{column};
+ } elsif (defined $err->{line}) {
+ $line = $err->{line};
+ $column = $err->{column};
+ }
+ }
+
+ if (defined $line) {
+ if (defined $column and $column > 0) {
+ $r = qq[
Line $line column $column];
+ } else {
+ $line = $line - 1 || 1;
+ $r = qq[
Line $line];
}
}
if (defined $err->{node}) {
$r .= ' ' if length $r;
- $r = get_node_link ($input, $err->{node});
+ $r .= get_node_link ($input, $err->{node});
}
if (defined $err->{index}) {
- $r .= ' ' if length $r;
- $r .= 'Index ' . (0+$err->{index});
+ if (length $r) {
+ $r .= ', Index ' . (0+$err->{index});
+ } else {
+ $r .= "
Index "
+ . (0+$err->{index}) . '';
+ }
}
if (defined $err->{value}) {
@@ -880,6 +1203,8 @@
} elsif ($err->{level} eq 'u' or $err->{level} eq 'unsupported') {
$r = qq[
Not
supported: ];
+ } elsif ($err->{level} eq 'i') {
+ $r = qq[
Information: ];
} else {
my $elevel = htescape ($err->{level});
$r = qq[
$elevel:
@@ -1124,6 +1449,8 @@
return $r;
}
+ $r->{inner_html_element} = $http->get_parameter ('e');
+
return $r;
} # get_input_document
@@ -1156,11 +1483,11 @@
=head1 LICENSE
-Copyright 2007 Wakaba
+Copyright 2007-2008 Wakaba
This library is free software; you can redistribute it
and/or modify it under the same terms as Perl itself.
=cut
-## $Date: 2008/02/10 03:11:06 $
+## $Date: 2008/03/17 13:45:35 $