changeset 312:75a78cbf7dcf

View refactoring: INIT blocks are deprecated
author cin
date Mon, 29 Apr 2013 01:10:42 +0400 (2013-04-28)
parents d3b5a67ad2e8
children ec4ec1f056fe
files Lib/IMPL/Object/Singleton.pm Lib/IMPL/Web/View/TTFactory.pm
diffstat 2 files changed, 13 insertions(+), 33 deletions(-) [+]
line wrap: on
line diff
--- a/Lib/IMPL/Object/Singleton.pm	Mon Apr 22 03:42:53 2013 +0400
+++ b/Lib/IMPL/Object/Singleton.pm	Mon Apr 29 01:10:42 2013 +0400
@@ -9,11 +9,12 @@
 
 __PACKAGE__->static_accessor_own(_instance => undef);
 
-my %instances;
-
-sub CTOR {
-    die IMPL::InvalidOperationException->new("Only one instance of the singleton can be created",ref $_[0])
-        if $_[0]->_instance;
+sub InitInstance {
+    my $self = shift;
+    die IMPL::InvalidOperationException->new("Only one instance of the singleton can be created", $self)
+        if $self->_instance;
+        
+    $self->_instance($self->new(@_));
 }
 
 sub instance {
--- a/Lib/IMPL/Web/View/TTFactory.pm	Mon Apr 22 03:42:53 2013 +0400
+++ b/Lib/IMPL/Web/View/TTFactory.pm	Mon Apr 29 01:10:42 2013 +0400
@@ -4,7 +4,7 @@
 use Template::Context();
 
 use Carp qw(carp);
-use IMPL::lang qw(:hash);
+use IMPL::lang qw(:hash is);
 use IMPL::Exception();
 use Scalar::Util qw(weaken);
 
@@ -23,13 +23,13 @@
     ],
     props => [
         template => PROP_RW,
+        activation => PROP_RW,
         context => PROP_RW,
-        instances => PROP_RW,
         baseLocation => PROP_RW,
         base => PROP_RW,
         registry => PROP_RO, 
         blocks => PROP_RO,
-        initialized => PROP_RO
+        _instance => PROP_RW
     ]
 };
 
@@ -46,10 +46,10 @@
     $context ||= new Template::Context();
     my $baseLocation = join( '/', splice( @{[split(/\//,$path)]}, 0, -1 ) );
     
+    $this->activation($template->activation || 'new');
     $this->template($template);
     $this->context($context);
     $this->baseLocation($baseLocation);
-    $this->instances(0);
     $this->registry($registry);
     
     if (my $baseTplName = $template->extends) {
@@ -126,30 +126,9 @@
 sub CreateObject {
     my $this = shift;
     
-    $this->InitOnDemand();
-    
-    my $instance = $this->SUPER::CreateObject(@_);
-
-    my $count = $this->instances;   
-    $count++;
-    $this->instances($count);
-    
-    return $instance;
-}
-
-sub InitOnDemand {
-    my ($this) = @_;
-    
-    unless ($this->initialized) {
-        $this->initialized(1);
-        
-        $this->base->InitOnDemand()
-            if $this->base;
-        
-        if (my $init = $this->template->blocks->{INIT}) {
-            $this->context->process($init);
-        }
-    }
+    $this->activation eq 'singleton' ?
+        $this->_instance || $this->_instance($this->next::method(@_)) :
+        $this->next::method(@_);
 }
 
 sub CloneContext {