-/*=========================================================================
-
+/*=========================================================================
Program: bbtk
Module: $RCSfile: bbtkComplexBlackBoxDescriptor.cxx,v $
Language: C++
- Date: $Date: 2008/02/08 11:56:10 $
- Version: $Revision: 1.9 $
-
- Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
- l'Image). All rights reserved. See Doc/License.txt or
- http://www.creatis.insa-lyon.fr/Public/bbtk/License.html for details.
-
- This software is distributed WITHOUT ANY WARRANTY; without even
- the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- PURPOSE. See the above copyright notices for more information.
-
+ Date: $Date: 2009/03/30 15:22:51 $
+ Version: $Revision: 1.19 $
=========================================================================*/
+/* ---------------------------------------------------------------------
+
+* 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.
+* ------------------------------------------------------------------------ */
+
+
/**
* \file
* \brief Class bbtk::ComplexBlackBoxDescriptor : describes a ComplexBlackBox (constituents, connections) and is able to create an instance of it.
namespace bbtk
{
-
+ //=======================================================================
+ ///
+ ComplexBlackBoxDescriptor::Pointer
+ ComplexBlackBoxDescriptor::New(const std::string& name)
+ {
+ bbtkDebugMessage("object",1,"##> ComplexBlackBoxDescriptor::New(\""<<name<<"\")"<<std::endl);
+ ComplexBlackBoxDescriptor::Pointer p =
+ MakePointer(new ComplexBlackBoxDescriptor(name));
+ bbtkDebugMessage("object",1,"<## ComplexBlackBoxDescriptor::New(\""<<name<<"\")"<<std::endl);
+ return p;
+ }
+ //=======================================================================
//=======================================================================
/// Default ctor
ComplexBlackBoxDescriptor::ComplexBlackBoxDescriptor(const std::string& name)
- : BlackBoxDescriptor()
{
- bbtkDebugMessageInc("Kernel",9,"ComplexBlackBoxDescriptor::ComplexBlackBoxDescriptor(\""<<name<<"\")"<<std::endl);
+ bbtkDebugMessage("object",2,"==> ComplexBlackBoxDescriptor::ComplexBlackBoxDescriptor(\""<<name<<"\")"<<std::endl);
SetTypeName(name);
AddToCategory("complex box");
- mPrototype = new ComplexBlackBox(name+std::string("Prototype"),this);
- bbtkDebugDecTab("Kernel",9);
+ mPrototype = ComplexBlackBox::New(name+std::string("Prototype"),
+ MakePointer(this,true));
+ mPrototype->SetAsPrototype();
+ bbtkDebugMessage("object",2,"<== ComplexBlackBoxDescriptor::ComplexBlackBoxDescriptor(\""<<name<<"\")"<<std::endl);
}
//=======================================================================
/// Default dtor
ComplexBlackBoxDescriptor::~ComplexBlackBoxDescriptor()
{
- bbtkDebugMessageInc("Kernel",9,"ComplexBlackBoxDescriptor::~ComplexBlackBoxDescriptor(\""<<GetTypeName()<<"\")"<<std::endl);
-
- delete mPrototype;
-
- bbtkDebugDecTab("Kernel",9);
+ bbtkDebugMessage("object",2,"==> ComplexBlackBoxDescriptor::~ComplexBlackBoxDescriptor(\""<<GetTypeName()<<"\")"<<std::endl);
+ // mPrototype->Delete();
+ mPrototype.reset();
+ bbtkDebugMessage("object",2,"<== ComplexBlackBoxDescriptor::~ComplexBlackBoxDescriptor(\""<<GetTypeName()<<"\")"<<std::endl);
}
//=======================================================================
+ //=========================================================================
+ /// Check
+ void ComplexBlackBoxDescriptor::Check(bool recursive) const
+ {
+ mPrototype->Check(recursive);
+ }
+ //=========================================================================
//=======================================================================
/// Creates an instance of name <name> of the ComplexBlackBox of which this is the descriptor
- BlackBox* ComplexBlackBoxDescriptor::CreateInstance(const std::string& name)
+ BlackBox::Pointer
+ ComplexBlackBoxDescriptor::NewBlackBox(const std::string& name)
{
- //bbtkError("ComplexBlackBoxDescriptor::CreateInstance not implemented");
bbtkDebugMessageInc("Kernel",5,
- "ComplexBlackBoxDescriptor::CreateInstance(\""
+ "ComplexBlackBoxDescriptor::NewBlackBox(\""
<<name<<"\") ["
<<GetTypeName()<<"]"<<std::endl);
}
//=======================================================================
-
+ /*
+ //=======================================================================
+ /// Release
+ void ComplexBlackBoxDescriptor::Release(bool release_package)
+ {
+ }
+ //=======================================================================
+ */
//=======================================================================
/// Adds a black box to the complex box
<<type<<"\",\""<<name<<"\") ["
<<GetTypeName()<<"]"<<std::endl);
+ //
+ if (!GetFactory())
+ {
+ bbtkError("ComplexBlackBoxDescriptor::Add : no factory set");
+ }
// Verify that a box with the same name does not exist already
if ( mPrototype->bbUnsafeGetBlackBox( name ) )
bbtkError("a black box \""<<name<<"\" already exists");
}
// ok : create new one
- mPrototype->bbAddBlackBox ( /*mFactory->Create*/ NewBlackBox(type,name) );
+ mPrototype->bbAddBlackBox ( GetFactory()->NewBlackBox(type,name) );
bbtkDebugDecTab("Kernel",5);
}
//=======================================================================
+
+ //=======================================================================
+ /// Removes a black box from the complex box
+ void ComplexBlackBoxDescriptor::Remove( const std::string& name,
+ bool remove_connections)
+ {
+ mPrototype->bbRemoveBlackBox(name,remove_connections);
+ }
+ //=======================================================================
+
- //=======================================================================
+ //=======================================================================
/// Adds a black box to the execution list
void ComplexBlackBoxDescriptor::AddToExecutionList ( const std::string& box)
{
<<box<<"\" ["
<<GetTypeName()<<"]"<<std::endl);
// Verify that the box exists
- BlackBox* b = mPrototype->bbUnsafeGetBlackBox( box );
+ BlackBox::Pointer b = mPrototype->bbUnsafeGetBlackBox( box );
if ( !b )
{
bbtkError("the black box \""<<box<<"\" does not exist");
<<to<<"\",\""<<input
<<"\") ["
<<GetTypeName()<<"]"<<std::endl);
+ //
+ if (!GetFactory())
+ {
+ bbtkError("ComplexBlackBoxDescriptor::Connect : no factory set");
+ }
+
+
// Verify that a box with the same name does not exist already
- BlackBox* bbfrom = mPrototype->bbGetBlackBox( from );
+ BlackBox::Pointer bbfrom = mPrototype->bbGetBlackBox( from );
if ( !bbfrom )
{
bbtkError("the black box \""<<from<<"\" does not exist");
}
- BlackBox* bbto = mPrototype->bbGetBlackBox( to );
+ BlackBox::Pointer bbto = mPrototype->bbGetBlackBox( to );
if ( !bbto )
{
bbtkError("the black box \""<<to<<"\" does not exist");
}
- Connection* c = /*mFactory->*/ NewConnection( bbfrom, output, bbto, input );
+ Connection::Pointer c
+ = GetFactory()->NewConnection( bbfrom, output, bbto, input );
mPrototype->bbAddConnection(c);
<<"\") ["
<<GetTypeName()<<"]"<<std::endl);
- BlackBox* bb = mPrototype->bbGetBlackBox( box );
+ BlackBox::Pointer bb = mPrototype->bbGetBlackBox( box );
if ( !bb )
{
bbtkError("the black box \""<<box<<"\" does not exist");
<<input<<"\"");
}
+ const BlackBoxInputDescriptor* d =
+ bb->bbGetDescriptor()->GetInputDescriptor(input);
AddInputDescriptor ( new ComplexBlackBoxInputDescriptor
( typeid(ComplexBlackBoxDescriptor),
name,
help,
+ d->GetNature(),
box,
input,
- bb->bbGetInputType(input)));
+ d->GetTypeInfo()));
bbtkDebugDecTab("Kernel",5);
<<"\") ["
<<GetTypeName()<<"]"<<std::endl);
- BlackBox* bb = mPrototype->bbGetBlackBox( box );
+ BlackBox::Pointer bb = mPrototype->bbGetBlackBox( box );
if ( !bb )
{
bbtkError("the black box \""<<box<<"\" does not exist");
<<output<<"\"");
}
+ const BlackBoxOutputDescriptor* d =
+ bb->bbGetDescriptor()->GetOutputDescriptor(output);
AddOutputDescriptor ( new ComplexBlackBoxOutputDescriptor
( typeid(ComplexBlackBoxDescriptor),
name,
help,
+ d->GetNature(),
box,
output,
- bb->bbGetOutputType(output)));
+ d->GetTypeInfo()));
bbtkDebugDecTab("Kernel",5);
std::string descr = GetDescription();
- Utilities::html_format(descr);
+ //Utilities::html_format(descr);
std::string author = GetAuthor();
Utilities::html_format(author);
if (inc.size()>0)
{
s << "<TR><TD style='vertical-align: top;'><b> To use it </b></TD><TD style='vertical-align: top;'> : </TD><TD style='vertical-align: top;'> include ";
- s << inc << " <a href=\"../../../bbs/"<<inc<<"\">[source]</a>";
+ // s << inc << " <a href=\"../../../bbs/"<<inc<<"\">[source]</a>";
+ // LG TODO : USE PACKAGE BBS PATH
+ s << inc << " <a href=\""<<inc<<"\">[source]</a>";
s << "</TD></TR>\n";
}
{
(s) << "<TR><TD style='vertical-align: top;'><b> Uses </b></TD><TD style='vertical-align: top;'> : </TD><TD style='vertical-align: top;'> ";
- std::set<BlackBoxDescriptor*> pdeps;
+ std::set<BlackBoxDescriptor::Pointer> pdeps;
ComplexBlackBox::BlackBoxMapType::const_iterator b;
for ( b = B.begin(); b != B.end(); ++b )
{
- BlackBoxDescriptor* d = b->second->bbGetDescriptor();
+ BlackBoxDescriptor::Pointer d = b->second->bbGetDescriptor();
if (pdeps.find(d) != pdeps.end())
continue;
pdeps.insert(d);
- Package* p = d->GetPackage();
+ Package::Pointer p = d->GetPackage();
std::string name = b->second->bbGetTypeName();
url = p->GetDocRelativeURL();
else
url = p->GetDocURL();
-
+
s << "<a href=\"" <<url<<"#"<<name<<"\">"
<< p->GetName()<<"::"<<name<<"</a>\n";
- }
+ } // for
(s) << "</TD></TR>\n";
- }
+ } // If B.size
(s) << "</TABLE>\n";
Utilities::html_format(type);
std::string descr(in->second->GetDescription());
- Utilities::html_format(descr);
+ //Utilities::html_format(descr);
(s) << "<TR><TD style='vertical-align: top;'><B><PRE> "<<name<<" </PRE></B></TD>"
<< "<TD style='vertical-align: top;'><I><PRE> "<<type<<" </PRE></I></TD>"
Utilities::html_format(type);
std::string descr(o->second->GetDescription());
- Utilities::html_format(descr);
+ //Utilities::html_format(descr);
(s) << "<TR><TD style='vertical-align: top;'><B><PRE> "<<name<<" </PRE></B></TD>"
<< "<TD style='vertical-align: top;'><I><PRE> "<<type<<" </PRE></I></TD>"
InputDescriptorMapType::const_iterator i;
unsigned int namelmax = 0;
unsigned int typelmax = 0;
+ unsigned int natlmax = 0;
for ( i = mInput.begin(); i != mInput.end(); ++i )
{
if (i->second->GetName().size()>namelmax)
namelmax = i->second->GetName().size();
if (i->second->GetTypeName().size()>typelmax)
typelmax = i->second->GetTypeName().size();
+ if (i->second->GetNature().size()>natlmax)
+ natlmax = i->second->GetNature().size();
}
OutputDescriptorMapType::const_iterator o;
if (full)
namelmax = o->second->GetName().size();
if (o->second->GetTypeName().size()>typelmax)
typelmax = o->second->GetTypeName().size();
+ if (o->second->GetNature().size()>natlmax)
+ natlmax = o->second->GetNature().size();
}
}
//
std::string type(i->second->GetTypeName());
type += ">";
type.append(1+typelmax-type.size(),' ');
+ std::string nature(i->second->GetNature());
+ nature += "]";
+ nature.append(1+natlmax-nature.size(),' ');
bbtkMessage("Help",1,
- " '"<<name
- <<" <"<<type
- <<" : "<<i->second->GetDescription()<<std::endl);
+ " '"<<name
+ <<" <"<<type
+ <<" ["<<nature
+ <<" : "<<i->second->GetDescription()<<std::endl);
}
if (full)
{
std::string type(o->second->GetTypeName());
type += ">";
type.append(1+typelmax-type.size(),' ');
+ std::string nature(o->second->GetNature());
+ nature += "]";
+ nature.append(1+natlmax-nature.size(),' ');
bbtkMessage("Help",1,
- " '"<<name
+ " '"<<name
<<" <"<<type
+ <<" ["<<nature
<<" : "<<o->second->GetDescription()<<std::endl);
}
}
}
//=======================================================================
-
+ //==========================================================================
+ std::string ComplexBlackBoxDescriptor::GetObjectName() const
+ {
+ return std::string("ComplexBlackBoxDescriptor '")+GetFullTypeName()
+ +std::string("'");
+ }
+ //==========================================================================
+ //=======================================================================
+ std::string ComplexBlackBoxDescriptor::GetObjectInfo() const
+ {
+ std::string i;
+ return i;
+ }
+ //=======================================================================
+ //==========================================================================
+size_t ComplexBlackBoxDescriptor::GetObjectSize() const
+{
+ size_t s = Superclass::GetObjectSize();
+ s += ComplexBlackBoxDescriptor::GetObjectInternalSize();
+ return s;
+ }
+ //==========================================================================
+ //==========================================================================
+size_t ComplexBlackBoxDescriptor::GetObjectInternalSize() const
+{
+ size_t s = sizeof(ComplexBlackBoxDescriptor);
+ return s;
+ }
+ //==========================================================================
+ //==========================================================================
+ size_t ComplexBlackBoxDescriptor::GetObjectRecursiveSize() const
+ {
+ size_t s = Superclass::GetObjectRecursiveSize();
+ s += ComplexBlackBoxDescriptor::GetObjectInternalSize();
+ s += mPrototype->GetObjectRecursiveSize();
+ return s;
+ }
+ //==========================================================================
}