Mercurial > pub > Impl
view Lib/Schema/DB/Constraint/PrimaryKey.pm @ 167:1f7a6d762394
SQL schema in progress
author | sourcer |
---|---|
date | Thu, 12 May 2011 08:57:19 +0400 |
parents | 4267a2ac3d46 |
children |
line wrap: on
line source
package Schema::DB::Constraint::PrimaryKey; use strict; use Common; use parent qw(Schema::DB::Constraint::Index); BEGIN { DeclareProperty ConnectedFK => ACCESS_READ; } sub CTOR { my ($this,%args) = @_; $this->SUPER::CTOR(%args); $this->{$ConnectedFK} = {}; } sub ConnectFK { my ($this,$FK) = @_; UNIVERSAL::isa($FK,'Schema::DB::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;