]> Creatis software - bbtk.git/blobdiff - kernel/src/bbtkVtkBlackBoxMacros.h
Fixed (sure ? to test extensively) the problem with vtk-inherited black boxes desallo...
[bbtk.git] / kernel / src / bbtkVtkBlackBoxMacros.h
index 448e2fe23744974f8c23f0a932efbf2242c09922..ce87d7e37c2ccc56472c16322767a65d7283360a 100644 (file)
@@ -2,8 +2,8 @@
   Program:   bbtk
   Module:    $RCSfile: bbtkVtkBlackBoxMacros.h,v $
   Language:  C++
-  Date:      $Date: 2008/10/17 08:18:14 $
-  Version:   $Revision: 1.7 $
+  Date:      $Date: 2009/02/27 11:20:25 $
+  Version:   $Revision: 1.8 $
 =========================================================================*/
 
 /* ---------------------------------------------------------------------
@@ -36,7 +36,7 @@
  */
 #ifndef __bbtkVtkBlackBoxMacros_h__
 #define __bbtkVtkBlackBoxMacros_h__
-//#include <vtkGarbageCollector.h>
+#include <vtkGarbageCollector.h>
 //#include <vtkObjectFactory.h>
 #include <vtkDebugLeaks.h>
 
 //===========================================================================
 //===========================================================================
 
+//===========================================================================
+#define BBTK_VTK_DISABLE_GARBAGE_COLLECTOR                             \
+  public:                                                              \
+  virtual void Register(vtkObjectBase* o) {}                           \
+  virtual void UnRegister(vtkObjectBase* o) {}                         \
+  protected:                                                           \
+  virtual void ReportReferences(vtkGarbageCollector* collector) {}
+
+/*
+       
+  public:                                 \
+  virtual void Register(vtkObjectBase* o) {} \
+     {
+     this->RegisterInternal(o, 1);
+     }
+   virtual void UnRegister(vtkObjectBase* o)
+     {
+     this->UnRegisterInternal(o, 1);
+     }
+
+  protected:
+
+   virtual void ReportReferences(vtkGarbageCollector* collector)
+     {
+     // Report references held by this object that may be in a loop.
+     this->Superclass::ReportReferences(collector);
+     vtkGarbageCollectorReport(collector, this->OtherObject, "Other Object");
+     }
+*/
+//===========================================================================
 
 //===========================================================================
 #define BBTK_VTK_DELETE()                                              \
   void bbDelete() {                                                    \
+    for (int i=0; i<vtkParent::GetNumberOfInputPorts();++i)            \
+      vtkParent::SetInput(i,0);                                                \
     bbGetOutputOut()->SetSource(NULL);                                 \
+    /*std::cout << "VTK : bbDelete() "<<std::endl;*/                   \
+    /*std::cout << "Use count = "<<GetUseCount()<<std::endl;*/         \
+    /*std::cout << "VTK count = "<<GetReferenceCount()<<std::endl;*/   \
+    /*    vtkParent::SetReferenceCount(1); GetUseCount());*/           \
+    /*delete this;     */                                              \
     vtkParent::Delete();                                               \
   }
 
@@ -62,7 +99,7 @@
 #define BBTK_VTK_NEW(CLASS,VTKPARENT)                                  \
   inline static Pointer New(const std::string& name)                   \
   {                                                                    \
-    vtkDebugLeaks::ConstructClass(#VTKPARENT);                         \
+    /*vtkDebugLeaks::ConstructClass(#VTKPARENT);*/                     \
     bbtkDebugMessage("object",1,"##> "<<#CLASS                         \
                     <<"::New(\""<<name<<"\")"<<std::endl);             \
     Pointer p = MakeBlackBoxPointer(new Self(name));                   \
 #define BBTK_VTK_CLONE(CLASS,VTKPARENT)                                        \
   inline bbtk::BlackBox::Pointer bbClone(const std::string& name)      \
   {                                                                    \
-    vtkDebugLeaks::ConstructClass(#VTKPARENT);                         \
+    /*vtkDebugLeaks::ConstructClass(#VTKPARENT);*/                     \
     bbtkDebugMessage("object",1,"##> "<<#CLASS                         \
                     <<"::bbClone(\""<<name<<"\")"<<std::endl);         \
     Pointer p = MakeBlackBoxPointer(new Self(*this,name));             \
     bbtkDebugMessage("object",1,"<## "<<#CLASS                         \
                     <<"::bbClone(\""<<name<<"\")"<<std::endl);         \
     return p;                                                          \
-  }                                                                    \
+  }                                                                    
 
 
 //===========================================================================
   BBTK_VTK_DELETE();                                                   \
   public :                                                             \
   BBTK_VTK_NEW(CLASS,VTKPARENT);                                       \
-  BBTK_VTK_CLONE(CLASS,VTKPARENT);                                                     
+  BBTK_VTK_CLONE(CLASS,VTKPARENT);                                     
+
+//  BBTK_VTK_DISABLE_GARBAGE_COLLECTOR
 //===========================================================================
 
+#define BBTK_VTK_UNREGISTER(O) 
+
+//O->UnRegister(this);
+
 //===========================================================================
 /// Declares a vtkImageAlgorithm-inherited AtomicBlackBox input 
 #define BBTK_DECLARE_VTK_IMAGE_ALGORITHM_INPUT(NAME,TYPE)              \
   { return GetImageDataInput(0); /*vtkParent::GetInput();*/ }          \
   void bbSetInput##NAME (TYPE d)                                       \
   { vtkParent::SetInput( (vtkDataObject*) d);                          \
-    /*bbSetModifiedStatus();*/ }                               
+    BBTK_VTK_UNREGISTER(d);/*bbSetModifiedStatus();*/ }                                
 //===========================================================================
 
 //===========================================================================
   { return GetPolyDataInput(0); /*vtkParent::GetInput();*/ }           \
   void bbSetInput##NAME (TYPE d)                                       \
   { vtkParent::SetInput( (vtkDataObject*) d);                          \
-    /*bbSetModifiedStatus();*/ }                                                      
+    BBTK_VTK_UNREGISTER(d);/*bbSetModifiedStatus();*/ }                                                       
 //===========================================================================
 
 //===========================================================================
   TYPE bbGetInput##NAME ()                                             \
   { return dynamic_cast<TYPE>(vtkParent::GetInput()); }                        \
   void bbSetInput##NAME (TYPE d)                                       \
-  { vtkParent::SetInput( (vtkDataObject*) d); /*vtkParent::GetOutput() = d;*/ }
+  { vtkParent::SetInput( (vtkDataObject*) d);                          \
+   BBTK_VTK_UNREGISTER(d);/*vtkParent::GetOutput() = d;*/ }
 
 //===========================================================================