annotate Lib/IMPL/lang.pm @ 173:aaab45153411

minor bugfixes
author sourcer
date Wed, 14 Sep 2011 18:59:01 +0400
parents fd92830036c3
children d920d2b70230
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
164
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
1 package IMPL::lang;
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
2 use strict;
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
3 use warnings;
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
4
165
76515373dac0 Added Class::Template,
wizard
parents: 164
diff changeset
5 use parent qw(Exporter);
164
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
6 use IMPL::_core::version;
173
aaab45153411 minor bugfixes
sourcer
parents: 169
diff changeset
7 use IMPL::clone qw(clone);
164
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
8
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
9 require IMPL::Class::PropertyInfo;
164
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
10
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
11 our @EXPORT = qw(&is);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
12 our %EXPORT_TAGS = (
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
13 base => [
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
14 qw(
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
15 &is
173
aaab45153411 minor bugfixes
sourcer
parents: 169
diff changeset
16 &clone
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
17 )
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
18 ],
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
19 constants => [
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
20 qw(
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
21 &ACCESS_PUBLIC
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
22 &ACCESS_PROTECTED
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
23 &ACCESS_PRIVATE
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
24 &PROP_GET
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
25 &PROP_SET
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
26 &PROP_OWNERSET
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
27 &PROP_LIST
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
28 &PROP_ALL
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
29 )
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
30 ],
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
31
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
32 declare => [
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
33 qw(
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
34 &public
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
35 &protected
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
36 &private
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
37 &virtual
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
38 &property
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
39 &static
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
40 &property
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
41 )
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
42 ],
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
43 compare => [
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
44 qw(
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
45 &equals
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
46 &equals_s
168
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
47 &hashCompare
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
48 )
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
49 ],
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
50 hash => [
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
51 qw(
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
52 &hashApply
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
53 &hashMerge
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
54 &hashDiff
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
55 &hashCompare
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
56 )
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
57 ]
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
58 );
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
59
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
60 our @EXPORT_OK = keys %{ { map (($_,1) , map (@{$_}, values %EXPORT_TAGS) ) } };
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
61
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
62 use constant {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
63 ACCESS_PUBLIC => 1,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
64 ACCESS_PROTECTED => 2,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
65 ACCESS_PRIVATE => 3,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
66 PROP_GET => 1,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
67 PROP_SET => 2,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
68 PROP_OWNERSET => 10,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
69 PROP_LIST => 4,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
70 PROP_ALL => 3
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
71 };
164
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
72
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
73 sub is($$) {
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
74 eval { $_[0]->isa( $_[1] ) };
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
75 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
76
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
77 sub virtual($) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
78 $_[0]->Virtual(1);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
79 $_[0];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
80 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
81
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
82 sub public($) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
83 $_[0]->Access(ACCESS_PUBLIC);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
84 $_[0]->Implement;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
85 $_[0];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
86 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
87
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
88 sub private($) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
89 $_[0]->Access(ACCESS_PRIVATE);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
90 $_[0]->Implement;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
91 $_[0];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
92 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
93
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
94 sub protected($) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
95 $_[0]->Access(ACCESS_PROTECTED);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
96 $_[0]->Implement;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
97 $_[0];
164
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
98 }
eb3e9861a761 SQL traits in progress
wizard
parents:
diff changeset
99
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
100 sub property($$;$) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
101 my ( $propName, $mutators, $attributes ) = @_;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
102 my $Info = new IMPL::Class::PropertyInfo(
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
103 {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
104 Name => $propName,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
105 Mutators => $mutators,
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
106 Class => scalar(caller),
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
107 Attributes => $attributes
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
108 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
109 );
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
110 return $Info;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
111 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
112
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
113 sub static($$) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
114 my ( $name, $value ) = @_;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
115 my $class = caller;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
116 $class->static_accessor( $name, $value );
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
117 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
118
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
119 sub equals {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
120 if (defined $_[0]) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
121 return 0 if (not defined $_[1]);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
122
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
123 return $_[0] == $_[1];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
124 } else {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
125 return 0 if defined $_[1];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
126
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
127 return 1;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
128 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
129 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
130
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
131 sub equals_s {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
132 if (defined $_[0]) {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
133 return 0 if (not defined $_[1]);
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
134
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
135 return $_[0] eq $_[1];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
136 } else {
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
137 return 0 if defined $_[1];
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
138
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
139 return 1;
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
140 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
141 }
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
142
168
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
143 sub hashDiff {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
144 my ($src,$dst) = @_;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
145
169
fd92830036c3 corrected IMPL::SQL::Schema::Diff
sourcer
parents: 168
diff changeset
146 $dst = $dst ? { %$dst } : {} ;
fd92830036c3 corrected IMPL::SQL::Schema::Diff
sourcer
parents: 168
diff changeset
147 $src ||= {};
168
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
148
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
149 my %result;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
150
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
151 foreach my $key ( keys %$src ) {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
152 if (exists $dst->{$key}) {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
153 $result{"+$key"} = $dst->{$key} unless equals_s($dst->{$key}, $src->{$key});
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
154 delete $dst->{$key};
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
155 } else {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
156 $result{"-$key"} = 1;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
157 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
158 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
159
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
160 $result{"+$_"} = $dst->{$_} foreach keys %$dst;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
161
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
162 return \%result;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
163 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
164
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
165 sub hashMerge {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
166 return hashApply( { %{$_[0]} }, $_[1] );
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
167 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
168
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
169 sub hashApply {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
170 my ($target,$diff) = @_;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
171
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
172 while ( my ($key,$value) = each %$diff) {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
173 $key =~ /^(\+|-)?(.*)$/;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
174 my $op = $1 || '+';
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
175 $key = $2;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
176
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
177 if ($op eq '-') {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
178 delete $target->{$key};
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
179 } else {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
180 $target->{$key} = $value;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
181 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
182 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
183
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
184 return $target;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
185 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
186
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
187 sub hashCompare {
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
188 my ($l,$r,$cmp) = @_;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
189
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
190 $cmp ||= \&equals_s;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
191
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
192 return 0 unless scalar keys %$l == scalar keys %$r;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
193 &$cmp($l->{$_},$r->{$_}) || return 0 foreach keys %$l;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
194
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
195 return 1;
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
196 }
6148f89bb7bf IMPL::SQL::Schema::Traits::Diff alfa version
sourcer
parents: 167
diff changeset
197
167
1f7a6d762394 SQL schema in progress
sourcer
parents: 165
diff changeset
198 1;