1 /**************************************************************
3 Copyright (C) 1997 Oskar Swida
5 This program is free software; you can redistribute it and/or
6 modify it under the terms of the GNU General Public License
7 as published by the Free Software Foundation; either version 2
8 of the License, or (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 NOTE: This software is using the free software license of
23 the QT library v.1.30 from Troll Tech AS.
24 See the file LICENSE.QT.
27 To contact the author, write:
28 e-mail: swida@aragorn.pb.bialystok.pl
30 ************************************************************/
35 #include <QtGui/QMainWindow>
36 #include <QtGui/QListWidget>
37 #include <QtGui/QTextEdit>
38 #include <QtCore/QSocketNotifier>
39 #include <QtCore/QDir>
43 #include "ui/kernelwindow.h"
48 #define REMOTE_PATH "REMOTE"
50 #define MAXINSTANCES 256
66 /** Interpreter identifier */
68 /** Defines if interpreter is remote or not */
76 QSocketNotifier *notify;
77 /* IDs of my remote INT modules */
78 int RInstances[MAXINSTANCES];
79 /* Parent interpreter info */
90 ConnectEntry(char *s) {
94 ConnectEntry(const char *s) {
103 class QKernel : public QMainWindow, private Ui::KernelWindow {
111 QKernel(int argc, char **argv);
113 void WriteMessage(const char * msg);
117 void IntMessage(int);
120 virtual void closeEvent (QCloseEvent * e);
123 QList<InterpEntry*> Interpreters;
124 QList<ConnectEntry*> ConnectList;
127 * number of working interpreters
128 * @attention Currently not in use
133 * number of connected VLPs
135 int ActiveConnections;
137 * Indicates state of the Kernel Program. Is it locked or not.
146 QSocketNotifier *Net_Notify;
151 void loadConfig(const QString &fname);
152 void loadConfig(const char *);
154 void RunGraphModule(char*);
156 InterpEntry *findINTbySocket(int);
157 InterpEntry *findINTbyID(int);
158 InterpEntry *RunIntModule(char *ss, int r);
159 void RemoteInstance(InterpEntry*, int);
160 void CloseInstances(InterpEntry*);
163 * Sets QKernel menu entries to the given status
164 * @param locked status which will be set on the menu entries.
166 void setLocked(bool locked);
168 QString getConfigFilePath();
169 const char * getHomeDir();
170 const char * getRemoteDir();
172 const char * getNetModuleSocket();
173 const char * getGraphModuleSocket();
176 void on_actionExecute_triggered();
177 void on_actionKill_triggered();
178 void on_actionQuit_triggered();
180 void on_actionMessage_triggered();
181 void on_actionConnect_triggered();
182 void on_actionDisconnect_triggered();
183 void on_actionInfo_triggered();
185 void on_actionEditor_triggered();
186 void on_actionHelp_triggered();
187 void on_actionOptions_triggered();
188 void on_actionInfo_messages_triggered();
189 void on_actionLock_console_triggered();
190 void on_actionUnlock_console_triggered();
196 #endif /* VLP_KERNEL_H */