line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
# Copyright (c) 2009, 2010 Oleksandr Tymoshenko |
2
|
|
|
|
|
|
|
# All rights reserved. |
3
|
|
|
|
|
|
|
|
4
|
|
|
|
|
|
|
# Redistribution and use in source and binary forms, with or without |
5
|
|
|
|
|
|
|
# modification, are permitted provided that the following conditions |
6
|
|
|
|
|
|
|
# are met: |
7
|
|
|
|
|
|
|
# 1. Redistributions of source code must retain the above copyright |
8
|
|
|
|
|
|
|
# notice, this list of conditions and the following disclaimer. |
9
|
|
|
|
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright |
10
|
|
|
|
|
|
|
# notice, this list of conditions and the following disclaimer in the |
11
|
|
|
|
|
|
|
# documentation and/or other materials provided with the distribution. |
12
|
|
|
|
|
|
|
|
13
|
|
|
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND |
14
|
|
|
|
|
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
15
|
|
|
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
16
|
|
|
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE |
17
|
|
|
|
|
|
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
18
|
|
|
|
|
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS |
19
|
|
|
|
|
|
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
20
|
|
|
|
|
|
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
21
|
|
|
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |
22
|
|
|
|
|
|
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
23
|
|
|
|
|
|
|
# SUCH DAMAGE. |
24
|
|
|
|
|
|
|
package EBook::EPUB::Lite::Metadata::DCItem; |
25
|
4
|
|
|
4
|
|
20
|
use Moo; |
|
4
|
|
|
|
|
26
|
|
|
4
|
|
|
|
|
24
|
|
26
|
4
|
|
|
4
|
|
976
|
use Types::Standard qw/ArrayRef Object Str/; |
|
4
|
|
|
|
|
6
|
|
|
4
|
|
|
|
|
25
|
|
27
|
|
|
|
|
|
|
|
28
|
|
|
|
|
|
|
# |
29
|
|
|
|
|
|
|
# Helper class for DC metadata items. Just contains name, value and attributes. |
30
|
|
|
|
|
|
|
# values goes as CDATA. |
31
|
|
|
|
|
|
|
# End-user should not use this module directly |
32
|
|
|
|
|
|
|
# |
33
|
|
|
|
|
|
|
|
34
|
|
|
|
|
|
|
has name => (isa => Str, is => 'rw'); |
35
|
|
|
|
|
|
|
has value => (isa => Str, is => 'rw'); |
36
|
|
|
|
|
|
|
|
37
|
|
|
|
|
|
|
has attributes => ( |
38
|
|
|
|
|
|
|
is => 'ro', |
39
|
|
|
|
|
|
|
isa => ArrayRef[Str], |
40
|
|
|
|
|
|
|
default => sub { [] }, |
41
|
|
|
|
|
|
|
); |
42
|
|
|
|
|
|
|
sub encode |
43
|
|
|
|
|
|
|
{ |
44
|
8
|
|
|
8
|
0
|
17
|
my ($self, $writer) = @_; |
45
|
|
|
|
|
|
|
$writer->dataElement($self->name, $self->value, |
46
|
8
|
|
|
|
|
201
|
@{$self->attributes}, |
|
8
|
|
|
|
|
3462
|
|
47
|
|
|
|
|
|
|
); |
48
|
8
|
|
|
|
|
954
|
my %attr = @{$self->attributes()}; |
|
8
|
|
|
|
|
59
|
|
49
|
|
|
|
|
|
|
} |
50
|
|
|
|
|
|
|
|
51
|
|
|
|
|
|
|
# Override default - set not reference value but |
52
|
|
|
|
|
|
|
# reference content |
53
|
|
|
|
|
|
|
sub copy_attributes |
54
|
|
|
|
|
|
|
{ |
55
|
0
|
|
|
0
|
0
|
|
my ($self, $ref) = @_; |
56
|
0
|
|
|
|
|
|
@{$self->attributes()} = @{$ref}; |
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
57
|
|
|
|
|
|
|
} |
58
|
|
|
|
|
|
|
|
59
|
|
|
|
|
|
|
1; |