1 |
=head1 NAME |
2 |
|
3 |
Whatpm::ContentChecker - DOM Conformance Checker |
4 |
|
5 |
=head1 SYNOPSIS |
6 |
|
7 |
use Whatpm::ContentChecker; |
8 |
|
9 |
Whatpm::ContentChecker->check_document ($doc, sub { |
10 |
my %arg = @_; |
11 |
warn get_node_path ($arg{node}), ": ", |
12 |
($arg{level} || "Error"), ": ", |
13 |
$arg{type}, "\n"; |
14 |
}); |
15 |
|
16 |
Whatpm::ContentChecker->check_element ($doc, sub { |
17 |
my %arg = @_; |
18 |
warn get_node_path ($arg{node}), ": ", |
19 |
($arg{level} || "Error"), ": ", |
20 |
$arg{type}, "\n"; |
21 |
}); |
22 |
|
23 |
=head1 DESCRIPTION |
24 |
|
25 |
The C<Whatpm::ContentChecker> Perl module contains two methods |
26 |
to validate DOM tree for its conformance to the markup language |
27 |
in use. |
28 |
|
29 |
This module is part of Whatpm, Perl Modules for |
30 |
Web Hypertext Application Technologies, which is a subproject |
31 |
of manakai. |
32 |
|
33 |
=head1 METHODS |
34 |
|
35 |
This module contains two static methods: |
36 |
|
37 |
=over 4 |
38 |
|
39 |
=item Whatpm::ContentChecker->check_document (I<$document>, I<$onerror>); |
40 |
|
41 |
Checks a document, I<$document>, and its descendant for their |
42 |
conformance. If there is an error or a warnign, then the |
43 |
I<$onerror> C<CODE> is invoked with named arguments same |
44 |
as ones for the method C<check_element>. |
45 |
|
46 |
=item Whatpm::ContentChecker->check_element (I<$element>, I<$onerror>); |
47 |
|
48 |
Checks an element, I<$element>, and its descendant for their conformance. |
49 |
If there is an error or a warning, then the I<$onerror> C<CODE> |
50 |
is invoked with named arguments: |
51 |
|
52 |
=over 4 |
53 |
|
54 |
=item level (Might be C<undef>) |
55 |
|
56 |
A string which describes the severity of the error or warning. |
57 |
For the list of the severities, see |
58 |
<http://suika.fam.cx/gate/2005/sw/Whatpm%20Error%20Types>. |
59 |
|
60 |
=item node (Always specified) |
61 |
|
62 |
The node with which the error is detected. |
63 |
|
64 |
=item type (Always specified) |
65 |
|
66 |
A string which describes the type of the error or warning. |
67 |
For the list of the errors and warnings, see |
68 |
<http://suika.fam.cx/gate/2005/sw/Whatpm%20Error%20Types>. |
69 |
|
70 |
=back |
71 |
|
72 |
=back |
73 |
|
74 |
=head1 BUGS |
75 |
|
76 |
This conformance checker is work in progress; it I<might> not be |
77 |
able to detect all the errors in the DOM tree, and it I<might> |
78 |
detect an error for a node that is conforming in fact. |
79 |
|
80 |
=head1 NOTES ON IMPLEMENTATION DETAILS |
81 |
|
82 |
I<This section is not complete.> |
83 |
|
84 |
This section describes various internal constructions used in |
85 |
L<Whatpm::ContentChecker> and relevant modules. These data structures |
86 |
are not public interfaces -- they should not be accessed or modified |
87 |
by applications. They are documented here for the convenience of |
88 |
development only. |
89 |
|
90 |
=head2 The C<< $self->{flag} >> Structure |
91 |
|
92 |
=over 4 |
93 |
|
94 |
=item C<< $self->{flag}->{has_label} >> |
95 |
|
96 |
This flag is set to a true value if and only if there is a C<label> |
97 |
element ancestor of the current node. |
98 |
|
99 |
=item C<< $self->{flag}->{has_labelable} >> |
100 |
|
101 |
This flag is set to C<1> if and only if a nearest ancestor C<label> |
102 |
element has the C<for> attribute and there is no labelable |
103 |
form-associated element that is a descendant of the C<label> element |
104 |
and precedes the current node in tree order. This flag is set to C<2> |
105 |
if and only if there is a labelable form-associated element that is a |
106 |
descendant of the nearest ancestor C<label> element of the current |
107 |
node and precedes the current node in tree order. This flag is |
108 |
otherwise set to a false value. B<However>, when there is no ancestor |
109 |
C<label> element of the current node, i.e. when |
110 |
C<< $self->{flag}->{has_label} >> is false, the value of the |
111 |
C<< $self->{flag}->{has_labelable} >> flag is I<undefined>. |
112 |
|
113 |
=back |
114 |
|
115 |
=head2 The C<$element_state> Structure |
116 |
|
117 |
=over 4 |
118 |
|
119 |
=item C<< $element_state->{has_label_original} >> |
120 |
|
121 |
Used to preserve the value of C<< $self->{flag}->{has_label} >> at the |
122 |
time of invocation of the method C<element_start> for the element |
123 |
being checked. |
124 |
|
125 |
=item C<< $element_state->{has_labelable_original} >> |
126 |
|
127 |
Used to preserve the value of C<< $self->{flag}->{has_labelable} >> at |
128 |
the time of invocation of the method C<element_start> for the element |
129 |
being checked. |
130 |
|
131 |
=back |
132 |
|
133 |
=head1 SEE ALSO |
134 |
|
135 |
L<Whatpm::ContentChecker::Atom> |
136 |
|
137 |
L<Whatpm::ContentChecker::HTML> |
138 |
|
139 |
<http://suika.fam.cx/gate/2005/sw/Whatpm%20Error%20Types> |
140 |
|
141 |
=head1 AUTHOR |
142 |
|
143 |
Wakaba <w@suika.fam.cx> |
144 |
|
145 |
=head1 LICENSE |
146 |
|
147 |
Copyright 2007-2008 Wakaba <w@suika.fam.cx> |
148 |
|
149 |
This library is free software; you can redistribute it |
150 |
and/or modify it under the same terms as Perl itself. |
151 |
|
152 |
=cut |
153 |
|
154 |
# $Date: 2007/08/06 10:56:50 $ |