/[suikacvs]/messaging/manakai/lib/Message/DOM/ProcessingInstruction.pm
Suika

Contents of /messaging/manakai/lib/Message/DOM/ProcessingInstruction.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.3 - (show annotations) (download)
Sat Jun 16 08:05:48 2007 UTC (17 years, 5 months ago) by wakaba
Branch: MAIN
Changes since 1.2: +6 -5 lines
++ manakai/t/ChangeLog	16 Jun 2007 08:01:18 -0000
	* DOM-NodeList.t: New test.

2007-06-16  Wakaba  <wakaba@suika.fam.cx>

++ manakai/lib/Message/DOM/ChangeLog	16 Jun 2007 08:05:30 -0000
	* Attr.pm, AttributeDefinition.pm, DocumentFragment.pm,
	DocumentType.pm, Entity.pm,
	EntityReference.pm (____new): Initialize |child_nodes| by an empty list.

	* Node.pm, DOMCharacterData.pm, ElementTypeDefinition.pm,
	Notation.pm, ProcessingInstruction.pm (child_nodes): Implemetned.

	* DOMDocument.pm (AUTOLOAD): Typo fixed.

	* Node.pm (==, !=): Implemented.
	(manakai_read_only): Implemented.
	(is_same_node): Implemented.
	(is_equal_node): Alpha version.
	(manakai_set_read_only): Alpha version.
	(child_nodes, first_child, last_child, previous_sibling): Duplicate
	definitions are removed.

2007-06-16  Wakaba  <wakaba@suika.fam.cx>

1 package Message::DOM::ProcessingInstruction;
2 use strict;
3 our $VERSION=do{my @r=(q$Revision: 1.2 $=~/\d+/g);sprintf "%d."."%02d" x $#r,@r};
4 push our @ISA, 'Message::DOM::Node', 'Message::IF::ProcessingInstruction';
5 require Message::DOM::Node;
6
7 ## Spec:
8 ##
9
10 sub ____new ($$$$) {
11 my $self = shift->SUPER::____new (shift);
12 ($$self->{target}, $$self->{data}) = @_;
13 return $self;
14 } # ____new
15
16 sub AUTOLOAD {
17 my $method_name = our $AUTOLOAD;
18 $method_name =~ s/.*:://;
19 return if $method_name eq 'DESTROY';
20
21 if ({
22 ## Read-only attributes (trivial accessors)
23 target => 1,
24 data => 1,
25 }->{$method_name}) {
26 no strict 'refs';
27 eval qq{
28 sub $method_name (\$) {
29 if (\@_ > 1) {
30 require Carp;
31 Carp::croak (qq<Can't modify read-only attribute>);
32 }
33 return \${\$_[0]}->{$method_name};
34 }
35 };
36 goto &{ $AUTOLOAD };
37 } elsif ({
38 ## Read-write attributes (DOMString, trivial accessors)
39 }->{$method_name}) {
40 no strict 'refs';
41 eval qq{
42 sub $method_name (\$) {
43 if (\@_ > 1) {
44 \${\$_[0]}->{$method_name} = ''.$_[1];
45 }
46 return \${\$_[0]}->{$method_name};
47 }
48 };
49 goto &{ $AUTOLOAD };
50 } else {
51 require Carp;
52 Carp::croak (qq<Can't locate method "$AUTOLOAD">);
53 }
54 } # AUTOLOAD
55 sub target ($);
56 sub data ($);
57
58 ## The |Node| interface - attribute
59
60 sub child_nodes ($) {
61 require Message::DOM::NodeList;
62 return bless \\($_[0]), 'Message::DOM::NodeList::EmptyNodeList';
63 } # child_nodes
64
65 ## The target of the processing instruction [DOM1, DOM2].
66 ## Same as |ProcessingInstruction.target| [DOM3].
67
68 *node_name = \&target;
69
70 ## Spec:
71 ## <http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core.html#ID-111237558>
72
73 sub node_type ($) { 7 } # PROCESSING_INSTRUCTION_NODE
74
75 ## Spec:
76 ## <http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core.html#ID-F68D080>
77 ## Modified: <http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core.html#ID-1841493061>
78
79 ## The entire content exclude the target [DOM1, DOM2].
80 ## Same as |ProcessingInstruction.data| [DOM3].
81
82 *node_value = \&data;
83
84 package Message::IF::ProcessingInstruction;
85
86 package Message::DOM::Document;
87
88 ## Spec:
89 ## <http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/core.html#ID-135944439>
90 ## Compatibility note:
91 ## <http://suika.fam.cx/gate/2005/sw/createProcessingInstruction>
92
93 sub create_processing_instruction ($$$) {
94 return Message::DOM::ProcessingInstruction->____new (@_[0, 1, 2]);
95 } # create_processing_instruction
96
97 1;
98 ## License: <http://suika.fam.cx/~wakaba/archive/2004/8/18/license#Perl+MPL>
99 ## $Date: 2007/06/15 14:32:50 $

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24