Mercurial > pub > Impl
comparison Lib/IMPL/SQL/Schema/Constraint.pm @ 32:56cef8e3cda6
+1
author | Sergey |
---|---|
date | Mon, 09 Nov 2009 01:39:31 +0300 |
parents | |
children | 0004faa276dc |
comparison
equal
deleted
inserted
replaced
31:d59526f6310e | 32:56cef8e3cda6 |
---|---|
1 use strict; | |
2 package IMPL::SQL::Schema::Constraint; | |
3 use base qw(IMPL::Object IMPL::Object::Disposable); | |
4 | |
5 use IMPL::Class::Property; | |
6 use IMPL::Class::Property::Direct; | |
7 | |
8 BEGIN { | |
9 public _direct property Name => prop_get; | |
10 public _direct property Table => prop_get; | |
11 public _direct property Columns => prop_get; | |
12 } | |
13 | |
14 sub CTOR { | |
15 my ($this,%args) = @_; | |
16 die new IMPL::InvalidArgumentException("The table argument must be an instance of a table object") if not UNIVERSAL::isa($args{'Table'},'IMPL::SQL::Schema::Table'); | |
17 $this->{$Name} = $args{'Name'}; | |
18 $this->{$Table} = $args{'Table'}; | |
19 $this->{$Columns} = [map { ResolveColumn($this->Table,$_) } @{$args{'Columns'}}]; | |
20 } | |
21 | |
22 sub ResolveColumn { | |
23 my ($Table,$Column) = @_; | |
24 | |
25 my $cn = UNIVERSAL::isa($Column,'IMPL::SQL::Schema::Column') ? $Column->Name : $Column; | |
26 | |
27 my $resolved = $Table->Column($cn); | |
28 die new IMPL::InvalidOperationException("The column is not found in the table", $cn, $Table->Name) if not $resolved; | |
29 return $resolved; | |
30 } | |
31 | |
32 sub HasColumn { | |
33 my ($this,@Columns) = @_; | |
34 | |
35 my %Columns = map { $_, 1} @Columns; | |
36 | |
37 return scalar(grep { $Columns{$_->Name} } $this->Columns) == scalar(@Columns); | |
38 } | |
39 | |
40 sub UniqName { | |
41 my ($this) = @_; | |
42 return $this->{$Table}->Name.'_'.$this->{$Name}; | |
43 } | |
44 | |
45 sub Dispose { | |
46 my ($this) = @_; | |
47 | |
48 delete @$this{$Table,$Columns}; | |
49 $this->SUPER::Dispose; | |
50 } | |
51 1; |