-rw-r--r-- | noncore/apps/opie-console/MyPty.cpp | 17 | ||||
-rw-r--r-- | noncore/apps/opie-console/consoleconfigwidget.cpp | 11 | ||||
-rw-r--r-- | noncore/apps/opie-console/profileeditordialog.cpp | 2 |
3 files changed, 25 insertions, 5 deletions
diff --git a/noncore/apps/opie-console/MyPty.cpp b/noncore/apps/opie-console/MyPty.cpp index b0f0275..c3c58be 100644 --- a/noncore/apps/opie-console/MyPty.cpp +++ b/noncore/apps/opie-console/MyPty.cpp | |||
@@ -198,158 +198,173 @@ int MyPty::run(const char* cmd, QStrList &, const char*, int) | |||
198 | connect(m_sn_r,SIGNAL(activated(int)),this,SLOT(readPty())); | 198 | connect(m_sn_r,SIGNAL(activated(int)),this,SLOT(readPty())); |
199 | connect(m_sn_e,SIGNAL(activated(int)),this,SLOT(error())); | 199 | connect(m_sn_e,SIGNAL(activated(int)),this,SLOT(error())); |
200 | 200 | ||
201 | return 0; | 201 | return 0; |
202 | } | 202 | } |
203 | 203 | ||
204 | int MyPty::openPty() | 204 | int MyPty::openPty() |
205 | { | 205 | { |
206 | // This is code from the Qt DumbTerminal example | 206 | // This is code from the Qt DumbTerminal example |
207 | int ptyfd = -1; | 207 | int ptyfd = -1; |
208 | 208 | ||
209 | #ifdef HAVE_OPENPTY | 209 | #ifdef HAVE_OPENPTY |
210 | int ttyfd; | 210 | int ttyfd; |
211 | if ( openpty(&ptyfd,&ttyfd,ttynam,0,0) ) | 211 | if ( openpty(&ptyfd,&ttyfd,ttynam,0,0) ) |
212 | ptyfd = -1; | 212 | ptyfd = -1; |
213 | else | 213 | else |
214 | close(ttyfd); // we open the ttynam ourselves. | 214 | close(ttyfd); // we open the ttynam ourselves. |
215 | #else | 215 | #else |
216 | for (const char* c0 = "pqrstuvwxyzabcde"; ptyfd < 0 && *c0 != 0; c0++) { | 216 | for (const char* c0 = "pqrstuvwxyzabcde"; ptyfd < 0 && *c0 != 0; c0++) { |
217 | for (const char* c1 = "0123456789abcdef"; ptyfd < 0 && *c1 != 0; c1++) { | 217 | for (const char* c1 = "0123456789abcdef"; ptyfd < 0 && *c1 != 0; c1++) { |
218 | sprintf(m_ptynam,"/dev/pty%c%c",*c0,*c1); | 218 | sprintf(m_ptynam,"/dev/pty%c%c",*c0,*c1); |
219 | sprintf(m_ttynam,"/dev/tty%c%c",*c0,*c1); | 219 | sprintf(m_ttynam,"/dev/tty%c%c",*c0,*c1); |
220 | if ((ptyfd = ::open(m_ptynam,O_RDWR)) >= 0) { | 220 | if ((ptyfd = ::open(m_ptynam,O_RDWR)) >= 0) { |
221 | if (geteuid() != 0 && !access(m_ttynam,R_OK|W_OK) == 0) { | 221 | if (geteuid() != 0 && !access(m_ttynam,R_OK|W_OK) == 0) { |
222 | ::close(ptyfd); | 222 | ::close(ptyfd); |
223 | ptyfd = -1; | 223 | ptyfd = -1; |
224 | } | 224 | } |
225 | } | 225 | } |
226 | } | 226 | } |
227 | } | 227 | } |
228 | #endif | 228 | #endif |
229 | 229 | ||
230 | if ( ptyfd < 0 ) { | 230 | if ( ptyfd < 0 ) { |
231 | //qApp->exit(1); | 231 | //qApp->exit(1); |
232 | return -1; | 232 | return -1; |
233 | } | 233 | } |
234 | 234 | ||
235 | return ptyfd; | 235 | return ptyfd; |
236 | } | 236 | } |
237 | 237 | ||
238 | /*! | 238 | /*! |
239 | Create an instance. | 239 | Create an instance. |
240 | */ | 240 | */ |
241 | MyPty::MyPty(const Profile& prof) : m_cpid(0) | 241 | MyPty::MyPty(const Profile& prof) : m_cpid(0) |
242 | { | 242 | { |
243 | 243 | ||
244 | int term = prof.readNumEntry("Terminal", Profile::VT100 ); | 244 | int term = prof.readNumEntry("Terminal", Profile::VT100 ); |
245 | switch( term ) { | 245 | switch( term ) { |
246 | default: | 246 | default: |
247 | case Profile::VT100: | 247 | case Profile::VT100: |
248 | case Profile::VT102: | 248 | case Profile::VT102: |
249 | m_term = "vt100"; | 249 | m_term = "vt100"; |
250 | break; | 250 | break; |
251 | case Profile::Linux: | 251 | case Profile::Linux: |
252 | m_term = "linux"; | 252 | m_term = "linux"; |
253 | break; | 253 | break; |
254 | case Profile::XTerm: | 254 | case Profile::XTerm: |
255 | m_term = "xterm"; | 255 | m_term = "xterm"; |
256 | break; | 256 | break; |
257 | } | 257 | } |
258 | m_sn_e = 0l; | 258 | m_sn_e = 0l; |
259 | m_sn_r = 0l; | 259 | m_sn_r = 0l; |
260 | m_fd = openPty(); | 260 | m_fd = openPty(); |
261 | ProcCtl* ctl = ProcCtl::self(); | 261 | ProcCtl* ctl = ProcCtl::self(); |
262 | Q_UNUSED(ctl); | 262 | Q_UNUSED(ctl); |
263 | reload(prof); | 263 | reload(prof); |
264 | } | 264 | } |
265 | 265 | ||
266 | /*! | 266 | /*! |
267 | Destructor. | 267 | Destructor. |
268 | Note that the related client program is not killed | 268 | Note that the related client program is not killed |
269 | (yet) when a instance is deleted. | 269 | (yet) when a instance is deleted. |
270 | */ | 270 | */ |
271 | MyPty::~MyPty() | 271 | MyPty::~MyPty() |
272 | { | 272 | { |
273 | donePty(); | 273 | donePty(); |
274 | } | 274 | } |
275 | QString MyPty::identifier()const { | 275 | QString MyPty::identifier()const { |
276 | return QString::fromLatin1("term"); | 276 | return QString::fromLatin1("term"); |
277 | } | 277 | } |
278 | QString MyPty::name()const{ | 278 | QString MyPty::name()const{ |
279 | return identifier(); | 279 | return identifier(); |
280 | } | 280 | } |
281 | bool MyPty::open() { | 281 | bool MyPty::open() { |
282 | if (m_fd < 0) | 282 | if (m_fd < 0) |
283 | m_fd = openPty(); | 283 | m_fd = openPty(); |
284 | 284 | ||
285 | start(); | 285 | start(); |
286 | return true; | 286 | return true; |
287 | } | 287 | } |
288 | void MyPty::close() { | 288 | void MyPty::close() { |
289 | donePty(); | 289 | donePty(); |
290 | m_fd = openPty(); | 290 | m_fd = openPty(); |
291 | } | 291 | } |
292 | void MyPty::reload( const Profile& prof) { | 292 | void MyPty::reload( const Profile& prof) { |
293 | m_env.clear(); | 293 | m_env.clear(); |
294 | m_cmd = prof.readEntry("Command", "/bin/bash"); | 294 | m_cmd = prof.readEntry("Command", "/bin/sh"); |
295 | |||
296 | /* | ||
297 | * Lets check if m_cmd actually | ||
298 | * exists.... | ||
299 | * we try to use bin/bash and if | ||
300 | * this fails we | ||
301 | * will fallback to /bin/sh | ||
302 | * which should be there 100% | ||
303 | */ | ||
304 | if ( !QFile::exists(QFile::encodeName(m_cmd) ) ) | ||
305 | if (QFile::exists("/bin/bash") ) | ||
306 | m_cmd = "/bin/bash"; | ||
307 | else | ||
308 | m_cmd = "/bin/sh"; | ||
309 | |||
295 | int envcount = prof.readNumEntry("EnvVars", 0); | 310 | int envcount = prof.readNumEntry("EnvVars", 0); |
296 | for (int i=0; i<envcount; i++) { | 311 | for (int i=0; i<envcount; i++) { |
297 | QString name = prof.readEntry("Env_Name_" + QString::number(i), ""); | 312 | QString name = prof.readEntry("Env_Name_" + QString::number(i), ""); |
298 | QString value = prof.readEntry("Env_Value_" + QString::number(i), ""); | 313 | QString value = prof.readEntry("Env_Value_" + QString::number(i), ""); |
299 | if (!(name.isEmpty() || value.isEmpty())) { | 314 | if (!(name.isEmpty() || value.isEmpty())) { |
300 | m_env.insert(name, value); | 315 | m_env.insert(name, value); |
301 | } | 316 | } |
302 | } | 317 | } |
303 | } | 318 | } |
304 | /*! sends len bytes through the line */ | 319 | /*! sends len bytes through the line */ |
305 | void MyPty::send(const QByteArray& ar) | 320 | void MyPty::send(const QByteArray& ar) |
306 | { | 321 | { |
307 | #ifdef VERBOSE_DEBUG | 322 | #ifdef VERBOSE_DEBUG |
308 | // verbose debug | 323 | // verbose debug |
309 | printf("sending bytes:\n"); | 324 | printf("sending bytes:\n"); |
310 | for (uint i = 0; i < ar.count(); i++) | 325 | for (uint i = 0; i < ar.count(); i++) |
311 | printf("%c", ar[i]); | 326 | printf("%c", ar[i]); |
312 | printf("\n"); | 327 | printf("\n"); |
313 | #endif | 328 | #endif |
314 | 329 | ||
315 | ::write(m_fd, ar.data(), ar.count()); | 330 | ::write(m_fd, ar.data(), ar.count()); |
316 | } | 331 | } |
317 | 332 | ||
318 | /*! indicates that a block of data is received */ | 333 | /*! indicates that a block of data is received */ |
319 | void MyPty::readPty() | 334 | void MyPty::readPty() |
320 | { | 335 | { |
321 | QByteArray buf(4096); | 336 | QByteArray buf(4096); |
322 | 337 | ||
323 | int len = ::read( m_fd, buf.data(), 4096 ); | 338 | int len = ::read( m_fd, buf.data(), 4096 ); |
324 | 339 | ||
325 | if (len == -1 || len == 0) { | 340 | if (len == -1 || len == 0) { |
326 | donePty(); | 341 | donePty(); |
327 | return; | 342 | return; |
328 | } | 343 | } |
329 | 344 | ||
330 | if (len < 0) | 345 | if (len < 0) |
331 | return; | 346 | return; |
332 | 347 | ||
333 | 348 | ||
334 | buf.resize(len); | 349 | buf.resize(len); |
335 | emit received(buf); | 350 | emit received(buf); |
336 | 351 | ||
337 | #ifdef VERBOSE_DEBUG | 352 | #ifdef VERBOSE_DEBUG |
338 | // verbose debug | 353 | // verbose debug |
339 | printf("read bytes:\n"); | 354 | printf("read bytes:\n"); |
340 | for (uint i = 0; i < buf.count(); i++) | 355 | for (uint i = 0; i < buf.count(); i++) |
341 | printf("%c", buf[i]); | 356 | printf("%c", buf[i]); |
342 | printf("\n"); | 357 | printf("\n"); |
343 | #endif | 358 | #endif |
344 | 359 | ||
345 | } | 360 | } |
346 | QBitArray MyPty::supports()const { | 361 | QBitArray MyPty::supports()const { |
347 | QBitArray ar(3); | 362 | QBitArray ar(3); |
348 | //autoconnect | 363 | //autoconnect |
349 | ar[0] = 1; | 364 | ar[0] = 1; |
350 | // | 365 | // |
351 | ar[1] = 0; | 366 | ar[1] = 0; |
352 | ar[2] = 0; | 367 | ar[2] = 0; |
353 | 368 | ||
354 | return ar; | 369 | return ar; |
355 | } | 370 | } |
diff --git a/noncore/apps/opie-console/consoleconfigwidget.cpp b/noncore/apps/opie-console/consoleconfigwidget.cpp index 70e2e78..3f2d154 100644 --- a/noncore/apps/opie-console/consoleconfigwidget.cpp +++ b/noncore/apps/opie-console/consoleconfigwidget.cpp | |||
@@ -1,95 +1,100 @@ | |||
1 | #include <qlabel.h> | 1 | #include <qlabel.h> |
2 | #include <qlayout.h> | 2 | #include <qlayout.h> |
3 | #include <qcombobox.h> | 3 | #include <qcombobox.h> |
4 | #include <qlineedit.h> | 4 | #include <qlineedit.h> |
5 | #include <qpushbutton.h> | 5 | #include <qpushbutton.h> |
6 | #include <qlistview.h> | 6 | #include <qlistview.h> |
7 | #include <qhbox.h> | 7 | #include <qhbox.h> |
8 | #include <qregexp.h> | 8 | #include <qregexp.h> |
9 | #include <stdio.h> | 9 | #include <stdio.h> |
10 | 10 | ||
11 | #include "consoleconfigwidget.h" | 11 | #include "consoleconfigwidget.h" |
12 | 12 | ||
13 | ConsoleConfigWidget::ConsoleConfigWidget( const QString& name, QWidget* parent, | 13 | ConsoleConfigWidget::ConsoleConfigWidget( const QString& name, QWidget* parent, |
14 | const char* na ) | 14 | const char* na ) |
15 | : ProfileDialogConnectionWidget( name, parent, na ) { | 15 | : ProfileDialogConnectionWidget( name, parent, na ) { |
16 | m_lay = new QVBoxLayout( this ); | 16 | m_lay = new QVBoxLayout( this ); |
17 | QLabel *label = new QLabel(tr("Command to execute"), this); | 17 | QLabel *label = new QLabel(tr("Command to execute"), this); |
18 | m_lay->addWidget(label); | 18 | m_lay->addWidget(label); |
19 | m_cmd = new QLineEdit(this); | 19 | m_cmd = new QLineEdit(this); |
20 | m_lay->addWidget(m_cmd); | 20 | m_lay->addWidget(m_cmd); |
21 | label = new QLabel(tr("Environment Variables"), this); | 21 | label = new QLabel(tr("Environment Variables"), this); |
22 | m_lay->addWidget(label); | 22 | m_lay->addWidget(label); |
23 | m_env = new QListView(this); | 23 | m_env = new QListView(this); |
24 | m_env->addColumn(tr("Name")); | 24 | m_env->addColumn(tr("Name")); |
25 | m_env->addColumn(tr("Value")); | 25 | m_env->addColumn(tr("Value")); |
26 | m_lay->addWidget(m_env); | 26 | m_lay->addWidget(m_env); |
27 | 27 | ||
28 | QHBox *hbox = new QHBox(this); | 28 | QHBox *hbox = new QHBox(this); |
29 | label = new QLabel(tr("Name :"), hbox); | 29 | label = new QLabel(tr("Name :"), hbox); |
30 | m_name = new QLineEdit(hbox); | 30 | m_name = new QLineEdit(hbox); |
31 | m_lay->addWidget(hbox); | 31 | m_lay->addWidget(hbox); |
32 | 32 | ||
33 | hbox = new QHBox(this); | 33 | hbox = new QHBox(this); |
34 | label = new QLabel(tr("Value :"), hbox); | 34 | label = new QLabel(tr("Value :"), hbox); |
35 | m_value = new QLineEdit(hbox); | 35 | m_value = new QLineEdit(hbox); |
36 | m_lay->addWidget(hbox); | 36 | m_lay->addWidget(hbox); |
37 | 37 | ||
38 | hbox = new QHBox(this); | 38 | hbox = new QHBox(this); |
39 | hbox->setSpacing(10); | 39 | hbox->setSpacing(10); |
40 | m_remove = new QPushButton(tr("Remove"), hbox); | 40 | m_remove = new QPushButton(tr("Remove"), hbox); |
41 | connect(m_remove, SIGNAL(clicked()), this, SLOT(slotRemove())); | 41 | connect(m_remove, SIGNAL(clicked()), this, SLOT(slotRemove())); |
42 | m_add = new QPushButton(tr("Add"), hbox); | 42 | m_add = new QPushButton(tr("Add"), hbox); |
43 | connect(m_add, SIGNAL(clicked()), this, SLOT(slotAdd())); | 43 | connect(m_add, SIGNAL(clicked()), this, SLOT(slotAdd())); |
44 | m_lay->addWidget(hbox); | 44 | m_lay->addWidget(hbox); |
45 | } | 45 | } |
46 | 46 | ||
47 | void ConsoleConfigWidget::slotAdd() { | 47 | void ConsoleConfigWidget::slotAdd() { |
48 | if (!(m_name->text().isEmpty() || m_value->text().isEmpty())) { | 48 | if (!(m_name->text().isEmpty() || m_value->text().isEmpty())) { |
49 | QListViewItem *item = new QListViewItem(m_env); | 49 | QListViewItem *item = new QListViewItem(m_env); |
50 | item->setText(0, m_name->text()); | 50 | item->setText(0, m_name->text()); |
51 | item->setText(1, m_value->text()); | 51 | item->setText(1, m_value->text()); |
52 | m_env->insertItem(item); | 52 | m_env->insertItem(item); |
53 | } | 53 | } |
54 | } | 54 | } |
55 | 55 | ||
56 | void ConsoleConfigWidget::slotRemove() { | 56 | void ConsoleConfigWidget::slotRemove() { |
57 | QListViewItem *item = m_env->currentItem(); | 57 | QListViewItem *item = m_env->currentItem(); |
58 | if (item) { | 58 | if (item) { |
59 | m_env->takeItem(item); | 59 | m_env->takeItem(item); |
60 | } | 60 | } |
61 | } | 61 | } |
62 | 62 | ||
63 | ConsoleConfigWidget::~ConsoleConfigWidget() { | 63 | ConsoleConfigWidget::~ConsoleConfigWidget() { |
64 | } | 64 | } |
65 | 65 | ||
66 | void ConsoleConfigWidget::load( const Profile& prof ) { | 66 | void ConsoleConfigWidget::load( const Profile& prof ) { |
67 | /* | ||
68 | * we will use /bin/bash as default | ||
69 | * but will fallback in MyPty to /bin/sh | ||
70 | * if necessary | ||
71 | */ | ||
67 | m_cmd->setText(prof.readEntry("Command", "/bin/bash")); | 72 | m_cmd->setText(prof.readEntry("Command", "/bin/bash")); |
68 | int envcount = prof.readNumEntry("EnvVars", 0); | 73 | int envcount = prof.readNumEntry("EnvVars", 0); |
69 | for (int i=0; i<envcount; i++) { | 74 | for (int i=0; i<envcount; i++) { |
70 | QString name = prof.readEntry("Env_Name_" + QString::number(i), ""); | 75 | QString name = prof.readEntry("Env_Name_" + QString::number(i), ""); |
71 | QString value = prof.readEntry("Env_Value_" + QString::number(i), ""); | 76 | QString value = prof.readEntry("Env_Value_" + QString::number(i), ""); |
72 | if (!(name.isEmpty() || value.isEmpty())) { | 77 | if (!(name.isEmpty() || value.isEmpty())) { |
73 | QListViewItem *item = new QListViewItem(m_env); | 78 | QListViewItem *item = new QListViewItem(m_env); |
74 | item->setText(0, name); | 79 | item->setText(0, name); |
75 | item->setText(1, value); | 80 | item->setText(1, value); |
76 | m_env->insertItem(item); | 81 | m_env->insertItem(item); |
77 | } | 82 | } |
78 | } | 83 | } |
79 | } | 84 | } |
80 | 85 | ||
81 | void ConsoleConfigWidget::save( Profile& prof ) { | 86 | void ConsoleConfigWidget::save( Profile& prof ) { |
82 | prof.writeEntry( "Command", m_cmd->text()); | 87 | prof.writeEntry( "Command", m_cmd->text()); |
83 | QListViewItem *item = m_env->firstChild(); | 88 | QListViewItem *item = m_env->firstChild(); |
84 | int counter = 0; | 89 | int counter = 0; |
85 | while (item) { | 90 | while (item) { |
86 | QString name = item->text(0); | 91 | QString name = item->text(0); |
87 | QString value = item->text(1); | 92 | QString value = item->text(1); |
88 | prof.writeEntry("Env_Name_" + QString::number(counter), name); | 93 | prof.writeEntry("Env_Name_" + QString::number(counter), name); |
89 | prof.writeEntry("Env_Value_" + QString::number(counter), value); | 94 | prof.writeEntry("Env_Value_" + QString::number(counter), value); |
90 | item = item->nextSibling(); | 95 | item = item->nextSibling(); |
91 | counter++; | 96 | counter++; |
92 | } | 97 | } |
93 | prof.writeEntry("EnvVars", QString::number(counter)); | 98 | prof.writeEntry("EnvVars", QString::number(counter)); |
94 | } | 99 | } |
95 | 100 | ||
diff --git a/noncore/apps/opie-console/profileeditordialog.cpp b/noncore/apps/opie-console/profileeditordialog.cpp index fd04b6b..6b607df 100644 --- a/noncore/apps/opie-console/profileeditordialog.cpp +++ b/noncore/apps/opie-console/profileeditordialog.cpp | |||
@@ -107,133 +107,133 @@ void ProfileEditorDialog::initUI() | |||
107 | tabWidget->addTab(m_tabCon, "", QObject::tr("Connection")); | 107 | tabWidget->addTab(m_tabCon, "", QObject::tr("Connection")); |
108 | tabWidget->addTab(m_tabTerm, "", QObject::tr("Terminal")); | 108 | tabWidget->addTab(m_tabTerm, "", QObject::tr("Terminal")); |
109 | tabWidget->addTab(m_tabKey, "", QObject::tr("Special Keys")); | 109 | tabWidget->addTab(m_tabKey, "", QObject::tr("Special Keys")); |
110 | tabWidget->setCurrentTab( tabprof ); | 110 | tabWidget->setCurrentTab( tabprof ); |
111 | 111 | ||
112 | 112 | ||
113 | // fill the comboboxes | 113 | // fill the comboboxes |
114 | QStringList list = m_fact->connectionWidgets(); | 114 | QStringList list = m_fact->connectionWidgets(); |
115 | QStringList::Iterator it; | 115 | QStringList::Iterator it; |
116 | for (it =list.begin(); it != list.end(); ++it ) { | 116 | for (it =list.begin(); it != list.end(); ++it ) { |
117 | m_conCmb->insertItem( (*it) ); | 117 | m_conCmb->insertItem( (*it) ); |
118 | } | 118 | } |
119 | list = m_fact->terminalWidgets(); | 119 | list = m_fact->terminalWidgets(); |
120 | for (it =list.begin(); it != list.end(); ++it ) { | 120 | for (it =list.begin(); it != list.end(); ++it ) { |
121 | m_termCmb->insertItem( (*it) ); | 121 | m_termCmb->insertItem( (*it) ); |
122 | } | 122 | } |
123 | 123 | ||
124 | // load profile values | 124 | // load profile values |
125 | m_name->setText(m_prof.name()); | 125 | m_name->setText(m_prof.name()); |
126 | slotConActivated( m_fact->external(m_prof.ioLayerName() ) ); | 126 | slotConActivated( m_fact->external(m_prof.ioLayerName() ) ); |
127 | slotTermActivated( m_fact->external(m_prof.terminalName() ) ); | 127 | slotTermActivated( m_fact->external(m_prof.terminalName() ) ); |
128 | slotKeyActivated( "Default Keyboard" ); | 128 | slotKeyActivated( "Default Keyboard" ); |
129 | setCurrent( m_fact->external(m_prof.ioLayerName() ), m_conCmb ); | 129 | setCurrent( m_fact->external(m_prof.ioLayerName() ), m_conCmb ); |
130 | setCurrent( m_fact->external(m_prof.terminalName() ), m_termCmb ); | 130 | setCurrent( m_fact->external(m_prof.terminalName() ), m_termCmb ); |
131 | m_autoConnect->setChecked(m_prof.autoConnect()); | 131 | m_autoConnect->setChecked(m_prof.autoConnect()); |
132 | 132 | ||
133 | 133 | ||
134 | // signal and slots | 134 | // signal and slots |
135 | connect(m_conCmb, SIGNAL(activated(const QString& ) ), | 135 | connect(m_conCmb, SIGNAL(activated(const QString& ) ), |
136 | this, SLOT(slotConActivated(const QString&) ) ); | 136 | this, SLOT(slotConActivated(const QString&) ) ); |
137 | connect(m_termCmb, SIGNAL(activated(const QString& ) ), | 137 | connect(m_termCmb, SIGNAL(activated(const QString& ) ), |
138 | this, SLOT(slotTermActivated(const QString& ) ) ); | 138 | this, SLOT(slotTermActivated(const QString& ) ) ); |
139 | 139 | ||
140 | } | 140 | } |
141 | 141 | ||
142 | ProfileEditorDialog::~ProfileEditorDialog() { | 142 | ProfileEditorDialog::~ProfileEditorDialog() { |
143 | 143 | ||
144 | } | 144 | } |
145 | void ProfileEditorDialog::accept() | 145 | void ProfileEditorDialog::accept() |
146 | { | 146 | { |
147 | if(profName().isEmpty()) | 147 | if(profName().isEmpty()) |
148 | { | 148 | { |
149 | QMessageBox::information(this, | 149 | QMessageBox::information(this, |
150 | QObject::tr("Invalid profile"), | 150 | QObject::tr("Invalid profile"), |
151 | QObject::tr("Please enter a profile name.")); | 151 | QObject::tr("Please enter a profile name.")); |
152 | return; | 152 | return; |
153 | } | 153 | } |
154 | // Save profile and plugin profile | 154 | // Save profile and plugin profile |
155 | //if(plugin_plugin) plugin_plugin->save(); | 155 | //if(plugin_plugin) plugin_plugin->save(); |
156 | 156 | ||
157 | // Save general values | 157 | // Save general values |
158 | m_prof.setName( profName() ); | 158 | m_prof.setName( profName() ); |
159 | m_prof.setIOLayer( m_fact->internal(m_conCmb ->currentText() ) ); | 159 | m_prof.setIOLayer( m_fact->internal(m_conCmb ->currentText() ) ); |
160 | m_prof.setTerminalName( m_fact->internal(m_termCmb->currentText() ) ); | 160 | m_prof.setTerminalName( m_fact->internal(m_termCmb->currentText() ) ); |
161 | m_prof.setAutoConnect( m_autoConnect->isChecked() ); | 161 | m_prof.setAutoConnect( m_autoConnect->isChecked() ); |
162 | 162 | ||
163 | if (m_con ) | 163 | if (m_con ) |
164 | m_con->save( m_prof ); | 164 | m_con->save( m_prof ); |
165 | if (m_term ) | 165 | if (m_term ) |
166 | m_term->save( m_prof ); | 166 | m_term->save( m_prof ); |
167 | if (m_key) | 167 | if (m_key) |
168 | m_key->save( m_prof ); | 168 | m_key->save( m_prof ); |
169 | 169 | ||
170 | QDialog::accept(); | 170 | QDialog::accept(); |
171 | } | 171 | } |
172 | 172 | ||
173 | 173 | ||
174 | QString ProfileEditorDialog::profName()const | 174 | QString ProfileEditorDialog::profName()const |
175 | { | 175 | { |
176 | return m_name->text(); | 176 | return m_name->text(); |
177 | } | 177 | } |
178 | 178 | ||
179 | QCString ProfileEditorDialog::profType()const | 179 | QCString ProfileEditorDialog::profType()const |
180 | { | 180 | { |
181 | /*QStringList w = m_fact->configWidgets(); | 181 | /*QStringList w = m_fact->configWidgets(); |
182 | for(QStringList::Iterator it = w.begin(); it != w.end(); it++) | 182 | for(QStringList::Iterator it = w.begin(); it != w.end(); it++) |
183 | if(device_box->currentText() == m_fact->name((*it))) return (*it); | 183 | if(device_box->currentText() == m_fact->name((*it))) return (*it); |
184 | */ | 184 | */ |
185 | return QCString(); | 185 | return QCString(); |
186 | } | 186 | } |
187 | /* | 187 | /* |
188 | * we need to switch the widget | 188 | * we need to switch the widget |
189 | */ | 189 | */ |
190 | void ProfileEditorDialog::slotConActivated( const QString& str ) { | 190 | void ProfileEditorDialog::slotConActivated( const QString& str ) { |
191 | 191 | ||
192 | delete m_con; | 192 | delete m_con; |
193 | 193 | ||
194 | m_con = m_fact->newConnectionPlugin( str, m_svCon->viewport() ); | 194 | m_con = m_fact->newConnectionPlugin( str, m_svCon->viewport() ); |
195 | 195 | ||
196 | if ( !m_con ) { | 196 | if ( !m_con ) { |
197 | m_con = new NoOptions( str, m_svCon->viewport(), "name"); | 197 | m_con = new NoOptions( str, m_svCon->viewport(), "name"); |
198 | } | 198 | } |
199 | 199 | ||
200 | // FIXME ugly hack right. Right solution would be to look into the layer and see if it | 200 | // FIXME ugly hack right. Right solution would be to look into the layer and see if it |
201 | // supports auto connect and then set it as prefered | 201 | // supports auto connect and then set it as prefered |
202 | //if ( ( )->layer()->supports()[0] == 1 ) { | 202 | //if ( ( )->layer()->supports()[0] == 1 ) { |
203 | if ( m_conCmb ->currentText() == tr("local Console") ) { | 203 | if ( m_conCmb ->currentText() == tr("Local Console") ) { |
204 | m_autoConnect->setChecked( true ); | 204 | m_autoConnect->setChecked( true ); |
205 | } else { | 205 | } else { |
206 | m_autoConnect->setChecked( false ); | 206 | m_autoConnect->setChecked( false ); |
207 | } | 207 | } |
208 | 208 | ||
209 | m_con->load( m_prof ); | 209 | m_con->load( m_prof ); |
210 | m_svCon->addChild( m_con ); | 210 | m_svCon->addChild( m_con ); |
211 | } | 211 | } |
212 | 212 | ||
213 | 213 | ||
214 | /* | 214 | /* |
215 | * we need to switch the widget | 215 | * we need to switch the widget |
216 | */ | 216 | */ |
217 | void ProfileEditorDialog::slotTermActivated( const QString& str ) { | 217 | void ProfileEditorDialog::slotTermActivated( const QString& str ) { |
218 | 218 | ||
219 | delete m_term; | 219 | delete m_term; |
220 | 220 | ||
221 | m_term = m_fact->newTerminalPlugin( str, m_svTerm->viewport() ); | 221 | m_term = m_fact->newTerminalPlugin( str, m_svTerm->viewport() ); |
222 | 222 | ||
223 | if (m_term) { | 223 | if (m_term) { |
224 | m_term->load( m_prof ); | 224 | m_term->load( m_prof ); |
225 | m_svTerm->addChild( m_term ); | 225 | m_svTerm->addChild( m_term ); |
226 | } | 226 | } |
227 | } | 227 | } |
228 | 228 | ||
229 | void ProfileEditorDialog::slotKeyActivated(const QString &str) { | 229 | void ProfileEditorDialog::slotKeyActivated(const QString &str) { |
230 | delete m_key; | 230 | delete m_key; |
231 | m_key = m_fact->newKeyboardPlugin( str, m_tabKey ); | 231 | m_key = m_fact->newKeyboardPlugin( str, m_tabKey ); |
232 | 232 | ||
233 | if (m_key) { | 233 | if (m_key) { |
234 | 234 | ||
235 | m_key->load(m_prof); | 235 | m_key->load(m_prof); |
236 | m_layKey->addWidget(m_key); | 236 | m_layKey->addWidget(m_key); |
237 | } | 237 | } |
238 | 238 | ||
239 | } | 239 | } |