X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=kernel%2Fsrc%2FbbtkVirtualExec.h;h=1bb48a94fab0729263345db374c2202d34eee9a8;hb=372f03317f05d4a436b0f9c39b98558ec4810b78;hp=42217a7a1c88b3c53f7fa39121b34da6ab76891c;hpb=2d76cd309d74d5f83d701d6bb0a4140d5d122b36;p=bbtk.git diff --git a/kernel/src/bbtkVirtualExec.h b/kernel/src/bbtkVirtualExec.h index 42217a7..1bb48a9 100644 --- a/kernel/src/bbtkVirtualExec.h +++ b/kernel/src/bbtkVirtualExec.h @@ -3,8 +3,8 @@ Program: bbtk Module: $RCSfile: bbtkVirtualExec.h,v $ $ Language: C++ - Date: $Date: 2008/01/30 09:28:16 $ - Version: $Revision: 1.4 $ + Date: $Date: 2008/03/07 08:40:14 $ + Version: $Revision: 1.8 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -28,36 +28,42 @@ #define __bbtkVirtualExec_h__ #include "bbtkSystem.h" -#include "bbtkComplexBlackBox.h" +//#include "bbtkComplexBlackBox.h" #include "bbtkFactory.h" -#include -#include +//#include +//#include namespace bbtk { + class Interpreter; + class /*BBTK_EXPORT*/ VirtualExec // All methods are pure virtual { public: - typedef enum + typedef enum { NoDialog, TextDialog, GraphicalDialog } DialogModeType; + + VirtualExec() : mInterpreter(0) {} + + /// Sets the interpreter who uses it + void SetInterpreter(Interpreter* i) { mInterpreter = i; } + /// Gets the interpreter who uses it + Interpreter* GetInterpreter() { return mInterpreter; } + /// Gets the interpreter who uses it (const) + const Interpreter* GetInterpreter() const { return mInterpreter; } + + /// Gets the factory used by the executer + virtual Factory* GetFactory() { return 0; } + /// Gets the factory used by the executer (const) + virtual const Factory* GetFactory() const { return 0; } -/* - /// Constructor - VirtualExec(); - - /// - // void SetFactory(Factory* f); - - /// Destructor - virtual ~VirtualExec() = 0; -*/ /// Sets the inputs of the workspace : virtual void SetInputs(const std::map& m) = 0; @@ -81,6 +87,10 @@ namespace bbtk virtual void Define (const std::string &name, const std::string& pack, const std::string &scriptfilename) = 0; + + /// Sets the file name to use for the current definition + /// (Used to set it after the Define command) + virtual void SetCurrentFileName (const std::string &name ) = 0; /// End the definition of a ComplexBlackBox virtual void EndDefine () = 0; @@ -119,7 +129,7 @@ namespace bbtk const std::string &input, const std::string &value) = 0; - /// gets the output of the box + /// gets the output of the box virtual std::string Get (const std::string &box, const std::string &output) = 0; @@ -129,8 +139,8 @@ namespace bbtk ///Adds the authorName to the Box author list virtual void Author(const std::string &authorName) = 0; - ///Adds the keywords to the Box keywords list - virtual void Keyword(const std::string &keywords) = 0; + ///Adds the categories to the Box categoris list + virtual void Category(const std::string &categories) = 0; /// The description string which explains what does the ComplexBox virtual void Description(const std::string &d) = 0; @@ -147,21 +157,24 @@ namespace bbtk const std::string &custom_title, bool system_display = true) = 0; - /// 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 actual pipeline (Graphviz-dot needed). Returns the file path virtual std::string ShowGraphInstances(const std::string &nameblackbox, int detail, int level, bool system_display=true) = 0; -/// Description of the actual pipeline + /// Description of the actual pipeline virtual void ShowRelations(const std::string &nameblackbox, const std::string &detailStr, const std::string &levelStr) = 0; virtual void Reset() = 0; -/* + + // static const std::string& GetObjectDescription() = 0; // { static std::string s("VirtualExec"); return s; } -*/ protected: private: + /// The interpreter which uses it (0 if none) + Interpreter* mInterpreter; + /* /// Gets the current working black box virtual ComplexBlackBoxDescriptor* Current() = 0; @@ -180,7 +193,7 @@ namespace bbtk /// The root ComplexBlackBox, in which operations are done when outside a define/endefine block /// Its name in bbi is 'workspace' ComplexBlackBoxDescriptor* mRoot; - + /// Struct that stores info on user defined complex black boxes struct CBBDefinition { @@ -193,7 +206,11 @@ namespace bbtk /// The stack of current working ComplexBlackBox /// (is a stack for nested definitions) /// only contains the root when outside a define/endefine block - std::deque mCurrent; + std::deque mOpenDefinition; + + /// The stack of current working package + /// (is a stack for nested definitions) + std::deque mOpenPackage; /// flag which is true when we are inside a Define/EndDefine block // bool mDefineFlag; @@ -206,6 +223,7 @@ namespace bbtk /// Dialog mode DialogModeType mDialogMode; + */ }; } #endif