-/*=========================================================================
+/*
+ # ---------------------------------------------------------------------
+ #
+ # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
+ # pour la SantÈ)
+ # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
+ # Previous Authors : Laurent Guigues, Jean-Pierre Roux
+ # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
+ #
+ # This software is governed by the CeCILL-B license under French law and
+ # abiding by the rules of distribution of free software. You can use,
+ # modify and/ or redistribute the software under the terms of the CeCILL-B
+ # license as circulated by CEA, CNRS and INRIA at the following URL
+ # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+ # or in the file LICENSE.txt.
+ #
+ # As a counterpart to the access to the source code and rights to copy,
+ # modify and redistribute granted by the license, users are provided only
+ # with a limited warranty and the software's author, the holder of the
+ # economic rights, and the successive licensors have only limited
+ # liability.
+ #
+ # The fact that you are presently reading this means that you have had
+ # knowledge of the CeCILL-B license and that you accept its terms.
+ # ------------------------------------------------------------------------ */
+
+
+/*=========================================================================
Program: bbtk
Module: $RCSfile: bbtkVtkBlackBoxMacros.h,v $
Language: C++
- Date: $Date: 2009/05/18 06:07:58 $
- Version: $Revision: 1.11 $
+ Date: $Date: 2012/11/16 08:49:01 $
+ Version: $Revision: 1.15 $
=========================================================================*/
-/* ---------------------------------------------------------------------
-
-* Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale)
-* Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux
-*
-* This software is governed by the CeCILL-B license under French law and
-* abiding by the rules of distribution of free software. You can use,
-* modify and/ or redistribute the software under the terms of the CeCILL-B
-* license as circulated by CEA, CNRS and INRIA at the following URL
-* http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
-* or in the file LICENSE.txt.
-*
-* As a counterpart to the access to the source code and rights to copy,
-* modify and redistribute granted by the license, users are provided only
-* with a limited warranty and the software's author, the holder of the
-* economic rights, and the successive licensors have only limited
-* liability.
-*
-* The fact that you are presently reading this means that you have had
-* knowledge of the CeCILL-B license and that you accept its terms.
-* ------------------------------------------------------------------------ */
+
//===========================================================================
//===========================================================================
-#define BBTK_VTK_DISABLE_GARBAGE_COLLECTOR \
- public: \
- virtual void Register(vtkObjectBase* o) {} \
- virtual void UnRegister(vtkObjectBase* o) {} \
- protected: \
- virtual void ReportReferences(vtkGarbageCollector* collector) {}
+#define BBTK_VTK_BLACK_BOX_INTERFACE(CLASS,PARENTBLACKBOX,VTKOBJECT) \
+ BBTK_BLACK_BOX_INTERFACE(CLASS,PARENTBLACKBOX); \
+ typedef VTKOBJECT bbVtkObject; \
+ bbVtkObject* bbGetVtkObject() { return mVtkObject; } \
+ private: \
+ bbVtkObject *mVtkObject;
+
+//===========================================================================
+#define BBTK_VTK_SET_DEFAULT_VALUES() \
+ mVtkObject = bbVtkObject::New();
+// mVtkObject = NULL;
-/*
-
- 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_INITIALIZE_PROCESSING() \
+ mVtkObject = mVtkObject;
+// mVtkObject = bbVtkObject::New();
+//===========================================================================
+#define BBTK_VTK_FINALIZE_PROCESSING() \
+ if (mVtkObject) { mVtkObject->Delete(); mVtkObject = NULL; }
+
+/*
//===========================================================================
#define BBTK_VTK_DELETE() \
int bbDelete() { \
for (int i=0; i<mVtkObject->GetNumberOfInputPorts();++i) \
- mVtkObject->SetInput(i,0); \
+ mVtkObject->SetInput(i,0); \
bbGetOutputOut()->SetSource(NULL); \
int refs = mVtkObject->GetReferenceCount()-1; \
mVtkObject->Delete(); \
// bbmDescriptorPointer.reset();
//===========================================================================
+*/
-//===========================================================================
-#define BBTK_VTK_NEW(CLASS,VTKPARENT) \
- inline static Pointer New(const std::string& name) \
- { \
- /*vtkDebugLeaks::ConstructClass(#VTKPARENT);*/ \
- bbtkDebugMessage("object",1,"##> "<<#CLASS \
- <<"::New(\""<<name<<"\")"<<std::endl); \
- Pointer p = MakeBlackBoxPointer(new Self(name)); \
- bbtkDebugMessage("object",1,"<## "<<#CLASS \
- <<"::New(\""<<name<<"\")"<<std::endl); \
- return p; \
- }
-//===========================================================================
-
-//===========================================================================
-#define BBTK_VTK_CLONE(CLASS,VTKPARENT) \
- inline bbtk::BlackBox::Pointer bbClone(const std::string& name) \
- { \
- /*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; \
- }
-
-
-//===========================================================================
-#define BBTK_VTK_BLACK_BOX_INTERFACE(CLASS,PARENTBLACKBOX,VTKPARENT) \
- BBTK_BLACK_BOX_INTERFACE_WITHOUT_NEW(CLASS,PARENTBLACKBOX); \
- typedef VTKPARENT vtkParent; \
- BBTK_VTK_DELETE(); \
- public : \
- BBTK_VTK_NEW(CLASS,VTKPARENT); \
- BBTK_VTK_CLONE(CLASS,VTKPARENT); \
- private: \
- vtkParent *mVtkObject;
-
-// 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) \
public: \
TYPE bbGetInput##NAME () \
- { return mVtkObject->GetImageDataInput(0); /*vtkParent::GetInput();*/ } \
+ { if (mVtkObject) return mVtkObject->GetImageDataInput(0); return 0; } \
void bbSetInput##NAME (TYPE d) \
- { mVtkObject->SetInput( (vtkDataObject*) d); \
- BBTK_VTK_UNREGISTER(d);/*bbSetModifiedStatus();*/ }
+ { if (mVtkObject) mVtkObject->SetInput( (vtkDataObject*) d); }
+
//===========================================================================
//===========================================================================
/// Declares a vtkPolyDataAlgorithm-inherited AtomicBlackBox input
-#define BBTK_DECLARE_VTK_POL÷,TYPE) \
+#define BBTK_DECLARE_VTK_POLY_DATA_ALGORITHM_INPUT(NAME,TYPE) \
public: \
TYPE bbGetInput##NAME () \
- { return mVtkObject->GetPolyDataInput(0); /*vtkParent::GetInput();*/ } \
+ { if (mVtkObject) return mVtkObject->GetPolyDataInput(0); return 0; } \
void bbSetInput##NAME (TYPE d) \
- { mVtkObject->SetInput( (vtkDataObject*) d); \
- BBTK_VTK_UNREGISTER(d);/*bbSetModifiedStatus();*/ }
+ { if (mVtkObject) mVtkObject->SetInput( (vtkDataObject*) d); }
+
//===========================================================================
//===========================================================================
#define BBTK_DECLARE_VTK_OUTPUT(NAME,TYPE) \
public: \
TYPE bbGetOutput##NAME () \
- { return mVtkObject->GetOutput(); } \
- void bbSetOutput##NAME (TYPE d) \
- { /*vtkParent::GetOutput() = d;*/ }
+ { if (mVtkObject) return mVtkObject->GetOutput(); return 0; } \
+ void bbSetOutput##NAME (TYPE d) \
+ { }
//===========================================================================
//===========================================================================
/// Declares a vtkAlgorithm-inherited AtomicBlackBox input
-#define BBTK_DECLARE_VTK_INPUT(NAME,TYPE) \
+#define BBTK_DECLARE_VTK_INPUT(NAME,TYPE) \
public: \
TYPE bbGetInput##NAME () \
- { return dynamic_cast<TYPE>(mVtkObject->GetInput()); } \
+ { if (mVtkObject) return dynamic_cast<TYPE>(mVtkObject->GetInput()); \
+ return 0;} \
void bbSetInput##NAME (TYPE d) \
- { mVtkObject->SetInput( (vtkDataObject*) d); \
- BBTK_VTK_UNREGISTER(d);/*vtkParent::GetOutput() = d;*/ }
+ { if (mVtkObject) mVtkObject->SetInput( (vtkDataObject*) d); }
//===========================================================================
#define BBTK_DECLARE_VTK_PARAM(NAME,TYPE) \
public: \
TYPE bbGetInput##NAME () \
- { return mVtkObject->Get##NAME(); } \
+ { if (mVtkObject) return mVtkObject->Get##NAME(); return 0; } \
void bbSetInput##NAME (TYPE d) \
- { mVtkObject->Set##NAME(d); \
+ { if (mVtkObject) mVtkObject->Set##NAME(d); \
}
//===========================================================================
public: \
inline void bbUserProcess() \
{ \
- bbtkDebugMessage("process",1,"**> Processing ["<<bbGetFullName() \
- <<"]"<<std::endl); \
- mVtkObject->Update(); \
- bbtkDebugMessage("process",2,"<** Processing ["<<bbGetFullName() \
- <<"]"<<std::endl); \
+ bbtkBlackBoxDebugMessage("process",1,"**> Processing..." \
+ <<std::endl); \
+ mVtkObject->Update(); \
+printf("EED Process %s\n", bbGetFullName().c_str() ); \
+ vtkIndent indent(2); \
+ mVtkObject->PrintSelf(std::cout, indent ); \
+ bbtkBlackBoxDebugMessage("process",2,"<** Processing" \
+ <<std::endl); \
}
//============================================================================