X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkItkBlackBoxMacros.h;h=3cb6d16d1586671520ecade6cc674f14320ff4a7;hb=a32025c531a0e20e967dc2ba3e0817f6932061b1;hp=52cd4f8c63d9085e353a5a07eeaa18e621022b48;hpb=e64f1a51510b44580500fd9ec30b4c937255bf75;p=bbtk.git diff --git a/kernel/src/bbtkItkBlackBoxMacros.h b/kernel/src/bbtkItkBlackBoxMacros.h index 52cd4f8..3cb6d16 100644 --- a/kernel/src/bbtkItkBlackBoxMacros.h +++ b/kernel/src/bbtkItkBlackBoxMacros.h @@ -3,8 +3,8 @@ Program: bbtk Module: $RCSfile: bbtkItkBlackBoxMacros.h,v $ Language: C++ - Date: $Date: 2008/05/07 06:31:37 $ - Version: $Revision: 1.1 $ + Date: $Date: 2008/05/07 12:59:23 $ + Version: $Revision: 1.3 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -29,23 +29,36 @@ //=========================================================================== //=========================================================================== +//=========================================================================== +#define BBTK_ITK_DELETE() \ + void bbDelete() { \ + itkParent::UnRegister(); \ + } +//=========================================================================== + +//=========================================================================== +#define BBTK_ITK_BLACK_BOX_INTERFACE(CLASS,PARENTBLACKBOX,ITKPARENT) \ + BBTK_BLACK_BOX_INTERFACE(CLASS,PARENTBLACKBOX); \ + typedef ITKPARENT itkParent; \ + BBTK_ITK_DELETE(); +//=========================================================================== //=========================================================================== /// Declares an itk-inherited AtomicBlackBox input -#define BBTK_DECLARE_ITK_INPUT(PARENT,NAME,TYPE) \ +#define BBTK_DECLARE_ITK_INPUT(NAME,TYPE) \ public: \ TYPE bbGetInput##NAME () \ - { return PARENT::GetInput(); } \ + { return itkParent::GetInput(); } \ void bbSetInput##NAME (TYPE d) \ - { PARENT::SetInput(d); \ + { itkParent::SetInput(d); \ /*bbSetModifiedStatus();*/ } //=========================================================================== //=========================================================================== -#define BBTK_DECLARE_ITK_OUTPUT(PARENT,NAME,TYPE) \ +#define BBTK_DECLARE_ITK_OUTPUT(NAME,TYPE) \ public: \ TYPE bbGetOutput##NAME () \ - { return PARENT::GetOutput(); } \ + { return itkParent::GetOutput(); } \ void bbSetOutput##NAME (TYPE d) \ { /*PARENT::GetOutput() = d;*/ } //=========================================================================== @@ -54,15 +67,29 @@ /// Declares an AtomicBlackBox input corresponding to an inherited itk parameter /// which was declared by itkSetMacro/itkGetMacro /// The NAME **MUST** be the same than the itk parameter name -#define BBTK_DECLARE_ITK_PARAM(PARENT,NAME,TYPE) \ +#define BBTK_DECLARE_ITK_PARAM(NAME,TYPE) \ public: \ TYPE bbGetInput##NAME () \ - { return PARENT::Get##NAME(); } \ + { return itkParent::Get##NAME(); } \ void bbSetInput##NAME (TYPE d) \ - { PARENT::Set##NAME(d); \ + { itkParent::Set##NAME(d); \ /*bbSetModifiedStatus();*/ } //=========================================================================== +//============================================================================ +/// Defines the default bbUserProcess method for itk inherited black boxes +/// (calls itkParent::Update) +#define BBTK_ITK_PROCESS() \ + public: \ + inline void bbUserProcess() \ + { \ + bbtkDebugMessage("process",1,"**> Processing ["<