/usr/share/perl5/KiokuDB/TypeMap/Entry/Naive.pm is in libkiokudb-perl 0.57-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 | package KiokuDB::TypeMap::Entry::Naive;
BEGIN {
$KiokuDB::TypeMap::Entry::Naive::AUTHORITY = 'cpan:NUFFIN';
}
$KiokuDB::TypeMap::Entry::Naive::VERSION = '0.57';
use Moose;
# ABSTRACT: A typemap entry for "simple" objects
no warnings 'recursion';
use namespace::clean -except => 'meta';
with qw(KiokuDB::TypeMap::Entry::Std);
sub compile_collapse_body {
my ( $self, $class ) = @_;
return sub {
my ( $self, %args ) = @_;
my $object = $args{object};
return $self->make_entry(
%args,
data => $self->visit_ref_data($object),
);
};
}
sub compile_expand {
my ( $self, $class ) = @_;
return sub {
my ( $self, $entry ) = @_;
$self->inflate_data( $entry->data, \( my $obj ), $entry );
bless $obj, $class;
};
}
sub compile_refresh { return sub { die "TODO" } }
__PACKAGE__->meta->make_immutable;
__PACKAGE__
__END__
=pod
=encoding UTF-8
=head1 NAME
KiokuDB::TypeMap::Entry::Naive - A typemap entry for "simple" objects
=head1 VERSION
version 0.57
=head1 SYNOPSIS
KiokuDB::TypeMap->new(
entires => {
'My::Class' => KiokuDB::TypeMap::Entry::Naive->new,
},
);
=head1 DESCRIPTION
This typemap entry is suitable for plain objects that can be stored by simply
walking them recursively.
Most objects fall into this category, but there are notable exceptions:
=over 4
=item XS based objects, using a pointer as a number
When being deserialized the pointer value will no longer be valid, causing
segfaults.
=item Inside out objects
Since the referent is really a flyweight object with no data, the object will
be missing its attributes and a suitable typemap entry is required instead.
This applies to any object interacting with a global state of some sort.
=item Objects with magic
Perl SV level magic is not retained, apart from tied values.
=back
=head1 ATTRIBUTES
=over 4
=item intrinsic
If true the object will be collapsed without an ID as part of its parent.
=back
=head1 AUTHOR
Yuval Kogman <nothingmuch@woobling.org>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Yuval Kogman, Infinity Interactive.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
|