Program: bbtk
Module: $RCSfile: bbtkExecuter.h,v $ $
Language: C++
- Date: $Date: 2008/02/05 12:16:55 $
- Version: $Revision: 1.6 $
+ Date: $Date: 2008/03/07 08:40:14 $
+ Version: $Revision: 1.10 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
namespace bbtk
{
+ class Interpreter;
+
+
class /*BBTK_EXPORT*/ Executer : public VirtualExec
{
/// Constructor
Executer();
-
- ///
- // void SetFactory(Factory* f);
-
/// Destructor
~Executer();
+
+ /// Gets the factory used by the executer
+ Factory* GetFactory() { return mFactory; }
+ /// Gets the factory used by the executer (const)
+ const Factory* GetFactory() const { return mFactory; }
+
+
/// Sets the inputs of the workspace :
void SetInputs(const std::map<std::string,std::string>& m) { mInputs = m; }
const std::string& pack,
const std::string &scriptfilename);
+ /// Sets the file name to use for the current definition
+ /// (Used to set it after the Define command)
+ void SetCurrentFileName (const std::string &name );
+
/// End the definition of a ComplexBlackBox
void EndDefine ();
const std::string &box,
const std::string &output,
const std::string &help);
-
+
/// sets the input of the box with the value
void Set (const std::string &box,
const std::string &input,
/// prints the list off the boxes of the current box
void PrintBoxes();
- /// Generate a HTML with a gif file with the actual pipeline (Graphviz-dot needed). Returns the file path
+ /// Generate a HTML with a gif file with the current pipeline (Graphviz-dot needed). Returns the file path
std::string ShowGraph(const std::string &nameblackbox,
const std::string &detailStr,
const std::string &levelStr,
const std::string &custom_title,
bool system_display = true);
- /// Generate a HTML with a gif file with the actual pipeline (Graphviz-dot needed). Returns the file path
+ /// Generate a HTML with a gif file with the current pipeline (Graphviz-dot needed). Returns the file path
std::string ShowGraphInstances(const std::string &nameblackbox, int detail, int level, bool system_display=true);
/// Description of the actual pipeline
// ATTRIBUTES
/// The factory used
- // Factory* mFactory;
-
- /// The Root Package
- Package* mPackage;
+ Factory* mFactory;
- /// The root ComplexBlackBox, in which operations are done when outside a define/endefine block
+
+ /// The Root Package
+ /// Contains the root ComplexBlabkBox
+ /// In which ComplexBlackBoxes are put by default
+ /// Its name in bbi is 'user'
+ Package* mRootPackage;
+
+ /// The root ComplexBlackBox
+ /// in which operations are done when outside a define/endefine block
/// Its name in bbi is 'workspace'
- ComplexBlackBoxDescriptor* mRoot;
+ ComplexBlackBoxDescriptor* mRootCBB;
/// Struct that stores info on user defined complex black boxes
struct CBBDefinition
/// The stack of current working ComplexBlackBox
/// (is a stack for nested definitions)
- /// only contains the root when outside a define/endefine block
+ /// only contains the root cbb when outside a define/endefine block
std::deque<CBBDefinition> mOpenDefinition;
/// The stack of current working package
/// (is a stack for nested definitions)
std::deque<Package*> mOpenPackage;
- /// flag which is true when we are inside a Define/EndDefine block
- // bool mDefineFlag;
-
/// The input values of the Root ComplexBlackBox
std::map<std::string,std::string> mInputs;