Mercurial > pub > Impl
diff Lib/IMPL/SQL/Schema/Constraint/PrimaryKey.pm @ 49:16ada169ca75
migrating to the Eclipse IDE
author | wizard@linux-odin.local |
---|---|
date | Fri, 26 Feb 2010 10:49:21 +0300 |
parents | 56cef8e3cda6 |
children | 76515373dac0 |
line wrap: on
line diff
--- a/Lib/IMPL/SQL/Schema/Constraint/PrimaryKey.pm Fri Feb 26 01:43:42 2010 +0300 +++ b/Lib/IMPL/SQL/Schema/Constraint/PrimaryKey.pm Fri Feb 26 10:49:21 2010 +0300 @@ -1,43 +1,43 @@ -package IMPL::SQL::Schema::Constraint::PrimaryKey; -use strict; -use base qw(IMPL::SQL::Schema::Constraint::Index); -use IMPL::Class::Property; -use IMPL::Class::Property::Direct; - -__PACKAGE__->PassThroughArgs; - -BEGIN { - public _direct property ConnectedFK => prop_get; -} - -sub CTOR { - my ($this,%args) = @_; - - $this->SUPER::CTOR(%args); - - $this->{$ConnectedFK} = {}; -} - -sub ConnectFK { - my ($this,$FK) = @_; - - UNIVERSAL::isa($FK,'IMPL::SQL::Schema::Constraint::ForeignKey') or die new Exception('Aprimary key could be connected only to a foreign key'); - not exists $this->{$ConnectedFK}->{$FK->UniqName} or die new Exception('This primary key already conneted with the specified foreing key',$FK->Name,$FK->Table->Name); - - $this->{$ConnectedFK}->{$FK->UniqName} = $FK; -} - -sub DisconnectFK { - my ($this,$FK) = @_; - - delete $this->{$ConnectedFK}->{$FK->UniqName}; -} - -sub Dispose { - my ($this) = @_; - - delete $this->{$ConnectedFK}; - $this->SUPER::Dispose; -} - -1; \ No newline at end of file +package IMPL::SQL::Schema::Constraint::PrimaryKey; +use strict; +use base qw(IMPL::SQL::Schema::Constraint::Index); +use IMPL::Class::Property; +use IMPL::Class::Property::Direct; + +__PACKAGE__->PassThroughArgs; + +BEGIN { + public _direct property ConnectedFK => prop_get; +} + +sub CTOR { + my ($this,%args) = @_; + + $this->SUPER::CTOR(%args); + + $this->{$ConnectedFK} = {}; +} + +sub ConnectFK { + my ($this,$FK) = @_; + + UNIVERSAL::isa($FK,'IMPL::SQL::Schema::Constraint::ForeignKey') or die new Exception('Aprimary key could be connected only to a foreign key'); + not exists $this->{$ConnectedFK}->{$FK->UniqName} or die new Exception('This primary key already conneted with the specified foreing key',$FK->Name,$FK->Table->Name); + + $this->{$ConnectedFK}->{$FK->UniqName} = $FK; +} + +sub DisconnectFK { + my ($this,$FK) = @_; + + delete $this->{$ConnectedFK}->{$FK->UniqName}; +} + +sub Dispose { + my ($this) = @_; + + delete $this->{$ConnectedFK}; + $this->SUPER::Dispose; +} + +1;