summaryrefslogtreecommitdiff
path: root/noncore/apps/opie-console/mainwindow.cpp
authorjosef <josef>2002-11-01 11:12:54 (UTC)
committer josef <josef>2002-11-01 11:12:54 (UTC)
commit4c5a56dbaddb3ac6b587c61a8ba6841987cf60fa (patch) (unidiff)
tree0172b37a635518ab48dcd0919d803371722a58c6 /noncore/apps/opie-console/mainwindow.cpp
parentf99ad6016519a2f553c52812bac7859adb9aaa94 (diff)
downloadopie-4c5a56dbaddb3ac6b587c61a8ba6841987cf60fa.zip
opie-4c5a56dbaddb3ac6b587c61a8ba6841987cf60fa.tar.gz
opie-4c5a56dbaddb3ac6b587c61a8ba6841987cf60fa.tar.bz2
- allow toggling of line wrap via menu, as requested
If there was an icon, an entry in the menu bar could be made.
Diffstat (limited to 'noncore/apps/opie-console/mainwindow.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/opie-console/mainwindow.cpp43
1 files changed, 43 insertions, 0 deletions
diff --git a/noncore/apps/opie-console/mainwindow.cpp b/noncore/apps/opie-console/mainwindow.cpp
index 936b1b2..d221715 100644
--- a/noncore/apps/opie-console/mainwindow.cpp
+++ b/noncore/apps/opie-console/mainwindow.cpp
@@ -208,32 +208,39 @@ void MainWindow::initUI() {
208 * disconnect action 208 * disconnect action
209 */ 209 */
210 m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"), 210 m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"),
211 QString::null, 0, this, 0 ); 211 QString::null, 0, this, 0 );
212 m_disconnect->addTo( m_console ); 212 m_disconnect->addTo( m_console );
213 connect(m_disconnect, SIGNAL(activated() ), 213 connect(m_disconnect, SIGNAL(activated() ),
214 this, SLOT(slotDisconnect() ) ); 214 this, SLOT(slotDisconnect() ) );
215 215
216 m_console->insertSeparator(); 216 m_console->insertSeparator();
217 217
218 m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null, 218 m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null,
219 0, this, 0 ); 219 0, this, 0 );
220 m_transfer->addTo( m_console ); 220 m_transfer->addTo( m_console );
221 connect(m_transfer, SIGNAL(activated() ), 221 connect(m_transfer, SIGNAL(activated() ),
222 this, SLOT(slotTransfer() ) ); 222 this, SLOT(slotTransfer() ) );
223 223
224 /*
225 * immediate change of line wrap policy
226 */
227 m_isWrapped = false;
228 m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 );
229 m_wrap->addTo( m_console );
230 connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) );
224 231
225 /* 232 /*
226 * fullscreen 233 * fullscreen
227 */ 234 */
228 m_isFullscreen = false; 235 m_isFullscreen = false;
229 236
230 m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" ) 237 m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" )
231 , QString::null, 0, this, 0); 238 , QString::null, 0, this, 0);
232 m_fullscreen->addTo( m_console ); 239 m_fullscreen->addTo( m_console );
233 connect( m_fullscreen, SIGNAL( activated() ), 240 connect( m_fullscreen, SIGNAL( activated() ),
234 this, SLOT( slotFullscreen() ) ); 241 this, SLOT( slotFullscreen() ) );
235 242
236 m_console->insertSeparator(); 243 m_console->insertSeparator();
237 /* 244 /*
238 * terminate action 245 * terminate action
239 */ 246 */
@@ -311,32 +318,33 @@ void MainWindow::initUI() {
311 318
312 newCon->addTo( m_icons ); 319 newCon->addTo( m_icons );
313 m_setProfiles->addTo( m_icons ); 320 m_setProfiles->addTo( m_icons );
314 paste->addTo( m_icons ); 321 paste->addTo( m_icons );
315 m_openKeys->addTo(m_icons); 322 m_openKeys->addTo(m_icons);
316 m_fullscreen->addTo( m_icons ); 323 m_fullscreen->addTo( m_icons );
317 324
318 m_connect->setEnabled( false ); 325 m_connect->setEnabled( false );
319 m_disconnect->setEnabled( false ); 326 m_disconnect->setEnabled( false );
320 m_terminate->setEnabled( false ); 327 m_terminate->setEnabled( false );
321 m_transfer->setEnabled( false ); 328 m_transfer->setEnabled( false );
322 m_scripts->setItemEnabled(m_runScript_id, false); 329 m_scripts->setItemEnabled(m_runScript_id, false);
323 m_recordScript->setEnabled( false ); 330 m_recordScript->setEnabled( false );
324 m_saveScript->setEnabled( false ); 331 m_saveScript->setEnabled( false );
325 m_fullscreen->setEnabled( false ); 332 m_fullscreen->setEnabled( false );
326 m_closewindow->setEnabled( false ); 333 m_closewindow->setEnabled( false );
334 m_wrap->setEnabled( false );
327 335
328 /* 336 /*
329 * connect to the menu activation 337 * connect to the menu activation
330 */ 338 */
331 connect( m_sessionsPop, SIGNAL(activated( int ) ), 339 connect( m_sessionsPop, SIGNAL(activated( int ) ),
332 this, SLOT(slotProfile( int ) ) ); 340 this, SLOT(slotProfile( int ) ) );
333 341
334 m_consoleWindow = new TabWidget( this, "blah"); 342 m_consoleWindow = new TabWidget( this, "blah");
335 connect(m_consoleWindow, SIGNAL(activated(Session*) ), 343 connect(m_consoleWindow, SIGNAL(activated(Session*) ),
336 this, SLOT(slotSessionChanged(Session*) ) ); 344 this, SLOT(slotSessionChanged(Session*) ) );
337 setCentralWidget( m_consoleWindow ); 345 setCentralWidget( m_consoleWindow );
338 346
339} 347}
340 348
341ProfileManager* MainWindow::manager() { 349ProfileManager* MainWindow::manager() {
342 return m_manager; 350 return m_manager;
@@ -512,32 +520,33 @@ void MainWindow::slotClose() {
512 /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */ 520 /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */
513 m_curSession = NULL; 521 m_curSession = NULL;
514 tabWidget()->remove( /*currentSession()*/ses ); 522 tabWidget()->remove( /*currentSession()*/ses );
515 /*it's autodelete */ 523 /*it's autodelete */
516 m_sessions.remove( ses ); 524 m_sessions.remove( ses );
517 qWarning("after remove!!"); 525 qWarning("after remove!!");
518 526
519 if (!currentSession() ) { 527 if (!currentSession() ) {
520 m_connect->setEnabled( false ); 528 m_connect->setEnabled( false );
521 m_disconnect->setEnabled( false ); 529 m_disconnect->setEnabled( false );
522 m_terminate->setEnabled( false ); 530 m_terminate->setEnabled( false );
523 m_transfer->setEnabled( false ); 531 m_transfer->setEnabled( false );
524 m_recordScript->setEnabled( false ); 532 m_recordScript->setEnabled( false );
525 m_saveScript->setEnabled( false ); 533 m_saveScript->setEnabled( false );
526 m_scripts->setItemEnabled(m_runScript_id, false); 534 m_scripts->setItemEnabled(m_runScript_id, false);
527 m_fullscreen->setEnabled( false ); 535 m_fullscreen->setEnabled( false );
536 m_wrap->setEnabled( false );
528 m_closewindow->setEnabled( false ); 537 m_closewindow->setEnabled( false );
529 } 538 }
530 539
531 m_kb->loadDefaults(); 540 m_kb->loadDefaults();
532} 541}
533 542
534/* 543/*
535 * We will get the name 544 * We will get the name
536 * Then the profile 545 * Then the profile
537 * and then we will make a profile 546 * and then we will make a profile
538 */ 547 */
539void MainWindow::slotProfile( int id) { 548void MainWindow::slotProfile( int id) {
540 Profile prof = manager()->profile( m_sessionsPop->text( id) ); 549 Profile prof = manager()->profile( m_sessionsPop->text( id) );
541 create( prof ); 550 create( prof );
542} 551}
543void MainWindow::create( const Profile& prof ) { 552void MainWindow::create( const Profile& prof ) {
@@ -552,48 +561,55 @@ void MainWindow::create( const Profile& prof ) {
552 QObject::tr("Session failed"), 561 QObject::tr("Session failed"),
553 QObject::tr("<qt>Cannot open session: Not all components were found.</qt>")); 562 QObject::tr("<qt>Cannot open session: Not all components were found.</qt>"));
554 //if(ses) delete ses; 563 //if(ses) delete ses;
555 return; 564 return;
556 } 565 }
557 566
558 m_sessions.append( ses ); 567 m_sessions.append( ses );
559 tabWidget()->add( ses ); 568 tabWidget()->add( ses );
560 tabWidget()->repaint(); 569 tabWidget()->repaint();
561 m_curSession = ses; 570 m_curSession = ses;
562 571
563 // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it 572 // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it
564 m_connect->setEnabled( true ); 573 m_connect->setEnabled( true );
565 m_disconnect->setEnabled( false ); 574 m_disconnect->setEnabled( false );
566 m_terminate->setEnabled( true ); 575 m_terminate->setEnabled( true );
567 m_fullscreen->setEnabled( true ); 576 m_fullscreen->setEnabled( true );
577 m_wrap->setEnabled( true );
568 m_closewindow->setEnabled( true ); 578 m_closewindow->setEnabled( true );
569 m_transfer->setEnabled( false ); 579 m_transfer->setEnabled( false );
570 m_recordScript->setEnabled( false ); 580 m_recordScript->setEnabled( false );
571 m_saveScript->setEnabled( false ); 581 m_saveScript->setEnabled( false );
572 m_scripts->setItemEnabled(m_runScript_id, false); 582 m_scripts->setItemEnabled(m_runScript_id, false);
573 583
574 // is io_layer wants direct connection, then autoconnect 584 // is io_layer wants direct connection, then autoconnect
575 //if ( ( m_curSession->layer() )->supports()[0] == 1 ) { 585 //if ( ( m_curSession->layer() )->supports()[0] == 1 ) {
576 if (prof.autoConnect()) { 586 if (prof.autoConnect()) {
577 slotConnect(); 587 slotConnect();
578 } 588 }
579 589
580 590
581 QWidget *w = currentSession()->widget(); 591 QWidget *w = currentSession()->widget();
582 if(w) w->setFocus(); 592 if(w) w->setFocus();
583 593
594 if(currentSession()->profile().readNumEntry("Wrap", 80)){
595 m_isWrapped = true;
596 } else {
597 m_isWrapped = false;
598 }
599
584 m_kb->load(currentSession()->profile()); 600 m_kb->load(currentSession()->profile());
585} 601}
586 602
587void MainWindow::slotTransfer() 603void MainWindow::slotTransfer()
588{ 604{
589 if ( currentSession() ) { 605 if ( currentSession() ) {
590 Session *mysession = currentSession(); 606 Session *mysession = currentSession();
591 TransferDialog dlg(/*mysession->widgetStack()*/this, this); 607 TransferDialog dlg(/*mysession->widgetStack()*/this, this);
592 mysession->setTransferDialog(&dlg); 608 mysession->setTransferDialog(&dlg);
593 //dlg.reparent(mysession->widgetStack(), QPoint(0, 0)); 609 //dlg.reparent(mysession->widgetStack(), QPoint(0, 0));
594 //dlg.showMaximized(); 610 //dlg.showMaximized();
595 currentSession()->widgetStack()->addWidget(&dlg, -1); 611 currentSession()->widgetStack()->addWidget(&dlg, -1);
596 dlg.show(); 612 dlg.show();
597 //dlg.exec(); 613 //dlg.exec();
598 while(dlg.isRunning()) qApp->processEvents(); 614 while(dlg.isRunning()) qApp->processEvents();
599 mysession->setTransferDialog(0l); 615 mysession->setTransferDialog(0l);
@@ -641,36 +657,63 @@ void MainWindow::slotSessionChanged( Session* ses ) {
641 m_connect->setEnabled( true ); 657 m_connect->setEnabled( true );
642 m_disconnect->setEnabled( false ); 658 m_disconnect->setEnabled( false );
643 m_recordScript->setEnabled( false ); 659 m_recordScript->setEnabled( false );
644 m_saveScript->setEnabled( false ); 660 m_saveScript->setEnabled( false );
645 m_scripts->setItemEnabled(m_runScript_id, false); 661 m_scripts->setItemEnabled(m_runScript_id, false);
646 } 662 }
647 663
648 if ( ( m_curSession->layer() )->supports()[1] == 0 ) { 664 if ( ( m_curSession->layer() )->supports()[1] == 0 ) {
649 m_transfer->setEnabled( false ); 665 m_transfer->setEnabled( false );
650 } else { 666 } else {
651 m_transfer->setEnabled( true ); 667 m_transfer->setEnabled( true );
652 } 668 }
653 669
654 QWidget *w = m_curSession->widget(); 670 QWidget *w = m_curSession->widget();
655 if(w) w->setFocus(); 671 if(w) w->setFocus();
656 672
673 if(currentSession()->profile().readNumEntry("Wrap", 80)){
674 m_isWrapped = true;
675 } else {
676 m_isWrapped = false;
677 }
678
657 m_kb->load(currentSession()->profile()); 679 m_kb->load(currentSession()->profile());
658 } 680 }
659} 681}
660 682
683void MainWindow::slotWrap()
684{
685 if(m_curSession)
686 {
687 EmulationHandler *e = m_curSession->emulationHandler();
688 if(e)
689 {
690 if(m_isWrapped)
691 {
692 e->setWrap(80);
693 m_isWrapped = false;
694 }
695 else
696 {
697 e->setWrap(0);
698 m_isWrapped = true;
699 }
700 }
701 }
702}
703
661void MainWindow::slotFullscreen() { 704void MainWindow::slotFullscreen() {
662 705
663 706
664 707
665 if ( m_isFullscreen ) { 708 if ( m_isFullscreen ) {
666 ( m_curSession->widgetStack() )->reparent( savedParentFullscreen, 0, QPoint(0,0), true ); 709 ( m_curSession->widgetStack() )->reparent( savedParentFullscreen, 0, QPoint(0,0), true );
667 ( m_curSession->widgetStack() )->resize( savedParentFullscreen->width(), savedParentFullscreen->height() ); 710 ( m_curSession->widgetStack() )->resize( savedParentFullscreen->width(), savedParentFullscreen->height() );
668 ( m_curSession->emulationHandler() )->cornerButton()->hide(); 711 ( m_curSession->emulationHandler() )->cornerButton()->hide();
669 disconnect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) ); 712 disconnect( ( m_curSession->emulationHandler() )->cornerButton(), SIGNAL( pressed() ), this, SLOT( slotFullscreen() ) );
670 713
671 } else { 714 } else {
672 savedParentFullscreen = ( m_curSession->widgetStack() )->parentWidget(); 715 savedParentFullscreen = ( m_curSession->widgetStack() )->parentWidget();
673 ( m_curSession->widgetStack() )->setFrameStyle( QFrame::NoFrame ); 716 ( m_curSession->widgetStack() )->setFrameStyle( QFrame::NoFrame );
674 ( m_curSession->widgetStack() )->reparent( 0, WStyle_Tool | WStyle_Customize | WStyle_StaysOnTop 717 ( m_curSession->widgetStack() )->reparent( 0, WStyle_Tool | WStyle_Customize | WStyle_StaysOnTop
675 , QPoint(0,0), false ); 718 , QPoint(0,0), false );
676 ( m_curSession->widgetStack() )->resize( qApp->desktop()->width(), qApp->desktop()->height() ); 719 ( m_curSession->widgetStack() )->resize( qApp->desktop()->width(), qApp->desktop()->height() );