1 /*=========================================================================
4 Module: $RCSfile: bbtkWxGUIScriptingInterface.h,v $
6 Date: $Date: 2008/04/25 07:33:17 $
7 Version: $Revision: 1.6 $
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::Pointer GetInterpreter() const { return mInterpreter; }
71 /// Sets the inputs of the workspace :
72 /// the map is passed as is to the Executer
73 void SetInputs(const std::map<std::string,std::string>& m)
74 { mInterpreter->SetInputs(m); }
76 /// Puts the executer in "no exec" mode,
77 /// which creates but does not execute pipelines.
78 void SetNoExecMode(bool b) { mInterpreter->SetNoExecMode(b); }
80 void SetDialogMode(Interpreter::DialogModeType t)
81 { mInterpreter->SetDialogMode(t); }
83 /// Runs the interpretation of a file
84 /// Returns false on error
85 bool InterpretFile( const std::string& filename);
87 void Open(const std::string& filename);
90 void OnMenuQuit(wxCommandEvent& event);
91 void OnMenuAbout(wxCommandEvent& event);
92 void OnMenuEditConfig(wxCommandEvent& WXUNUSED(event));
93 void OnMenuCreatePackage(wxCommandEvent& WXUNUSED(event));
94 void OnMenuCreateBlackBox(wxCommandEvent& WXUNUSED(event));
95 void OnMenuShowImageGraph(wxCommandEvent& WXUNUSED(event));
96 void OnMenuCreateIndex(wxCommandEvent& WXUNUSED(event));
97 void OnMenuWindowsFiles(wxCommandEvent& event);
98 void OnMenuWindowsHelp(wxCommandEvent& event);
99 void OnMenuWindowsMessages(wxCommandEvent& event);
100 void OnMenuWindowsCommand(wxCommandEvent& event);
101 void OnMenuWindowsSave( wxCommandEvent& WXUNUSED(event));
102 void OnMenuWindowsCheck( wxCommandEvent& event,
104 void OnPaneClose(wxAuiManagerEvent& evt);
107 // void OnButtonRun(wxCommandEvent& WXUNUSED(event));
109 // Interpreter callbacks
110 bool InterpreterUserHasOwnHtmlPageViewer() { return true; }
111 void InterpreterUserViewHtmlPage(const std::string&);
113 // WxGUICommand callbacks
114 void WxGUICommandEnter(const std::string&);
116 // WxGUITextEditor callbacks
117 void WxGUITextEditorRun();
119 // WxGUIHtmlBrowser callbacks
120 bool WxGUIHtmlBrowserUserOnLinkClicked(const std::string& target);
123 Interpreter::Pointer mInterpreter;
125 wxAuiNotebook* mwxNotebook;
128 //EED wxNotebook* mwxNotebook;
129 // wxAuiNotebook* mwxNotebook;
130 // wxPanel *mwxPageCommand, *mwxPageHelp;
132 WxGUICommand* mWxGUICommand;
133 WxGUIOutputMessages* mWxGUIOutputMessages;
134 WxGUIHtmlBrowser* mWxGUIHtmlBrowser;
135 WxGUITextEditor* mWxGUITextEditor;
137 wxMenuItem* mwxMenuItemReset;
138 // wxButton* mwxButtonRun;
143 DECLARE_EVENT_TABLE()
151 #endif // __bbtkWxGUIScriptingInterface_h__
153 #endif //_USE_WXWIDGETS_