Commit | Line | Data |
aec3eff1 |
1 | package DBIx::Class::ResultSourceHandle; |
2 | |
3 | use strict; |
4 | use warnings; |
5 | use Storable; |
3a81f59b |
6 | use Carp; |
aec3eff1 |
7 | |
8 | use base qw/DBIx::Class/; |
9 | |
10 | use overload |
5f946071 |
11 | # on some RH perls the following line causes serious performance problem |
12 | # see https://bugzilla.redhat.com/show_bug.cgi?id=196836 |
3441fd57 |
13 | q/""/ => sub { __PACKAGE__ . ":" . shift->source_moniker; }, |
aec3eff1 |
14 | fallback => 1; |
15 | |
3441fd57 |
16 | __PACKAGE__->mk_group_accessors('simple' => qw/schema source_moniker/); |
aec3eff1 |
17 | |
4146e3da |
18 | # Schema to use when thawing. |
19 | our $thaw_schema; |
20 | |
aec3eff1 |
21 | =head1 NAME |
22 | |
b24d86a1 |
23 | DBIx::Class::ResultSourceHandle - Decouple Rows/ResultSets objects from their Source objects |
aec3eff1 |
24 | |
25 | =head1 DESCRIPTION |
26 | |
27 | This module removes fixed link between Rows/ResultSets and the actual source |
28 | objects, which gets round the following problems |
29 | |
30 | =over 4 |
31 | |
32 | =item * |
33 | |
34 | Needing to keep C<$schema> in scope, since any objects/result_sets |
35 | will have a C<$schema> object through their source handle |
36 | |
37 | =item * |
38 | |
39 | Large output when using Data::Dump(er) since this class can be set to |
40 | stringify to almost nothing |
41 | |
42 | =item * |
43 | |
7137528d |
44 | Closer to being able to do a Serialize::Storable that doesn't require class-based connections |
aec3eff1 |
45 | |
46 | =back |
47 | |
48 | =head1 METHODS |
49 | |
50 | =head2 new |
51 | |
52 | =cut |
53 | |
54 | sub new { |
55 | my ($class, $data) = @_; |
56 | |
57 | $class = ref $class if ref $class; |
58 | |
59 | bless $data, $class; |
60 | } |
61 | |
62 | =head2 resolve |
63 | |
3441fd57 |
64 | Resolve the moniker into the actual ResultSource object |
aec3eff1 |
65 | |
66 | =cut |
67 | |
3441fd57 |
68 | sub resolve { return $_[0]->schema->source($_[0]->source_moniker) } |
aec3eff1 |
69 | |
7137528d |
70 | =head2 STORABLE_freeze |
71 | |
72 | Freezes a handle. |
73 | |
74 | =cut |
75 | |
aec3eff1 |
76 | sub STORABLE_freeze { |
77 | my ($self, $cloning) = @_; |
4146e3da |
78 | |
aec3eff1 |
79 | my $to_serialize = { %$self }; |
d4daee7b |
80 | |
3a81f59b |
81 | my $class = $self->schema->class($self->source_moniker); |
82 | $to_serialize->{schema} = $class; |
aec3eff1 |
83 | return (Storable::freeze($to_serialize)); |
84 | } |
85 | |
7137528d |
86 | =head2 STORABLE_thaw |
87 | |
4146e3da |
88 | Thaws frozen handle. Resets the internal schema reference to the package |
89 | variable C<$thaw_schema>. The recomened way of setting this is to use |
323e0bd0 |
90 | C<< $schema->thaw($ice) >> which handles this for you. |
7137528d |
91 | |
92 | =cut |
93 | |
4146e3da |
94 | |
aec3eff1 |
95 | sub STORABLE_thaw { |
96 | my ($self, $cloning,$ice) = @_; |
97 | %$self = %{ Storable::thaw($ice) }; |
3a81f59b |
98 | |
99 | my $class = delete $self->{schema}; |
100 | if( $thaw_schema ) { |
101 | $self->{schema} = $thaw_schema; |
102 | } |
103 | else { |
104 | my $rs = $class->result_source_instance; |
105 | $self->{schema} = $rs->schema if $rs; |
106 | } |
107 | |
108 | carp "Unable to restore schema" unless $self->{schema}; |
aec3eff1 |
109 | } |
110 | |
4146e3da |
111 | =head1 AUTHOR |
112 | |
113 | Ash Berlin C<< <ash@cpan.org> >> |
114 | |
115 | =cut |
116 | |
aec3eff1 |
117 | 1; |