X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkComplexBlackBoxDescriptor.cxx;h=d9e8da14fffa779c90cd7d9dafc10c47a755a636;hb=a4fe3363034ebb3d905fc1cdbc6725539bf272a1;hp=4d6b6e88533c1b74a84e978766b12cf5d6c40fe4;hpb=a26195c366a89795288009cf7e20f11afa494970;p=bbtk.git diff --git a/kernel/src/bbtkComplexBlackBoxDescriptor.cxx b/kernel/src/bbtkComplexBlackBoxDescriptor.cxx index 4d6b6e8..d9e8da1 100644 --- a/kernel/src/bbtkComplexBlackBoxDescriptor.cxx +++ b/kernel/src/bbtkComplexBlackBoxDescriptor.cxx @@ -3,8 +3,8 @@ Program: bbtk Module: $RCSfile: bbtkComplexBlackBoxDescriptor.cxx,v $ Language: C++ - Date: $Date: 2008/01/22 15:02:00 $ - Version: $Revision: 1.1 $ + Date: $Date: 2008/03/07 10:21:30 $ + Version: $Revision: 1.12 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -33,12 +33,14 @@ namespace bbtk //======================================================================= /// Default ctor ComplexBlackBoxDescriptor::ComplexBlackBoxDescriptor(const std::string& name) - : BlackBoxDescriptor() + : BlackBoxDescriptor(), + mFactory(0) { - bbtkDebugMessageInc("Core",9,"ComplexBlackBoxDescriptor::ComplexBlackBoxDescriptor(\""<bbClone(name); - bbtkDebugDecTab("Core",5); + bbtkDebugDecTab("Kernel",5); } //======================================================================= @@ -81,11 +83,16 @@ namespace bbtk const std::string& name ) { - bbtkDebugMessageInc("Core",5, + bbtkDebugMessageInc("Kernel",5, "ComplexBlackBoxDescriptor::Add(\"" <bbUnsafeGetBlackBox( name ) ) @@ -93,9 +100,9 @@ namespace bbtk bbtkError("a black box \""<bbAddBlackBox ( /*mFactory->Create*/ NewBlackBox(type,name) ); + mPrototype->bbAddBlackBox ( mFactory->NewBlackBox(type,name) ); - bbtkDebugDecTab("Core",5); + bbtkDebugDecTab("Kernel",5); } //======================================================================= @@ -103,7 +110,7 @@ namespace bbtk /// Adds a black box to the execution list void ComplexBlackBoxDescriptor::AddToExecutionList ( const std::string& box) { - bbtkDebugMessageInc("Core",5, + bbtkDebugMessageInc("Kernel",5, "ComplexBlackBoxDescriptor::AddToExecutionList(\"" <bbAddToExecutionList ( box ); - bbtkDebugDecTab("Core",5); + bbtkDebugDecTab("Kernel",5); } @@ -128,12 +135,19 @@ namespace bbtk const std::string& input ) { - bbtkDebugMessageInc("Core",5, + bbtkDebugMessageInc("Kernel",5, "ComplexBlackBoxDescriptor::Connect(\"" <bbGetBlackBox( from ); if ( !bbfrom ) @@ -146,11 +160,11 @@ namespace bbtk bbtkError("the black box \""<*/ NewConnection( bbfrom, output, bbto, input ); + Connection* c = mFactory->NewConnection( bbfrom, output, bbto, input ); mPrototype->bbAddConnection(c); - bbtkDebugDecTab("Core",5); + bbtkDebugDecTab("Kernel",5); } //======================================================================= @@ -162,7 +176,7 @@ namespace bbtk const std::string& input, const std::string& help) { - bbtkDebugMessageInc("Core",5, + bbtkDebugMessageInc("Kernel",5, "ComplexBlackBoxDescriptor::DefineInput(\"" <bbGetInputType(input))); - + AddInputDescriptor ( new ComplexBlackBoxInputDescriptor + ( typeid(ComplexBlackBoxDescriptor), + name, + help, + box, + input, + bb->bbGetInputType(input))); + - bbtkDebugDecTab("Core",5); + bbtkDebugDecTab("Kernel",5); } //======================================================================= @@ -199,7 +215,7 @@ namespace bbtk const std::string& output, const std::string& help) { - bbtkDebugMessageInc("Core",5, + bbtkDebugMessageInc("Kernel",5, "ComplexBlackBoxDescriptor::DefineOutput(\"" <bbGetOutputType(output))); - bbtkDebugDecTab("Core",5); + bbtkDebugDecTab("Kernel",5); } //======================================================================= @@ -256,7 +273,7 @@ namespace bbtk int detail, int level, const std::string& output_dir, bool relative_link) { - bbtkDebugMessageInc("Core",9, + bbtkDebugMessageInc("Kernel",9, "ComplexBlackBoxDescriptor::InsertHtmlHelp() [" < categories; + // Split the category string + std::string delimiters = ";,"; + Utilities::SplitString(GetCategory(), + delimiters,categories); + + (s) << "

\n"; (s) << "\n"; + << descr << "\n"; + (s) << "\n"; - + << author << "\n"; + + (s) << "\n"; std::string inc = GetScriptFileName(); if (inc.size()>0) { - (s) << "\n"; + s << "\n"; } const ComplexBlackBox::BlackBoxMapType& B = mPrototype->bbGetBlackBoxMap(); if (B.size()) - { - (s) << "\n"; + (s) << "\n"; - } + } - (s) << "
Description : " - << descr << "
Author(s) : " - << author << "
Category(s) : "; + std::vector::iterator ci; + for (ci=categories.begin(); ci!=categories.end(); ++ci) + { + s << "" << *ci + << " \n"; + } + s << "
Include : " - << inc << "
To use it : include "; + s << inc << "  [source]"; + s << "
Dependencies : "; - - - - std::set pdeps; - ComplexBlackBox::BlackBoxMapType::const_iterator b; - for ( b = B.begin(); b != B.end(); ++b ) - { - BlackBoxDescriptor* d = b->second->bbGetDescriptor(); - if (pdeps.find(d) != pdeps.end()) continue; - pdeps.insert(d); - - Package* p = d->GetPackage(); + { + (s) << "
Uses : "; + + std::set pdeps; + ComplexBlackBox::BlackBoxMapType::const_iterator b; + for ( b = B.begin(); b != B.end(); ++b ) + { + BlackBoxDescriptor* d = b->second->bbGetDescriptor(); + if (pdeps.find(d) != pdeps.end()) + continue; + pdeps.insert(d); + + Package* p = d->GetPackage(); - std::string name = b->second->bbGetTypeName(); + std::string name = b->second->bbGetTypeName(); - std::string url; - if (relative_link) - url = p->GetDocRelativeURL(); - else - url = p->GetDocURL(); + std::string url; + if (relative_link) + url = p->GetDocRelativeURL(); + else + url = p->GetDocURL(); - s << "" - << p->GetName()<<"::"<\n"; - } + s << "" + << p->GetName()<<"::"<\n"; + } - (s) << "
\n"; + (s) << "\n"; //------------- @@ -360,7 +394,7 @@ namespace bbtk Utilities::html_format(type); std::string descr(in->second->GetDescription()); - //Utilities::html_format(descr); + Utilities::html_format(descr); (s) << "

 "<"
 	  << "
 "<"
@@ -393,8 +427,7 @@ namespace bbtk
 	Utilities::html_format(type);
 	
 	std::string descr(o->second->GetDescription());
-	//Utilities::html_format(descr);
-	
+	Utilities::html_format(descr);
 	
 	(s) << "
 "<"
 	  << "
 "<"
@@ -406,7 +439,7 @@ namespace bbtk
     //------------
     // End
 
-    bbtkDebugDecTab("Core",9);
+    bbtkDebugDecTab("Kernel",9);
    }
   //=========================================================================
  
@@ -417,8 +450,9 @@ namespace bbtk
     if (full) bbtkMessage("Help",1,"Complex Black Box <"<<
 			  GetPackage()->GetName()<<"::"
 			  <"<second->GetName().size()>namelmax) 
-	  namelmax = i->second->GetName().size();
-	if (i->second->GetTypeName().size()>typelmax) 
-	  typelmax = i->second->GetTypeName().size();
-      }
+    {
+	   if (i->second->GetName().size()>namelmax) 
+	     namelmax = i->second->GetName().size();
+	   if (i->second->GetTypeName().size()>typelmax) 
+	     typelmax = i->second->GetTypeName().size();
+    }
     OutputDescriptorMapType::const_iterator o;
     if (full) 
-      {
-	for ( o = mOutput.begin();  o != mOutput.end(); ++o ) 
-	  {
-	    if (o->second->GetName().size()>namelmax) 
-	      namelmax = o->second->GetName().size();
+    {
+	   for ( o = mOutput.begin();  o != mOutput.end(); ++o ) 
+	   {
+	     if (o->second->GetName().size()>namelmax) 
+	       namelmax = o->second->GetName().size();
 	    if (o->second->GetTypeName().size()>typelmax) 
-	      typelmax = o->second->GetTypeName().size();
-	  }
-      }
+	       typelmax = o->second->GetTypeName().size();
+	   }
+    }
     //
 
     for ( i = mInput.begin();  i != mInput.end(); ++i ) 
-      {
-	std::string name(i->second->GetName());
-	name += "'";
-	name.append(1+namelmax-name.size(),' ');
-	std::string type(i->second->GetTypeName());
-	type += ">";
-	type.append(1+typelmax-type.size(),' ');
-	bbtkMessage("Help",1,
+    {
+	   std::string name(i->second->GetName());
+	   name += "'";
+	   name.append(1+namelmax-name.size(),' ');
+	   std::string type(i->second->GetTypeName());
+	   type += ">";
+	   type.append(1+typelmax-type.size(),' ');
+	   bbtkMessage("Help",1,
 		    "    '"<second->GetDescription()<second->GetName());
-	    name += "'";
-	    name.append(1+namelmax-name.size(),' ');
-	    std::string type(o->second->GetTypeName());
-	    type += ">";
-	    type.append(1+typelmax-type.size(),' ');
-	    bbtkMessage("Help",1,
-			"    '"<second->GetDescription()<second->GetName());
+	     name += "'";
+	     name.append(1+namelmax-name.size(),' ');
+	     std::string type(o->second->GetTypeName());
+	     type += ">";
+	     type.append(1+typelmax-type.size(),' ');
+	     bbtkMessage("Help",1,
+			 "    '"<second->GetDescription()<bbGetBlackBoxMap();
+    {
+	   const ComplexBlackBox::BlackBoxMapType& B = mPrototype->bbGetBlackBoxMap();
 	
-	if (B.size()) 
-	  bbtkMessage("Help",1," * Boxes : "<second->bbGetName()<<
-			"' <"
-			<< b->second->bbGetDescriptor()->GetPackage()->GetName() 
-			<<"::"
-			<second->bbGetTypeName()<<">"<second->bbGetName()<<
+			 "' <"
+			 << b->second->bbGetDescriptor()->GetPackage()->GetName() 
+			 <<"::"
+			 <second->bbGetTypeName()<<">"<