1 /*=========================================================================
4 Module: $RCSfile: bbtkWxGUIScriptingInterface.h,v $
6 Date: $Date: 2008/03/21 14:59:39 $
7 Version: $Revision: 1.2 $
9 Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
10 l'Image). All rights reserved. See Doc/License.txt or
11 http://www.creatis.insa-lyon.fr/Public/bbtk/License.html for details.
13 This software is distributed WITHOUT ANY WARRANTY; without even
14 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 PURPOSE. See the above copyright notices for more information.
17 =========================================================================*//**
18 * \brief Short description in one line
20 * Long description which
21 * can span multiple lines
33 #ifdef _USE_WXWIDGETS_
36 #ifndef __bbtkWxGUIScriptingInterface_h__
37 #define __bbtkWxGUIScriptingInterface_h__
39 #include <wx/aui/aui.h>
41 #include <wx/notebook.h>
42 #include <wx/html/htmlwin.h>
45 #include "bbtkInterpreter.h"
47 #include "bbtkWxGUITextEditor.h"
48 #include "bbtkWxGUICommand.h"
49 #include "bbtkWxGUIOutputMessages.h"
50 #include "bbtkWxGUIHtmlBrowser.h"
55 /// A scripting interface window
56 class BBTK_EXPORT WxGUIScriptingInterface : public wxFrame,
57 public InterpreterUser,
58 public WxGUICommandUser,
59 public WxGUITextEditorUser,
60 public WxGUIHtmlBrowserUser
63 WxGUIScriptingInterface( wxWindow *parent, wxString title, wxSize size);
64 ~WxGUIScriptingInterface();
66 /// Returns the Interpreter used
67 /// ONLY ONE FOR THE MOMENT BUT IN THE FUTURE CAN BE DIFFERENT
68 /// (DIFFERENT WORKSPACES)
69 Interpreter* GetInterpreter() { return mInterpreter; }
70 /// Returns the Interpreter used (const)
71 const Interpreter* GetInterpreter() const { return mInterpreter; }
73 /// Sets the inputs of the workspace :
74 /// the map is passed as is to the Executer
75 void SetInputs(const std::map<std::string,std::string>& m)
76 { mInterpreter->SetInputs(m); }
78 /// Puts the executer in "no exec" mode,
79 /// which creates but does not execute pipelines.
80 void SetNoExecMode(bool b) { mInterpreter->SetNoExecMode(b); }
82 void SetDialogMode(Interpreter::DialogModeType t)
83 { mInterpreter->SetDialogMode(t); }
85 /// Runs the interpretation of a file
86 /// Returns false on error
87 bool InterpretFile( const std::string& filename);
89 void Open(const std::string& filename);
92 void OnMenuQuit(wxCommandEvent& event);
93 void OnMenuAbout(wxCommandEvent& event);
94 void OnMenuEditConfig(wxCommandEvent& WXUNUSED(event));
95 void OnMenuCreatePackage(wxCommandEvent& WXUNUSED(event));
96 void OnMenuCreateBlackBox(wxCommandEvent& WXUNUSED(event));
97 void OnMenuShowImageGraph(wxCommandEvent& WXUNUSED(event));
98 void OnMenuCreateIndex(wxCommandEvent& WXUNUSED(event));
101 // void OnButtonRun(wxCommandEvent& WXUNUSED(event));
103 // Interpreter callbacks
104 bool InterpreterUserHasOwnHtmlPageViewer() { return true; }
105 void InterpreterUserViewHtmlPage(const std::string&);
107 // WxGUICommand callbacks
108 void WxGUICommandEnter(const std::string&);
110 // WxGUITextEditor callbacks
111 void WxGUITextEditorRun();
113 // WxGUIHtmlBrowser callbacks
114 bool WxGUIHtmlBrowserUserOnLinkClicked(const std::string& target);
117 Interpreter* mInterpreter;
120 //EED wxNotebook* mwxNotebook;
121 // wxAuiNotebook* mwxNotebook;
122 // wxPanel *mwxPageCommand, *mwxPageHelp;
124 WxGUICommand* mWxGUICommand;
125 WxGUIOutputMessages* mWxGUIOutputMessages;
126 WxGUIHtmlBrowser* mWxGUIHtmlBrowser;
127 WxGUITextEditor* mWxGUITextEditor;
129 // wxButton* mwxButtonRun;
134 DECLARE_EVENT_TABLE()
142 #endif // __bbtkWxGUIScriptingInterface_h__
144 #endif //_USE_WXWIDGETS_