File Coverage

blib/lib/YAML/Node.pm
Criterion Covered Total %
statement 100 117 85.4
branch 28 36 77.7
condition 2 2 100.0
subroutine 23 29 79.3
pod 0 6 0.0
total 153 190 80.5


line stmt bran cond sub pod time code
1 49     49   288 use strict; use warnings;
  49     49   113  
  49         1728  
  49         230  
  49         76  
  49         2567  
2             package YAML::Node;
3              
4 49     49   21740 use YAML::Tag;
  49         183  
  49         2075  
5             require YAML::Mo;
6              
7 49     49   363 use Exporter;
  49         117  
  49         89208  
8             our @ISA = qw(Exporter YAML::Mo::Object);
9             our @EXPORT = qw(ynode);
10              
11             sub ynode {
12 1942     1942 0 2966 my $self;
13 1942 100       6280 if (ref($_[0]) eq 'HASH') {
    100          
    50          
14 891         1403 $self = tied(%{$_[0]});
  891         1966  
15             }
16             elsif (ref($_[0]) eq 'ARRAY') {
17 61         104 $self = tied(@{$_[0]});
  61         183  
18             }
19             elsif (ref(\$_[0]) eq 'GLOB') {
20 0         0 $self = tied(*{$_[0]});
  0         0  
21             }
22             else {
23 990         1637 $self = tied($_[0]);
24             }
25 1942 100       6671 return (ref($self) =~ /^yaml_/) ? $self : undef;
26             }
27              
28             sub new {
29 96     96 0 7214 my ($class, $node, $tag) = @_;
30 96         224 my $self;
31 96         266 $self->{NODE} = $node;
32 96         374 my (undef, $type) = YAML::Mo::Object->node_info($node);
33 96 50       473 $self->{KIND} = (not defined $type) ? 'scalar' :
    100          
    100          
34             ($type eq 'ARRAY') ? 'sequence' :
35             ($type eq 'HASH') ? 'mapping' :
36             $class->die("Can't create YAML::Node from '$type'");
37 96   100     440 tag($self, ($tag || ''));
38 96 100       322 if ($self->{KIND} eq 'scalar') {
39 16         97 yaml_scalar->new($self, $_[1]);
40 16         62 return \ $_[1];
41             }
42 80         251 my $package = "yaml_" . $self->{KIND};
43 80         316 $package->new($self)
44             }
45              
46 0     0 0 0 sub node { $_->{NODE} }
47 0     0 0 0 sub kind { $_->{KIND} }
48             sub tag {
49 193     193 0 542 my ($self, $value) = @_;
50 193 100       397 if (defined $value) {
51 96         456 $self->{TAG} = YAML::Tag->new($value);
52 96         255 return $self;
53             }
54             else {
55 97         387 return $self->{TAG};
56             }
57             }
58             sub keys {
59 6     6 0 11 my ($self, $value) = @_;
60 6 50       13 if (defined $value) {
61 6         17 $self->{KEYS} = $value;
62 6         117 return $self;
63             }
64             else {
65 0         0 return $self->{KEYS};
66             }
67             }
68              
69             #==============================================================================
70             package yaml_scalar;
71              
72             @yaml_scalar::ISA = qw(YAML::Node);
73              
74             sub new {
75 16     16   45 my ($class, $self) = @_;
76 16         76 tie $_[2], $class, $self;
77             }
78              
79             sub TIESCALAR {
80 16     16   42 my ($class, $self) = @_;
81 16         30 bless $self, $class;
82 16         60 $self
83             }
84              
85             sub FETCH {
86 78     78   134 my ($self) = @_;
87             $self->{NODE}
88 78         745 }
89              
90             sub STORE {
91 0     0   0 my ($self, $value) = @_;
92 0         0 $self->{NODE} = $value
93             }
94              
95             #==============================================================================
96             package yaml_sequence;
97              
98             @yaml_sequence::ISA = qw(YAML::Node);
99              
100             sub new {
101 10     10   26 my ($class, $self) = @_;
102 10         16 my $new;
103 10         50 tie @$new, $class, $self;
104 10         77 $new
105             }
106              
107             sub TIEARRAY {
108 10     10   26 my ($class, $self) = @_;
109 10         36 bless $self, $class
110             }
111              
112             sub FETCHSIZE {
113 52     52   115 my ($self) = @_;
114 52         70 scalar @{$self->{NODE}};
  52         256  
115             }
116              
117             sub FETCH {
118 36     36   58 my ($self, $index) = @_;
119 36         131 $self->{NODE}[$index]
120             }
121              
122             sub STORE {
123 0     0   0 my ($self, $index, $value) = @_;
124 0         0 $self->{NODE}[$index] = $value
125             }
126              
127             sub undone {
128 0     0   0 die "Not implemented yet"; # XXX
129             }
130              
131             *STORESIZE = *POP = *PUSH = *SHIFT = *UNSHIFT = *SPLICE = *DELETE = *EXISTS =
132             *STORESIZE = *POP = *PUSH = *SHIFT = *UNSHIFT = *SPLICE = *DELETE = *EXISTS =
133             *undone; # XXX Must implement before release
134              
135             #==============================================================================
136             package yaml_mapping;
137              
138             @yaml_mapping::ISA = qw(YAML::Node);
139              
140             sub new {
141 70     70   223 my ($class, $self) = @_;
142 70         111 @{$self->{KEYS}} = sort keys %{$self->{NODE}};
  70         259  
  70         372  
143 70         142 my $new;
144 70         303 tie %$new, $class, $self;
145 70         372 $new
146             }
147              
148             sub TIEHASH {
149 70     70   219 my ($class, $self) = @_;
150 70         249 bless $self, $class
151             }
152              
153             sub FETCH {
154 299     299   594 my ($self, $key) = @_;
155 299 100       811 if (exists $self->{NODE}{$key}) {
156 259         1127 return (grep {$_ eq $key} @{$self->{KEYS}})
  143         1654  
157 143 50       225 ? $self->{NODE}{$key} : undef;
158             }
159 156         559 return $self->{HASH}{$key};
160             }
161              
162             sub STORE {
163 75     75   178 my ($self, $key, $value) = @_;
164 75 100       226 if (exists $self->{NODE}{$key}) {
    50          
165 2         5 $self->{NODE}{$key} = $value;
166             }
167             elsif (exists $self->{HASH}{$key}) {
168 0         0 $self->{HASH}{$key} = $value;
169             }
170             else {
171 73 100       102 if (not grep {$_ eq $key} @{$self->{KEYS}}) {
  457         613  
  73         177  
172 72         91 push(@{$self->{KEYS}}, $key);
  72         178  
173             }
174 73         177 $self->{HASH}{$key} = $value;
175             }
176 75         357 $value
177             }
178              
179             sub DELETE {
180 1     1   14 my ($self, $key) = @_;
181 1         2 my $return;
182 1 50       4 if (exists $self->{NODE}{$key}) {
    0          
183 1         4 $return = $self->{NODE}{$key};
184             }
185             elsif (exists $self->{HASH}{$key}) {
186 0         0 $return = delete $self->{NODE}{$key};
187             }
188 1         3 for (my $i = 0; $i < @{$self->{KEYS}}; $i++) {
  4         12  
189 3 100       9 if ($self->{KEYS}[$i] eq $key) {
190 1         3 splice(@{$self->{KEYS}}, $i, 1);
  1         4  
191             }
192             }
193 1         28 return $return;
194             }
195              
196             sub CLEAR {
197 0     0   0 my ($self) = @_;
198 0         0 @{$self->{KEYS}} = ();
  0         0  
199 0         0 %{$self->{HASH}} = ();
  0         0  
200             }
201              
202             sub FIRSTKEY {
203 188     188   538 my ($self) = @_;
204 188         446 $self->{ITER} = 0;
205 188         825 $self->{KEYS}[0]
206             }
207              
208             sub NEXTKEY {
209 424     424   681 my ($self) = @_;
210 424         1796 $self->{KEYS}[++$self->{ITER}]
211             }
212              
213             sub EXISTS {
214 88     88   178 my ($self, $key) = @_;
215 88         329 exists $self->{NODE}{$key}
216             }
217              
218             1;