+/*
+# ---------------------------------------------------------------------
+#
+# 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.
+# ------------------------------------------------------------------------ */
+
#ifdef WIN32
#define _CRT_SECURE_NO_DEPRECATE
#endif
bool mIsWidget;
std::string mParentBlackBox;
std::string mItkParent;
- std::string mVtkParent;
+ std::string mVtkObject;
bool mGeneric;
std::string mAuthor;
std::string mDescription;
std::vector<std::string> mInclude;
std::vector<std::string> mTypedef;
- std::string mUserConstructor;
- std::string mUserCopyConstructor;
- std::string mUserDestructor;
+ std::string mUserSetDefaultValues;
+ std::string mUserInitializeProcessing;
+ std::string mUserFinalizeProcessing;
typedef struct
{
std::string mHName;
std::string mCxxName;
+ void AlertString();
+
};
//==========================================================================
}
//==========================================================================
-
+void bbfy::AlertString()
+{
+
+ mFile << "//===== \n";
+ mFile << "// Before editing this file, make sure it's a file of your own ";
+ mFile << "(i.e.: it wasn't generated from xml description; if so : your modifications will be lost)\n";
+ mFile << "//===== \n";
+
+}
//==========================================================================
void bbfy::ParseXML()
{
+
+
+
XMLResults* res = new XMLResults;
XMLNode BB = XMLNode::parseFile(mFilename.c_str(),"blackbox",res);
else if (bbtype == vtkImageAlgorithmString)
{
mType = vtkImageAlgorithm;
- // Looks for <vtkparent> tag
- if (!BB.nChildNode("vtkparent"))
+ // Looks for <vtkobject> tag
+ if (!BB.nChildNode("vtkobject"))
{
throw bbfyException("Error : blackbox type '"
+vtkImageAlgorithmString
- +"' but no <vtkparent> tag found (mandatory)");
+ +"' but no <vtkobject> tag found (mandatory)");
}
- bbtk::GetTextOrClear(BB.getChildNode("vtkparent"),mVtkParent);
+ bbtk::GetTextOrClear(BB.getChildNode("vtkobject"),mVtkObject);
//
}
else if (bbtype == vtkPolyDataAlgorithmString )
{
mType = vtkPolyDataAlgorithm;
- // Looks for <vtkparent> tag
- if (!BB.nChildNode("vtkparent"))
+ // Looks for <vtkobject> tag
+ if (!BB.nChildNode("vtkobject"))
{
throw bbfyException("Error : blackbox type '"
+vtkPolyDataAlgorithmString
- +"' but no <vtkparent> tag found (mandatory)");
+ +"' but no <vtkobject> tag found (mandatory)");
}
- bbtk::GetTextOrClear(BB.getChildNode("vtkparent"),mVtkParent);
+ bbtk::GetTextOrClear(BB.getChildNode("vtkobject"),mVtkObject);
//
}
else
bbtk::GetTextOrClear(BB.getChildNode("namespace"),mNamespace);
}
- // UserConstructor body
- if (BB.nChildNode("constructor"))
+ // UserSetDefaultValues body
+ if (BB.nChildNode("defaultValues"))
{
- bbtk::GetTextOrClear(BB.getChildNode("constructor"),mUserConstructor);
+ bbtk::GetTextOrClear(BB.getChildNode("defaultValues"),
+ mUserSetDefaultValues);
}
- // UserCopyConstructor body
- if (BB.nChildNode("copyconstructor"))
+ // UserInitializeProcessing body
+ if (BB.nChildNode("initializeProcessing"))
{
- bbtk::GetTextOrClear(BB.getChildNode("copyconstructor"),mUserCopyConstructor);
+ bbtk::GetTextOrClear(BB.getChildNode("initializeProcessing"),
+ mUserInitializeProcessing);
}
- // UserDestructor body
- if (BB.nChildNode("destructor"))
+ // UserFinalizeProcessing body
+ if (BB.nChildNode("finalizeProcessing"))
{
- bbtk::GetTextOrClear(BB.getChildNode("destructor"),mUserDestructor);
+ bbtk::GetTextOrClear(BB.getChildNode("finalizeProcessing"),
+ mUserFinalizeProcessing);
}
-
- // Template parameters
+
+
+
+ // Template parameters
// mNbTemplateParam = BB.nChildNode("template");
if ( BB.nChildNode("template") > 0)
// process tag given ?
if (BB.nChildNode("process"))
{
- bbtk::GetTextOrClear(BB.getChildNode("process"),mProcess);
+ bbtk::GetTextOrClear(BB.getChildNode("process"),mProcess);
}
// CreateWidget
{
bbtk::GetTextOrClear(BB.getChildNode("createwidget"),mCreateWidget);
}
+
+
+
+
+
+
+
+ // OBSOLETE/UNSUPPORTED TAGS
+ // WARN IF OBSOLETE TAGS PROVIDED
+ if (BB.nChildNode("constructor"))
+ {
+ std::cout << "WARNING !!! The tag <constructor> is obsolete !!"<<std::endl;
+ }
+ if (BB.nChildNode("destructor"))
+ {
+ std::cout << "WARNING !!! The tag <destructor> is obsolete !!"<<std::endl;
+ }
+ if (BB.nChildNode("copy_constructor"))
+ {
+ std::cout << "WARNING !!! The tag <copy_constructor> is obsolete !!"<<std::endl;
+ }
+
+
+
}
//==========================================================================
mess += fullname + "\"";
throw bbfyException(mess);
}
-
+
+ AlertString();
+
// If is widget
if (mIsWidget)
{
mFile << "#define " << included <<"\n";
// Includes
- // mFile << "#include \"bbtkAtomicBlackBox.h\"\n";
+ mFile << "#include \"bb" << mPackage << "_EXPORT.h\"\n";
std::vector<std::string>::iterator i;
for (i=mInclude.begin(); i!=mInclude.end(); ++i)
{
}
// Class declaration and parents
- mFile << "class /*BBTK_EXPORT*/ "<<mName<<"\n";
+ mFile << "class bb"<<mPackage<<"_EXPORT "<<mName<<"\n";
mFile << " : \n";
/*
{
mFile << " public " << mItkParent <<",\n";
}
- else if ( (mType == vtkImageAlgorithm) ||
- (mType == vtkPolyDataAlgorithm) )
- {
- mFile << " public " << mVtkParent <<",\n";
- }
mFile << " public "<<mParentBlackBox << "\n";
mFile << " BBTK_VTK_BLACK_BOX_INTERFACE("
<< mName << ","
<< mParentBlackBox << ","
- << mVtkParent
+ << mVtkObject
<< ");\n";
}
+
// Default
else
{
mFile << *i <<"\n";
}
- // Declare user constructor / copy cons /destr
- mFile << "//=================================================================="<<std::endl;
- mFile << "/// User callback called in the box contructor"<<std::endl;
-
- mFile << "virtual void bbUserConstructor();"<<std::endl;
- mFile << "/// User callback called in the box copy constructor"<<std::endl;
- mFile << "virtual void bbUserCopyConstructor();"<<std::endl;
- mFile << "/// User callback called in the box destructor"<<std::endl;
- mFile << "virtual void bbUserDestructor();"<<std::endl;
- mFile << "//=================================================================="<<std::endl;
-
+ AlertString();
// Inputs
std::vector<IO>::iterator ioi;
throw bbfyException(mess);
}
}
+
// Outputs
for (ioi=mOutput.begin(); ioi!=mOutput.end(); ++ioi)
if (mIsWidget)
{
mFile << " BBTK_CREATE_WIDGET(CreateWidget);\n" ;
- mFile << " void CreateWidget();\n";
+ mFile << " void CreateWidget(wxWindow*);\n";
}
+ AlertString();
// EO black box declaration
mFile << "};\n\n";
{
throw bbfyException("template bb with more than 1 templ param not impl");
}
-
+
+
// Author
mFile << "BBTK_AUTHOR(\""<<mAuthor<< "\");\n";
WriteGenericITKFilterHeader();
}
+ AlertString();
// EO namespace
EndNamespace();
mess += "\"";
throw bbfyException(mess);
}
-
+
+ AlertString();
+
+
// Includes
// Header of the class
mFile << "#include \"" << mHName << "\"\n";
// Process
if ((mType == STD)||(mProcess.size()))
{
+ AlertString();
mFile << "void "<<mName<<"::Process()\n{\n";
mFile << mProcess << "\n";
mFile << "}\n";
// CreateWidget
if (mIsWidget)
{
- mFile << "void "<<mName<<"::CreateWidget()\n{\n";
+ AlertString();
+ mFile << "void "<<mName<<"::CreateWidget(wxWindow* parent)\n{\n";
mFile << mCreateWidget << "\n";
mFile << "}\n";
}
- // User constr / copy constr / destr implementation
- mFile <<"void "<<mName<<"::bbUserConstructor()"<<std::endl;
- mFile << "{"<<std::endl;
- //mFile<<"bbtkDebugMessage(\"Kernel\",9,\""<<mName<<::bbUserConstructor()"<<std::endl);"<<std::endl;
-
- mFile << mUserConstructor << std::endl;
+
+ // User Set Default Values
+ AlertString();
+ mFile <<"void "<<mName<<"::bbUserSetDefaultValues()"<<std::endl;
+ mFile << "{"<<std::endl;
+ if ( (mType == vtkImageAlgorithm) || (mType == vtkPolyDataAlgorithm) )
+ {
+ mFile << " BBTK_VTK_SET_DEFAULT_VALUES();\n";
+ }
+ mFile << mUserSetDefaultValues << std::endl;
mFile << "}" << std::endl;
- mFile <<"void "<<mName<<"::bbUserCopyConstructor()"<<std::endl;
+ // User Initialize Processing
+ AlertString();
+ mFile <<"void "<<mName<<"::bbUserInitializeProcessing()"
+ <<std::endl;
mFile << "{"<<std::endl;
- //mFile<<"bbtkDebugMessage(\"Kernel\",9,\""<<mName<<::bbUserCopyConstructor()"<<std::endl);"<<std::endl;
- mFile << mUserCopyConstructor << std::endl;
+ if ( (mType == vtkImageAlgorithm) || (mType == vtkPolyDataAlgorithm) )
+ {
+ mFile << " BBTK_VTK_INITIALIZE_PROCESSING();\n";
+ }
+ mFile << mUserInitializeProcessing << std::endl;
mFile << "}" << std::endl;
- mFile <<"void "<<mName<<"::bbUserDestructor()"<<std::endl;
+ // User Finalize Processing
+ AlertString();
+ mFile <<"void "<<mName<<"::bbUserFinalizeProcessing()"<<std::endl;
mFile << "{"<<std::endl;
- //mFile<<"bbtkDebugMessage(\"Kernel\",9,\""<<mName<<::bbUserDestructor()"<<std::endl);"<<std::endl;
- mFile << mUserDestructor << std::endl;
+ if ( (mType == vtkImageAlgorithm) || (mType == vtkPolyDataAlgorithm) )
+ {
+ mFile << " BBTK_VTK_FINALIZE_PROCESSING();\n";
+ }
+ mFile << mUserFinalizeProcessing << std::endl;
mFile << "}" << std::endl;