TDE base libraries and programs
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

4497 lines
143 KiB

/*
This file is part of Konsole, an X terminal.
Copyright (C) 1996 by Matthias Ettrich <ettrich@kde.org>
Copyright (C) 1997,1998 by Lars Doelle <lars.doelle@on-line.de>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
--------------------------------------------------------------
Additional changes:
- 2013/10/14 Michele Calgaro
add "scroll tabs on mouse wheel event" functionality
- 2013/10/19 Michele Calgaro
add "move session left/right" to tab popup menu
*/
/* The material contained in here more or less directly orginates from */
/* kvt, which is copyright (c) 1996 by Matthias Ettrich <ettrich@kde.org> */
/* */
/*! \class Konsole
\brief Konsole's main class and program
The class Konsole handles the application level. Mainly, it is responsible
for the configuration, taken from several files, from the command line
and from the user. It hardly does anything interesting.
Everything is created as late as possible to make it startup fast.
*/
/*TODO:
- allow to set codec
- officially declare this file to be hacked to death. ;^)
- merge into konsole_part.
*/
/*STATE:
konsole/twin session management, parts stuff, config, menues
are all in bad need for a complete rewrite.
While the emulation core (TEmulation, TEVt102, TEScreen, TEWidget)
are pretty stable, the upper level material has certainly drifted.
Everything related to Sessions, Configuration has to be redesigned.
It seems that the konsole now falls apart into individual sessions
and a session manager.
Time to start a requirement list.
- Rework the Emulation::setConnect logic.
Together with session changing (Shift-Left/Right, Ctrl-D) it allows
key events to propagate to other sessions.
- Get rid of the unconfigurable, uncallable initial "Konsole" session.
Leads to code replication in konsole_part and other issues. Related
to the booting of konsole, thus matter of redesign.
*/
/*FIXME:
- All the material in here badly sufferes from the fact that the
configuration can originate from many places, so all is duplicated
and falls out of service. Especially the command line is badly broken.
The sources are:
- command line
- menu
- configuration files
- other events (e.g. resizing)
We have to find a single-place method to better maintain this.
- In general, the material contained in here and in session.C
should be rebalanced. Much more material now comes from configuration
files and the overall routines should better respect this.
- Font+Size list should go to a configuration file, too.
- Controlling the widget is currently done by individual attributes.
This lead to quite some amount of flicker when a whole bunch of
attributes has to be set, e.g. in session swapping.
*/
#include <config.h>
#include <tqspinbox.h>
#include <tqcheckbox.h>
#include <tqimage.h>
#include <tqlayout.h>
#include <tqpushbutton.h>
#include <tqhbox.h>
#include <tqtoolbutton.h>
#include <tqtooltip.h>
#include <stdio.h>
#include <stdlib.h>
#include <tdefiledialog.h>
#include <kurlrequesterdlg.h>
#include <tdefontdialog.h>
#include <kkeydialog.h>
#include <kstandarddirs.h>
#include <tqpainter.h>
#include <tdemenubar.h>
#include <tdemessagebox.h>
#include <krootpixmap.h>
#include <krun.h>
#include <kstdaction.h>
#include <kinputdialog.h>
#include <kdebug.h>
#include <kipc.h>
#include <dcopclient.h>
#include <tdeglobalsettings.h>
#include <knotifydialog.h>
#undef B0
#include <kprinter.h>
#include <tdeaccelmanager.h>
#include <kurifilter.h>
#include <tdeaction.h>
#include <kshell.h>
#include <tqlabel.h>
#include <tdepopupmenu.h>
#include <tdelocale.h>
#include <sys/wait.h>
#include <sys/stat.h>
#include <signal.h>
#include <dirent.h>
#include <fcntl.h>
#include <assert.h>
#include <kiconloader.h>
#include <kstringhandler.h>
#include <ktip.h>
#include <kprocctrl.h>
#include <ktabwidget.h>
#include <kregexpeditorinterface.h>
#include <tdeparts/componentfactory.h>
#include <kcharsets.h>
#include <kcolordialog.h>
#include <tdeio/netaccess.h>
#include "konsole.h"
#include <netwm.h>
#include "printsettings.h"
#include <X11/Xlib.h>
#include <X11/Xatom.h>
#define KONSOLEDEBUG kdDebug(1211)
#define POPUP_NEW_SESSION_ID 121
#define POPUP_SETTINGS_ID 212
#define SESSION_NEW_WINDOW_ID 1
#define SESSION_NEW_SHELL_ID 100
extern bool argb_visual; // declared in main.cpp and konsole_part.cpp
// KonsoleFontSelectAction is now also used for selectSize!
class KonsoleFontSelectAction : public TDESelectAction {
public:
KonsoleFontSelectAction(const TQString &text, int accel,
const TQObject* receiver, const char* slot,
TQObject* parent, const char* name = 0 )
: TDESelectAction(text, accel, receiver, slot, parent, name) {}
KonsoleFontSelectAction( const TQString &text, const TQIconSet& pix,
int accel, const TQObject* receiver,
const char* slot, TQObject* parent,
const char* name = 0 )
: TDESelectAction(text, pix, accel, receiver, slot, parent, name) {}
virtual void slotActivated( int index );
};
void KonsoleFontSelectAction::slotActivated(int index) {
// emit even if it's already activated
if (currentItem() == index) {
TDESelectAction::slotActivated();
return;
} else {
TDESelectAction::slotActivated(index);
}
}
template class TQPtrDict<TESession>;
template class TQIntDict<KSimpleConfig>;
template class TQPtrDict<TDERadioAction>;
#define DEFAULT_HISTORY_SIZE 1000
Konsole::Konsole(const char* name, int histon, bool menubaron, bool tabbaron, bool frameon, bool scrollbaron,
TQCString type, bool b_inRestore, const int wanted_tabbar, const TQString &workdir )
:DCOPObject( "konsole" )
,TDEMainWindow(0, name)
,m_defaultSession(0)
,m_defaultSessionFilename("")
,tabwidget(0)
,te(0)
,se(0)
,se_previous(0)
,m_initialSession(0)
,colors(0)
,kWinModule(0)
,menubar(0)
,statusbar(0)
,m_session_string(i18n("&Session"))
,m_edit_string(i18n("&Edit"))
,m_view_string(i18n("&View"))
,m_bookmarks_string(i18n("&Bookmarks"))
,m_options_string(i18n("Se&ttings"))
,m_help_string(i18n("&Help"))
,m_session_id(-1)
,m_edit_id(-1)
,m_view_id(-1)
,m_bookmarks_id(-1)
,m_options_id(-1)
,m_help_id(-1)
,m_session(0)
,m_edit(0)
,m_view(0)
,m_bookmarks(0)
,m_bookmarksSession(0)
,m_options(0)
,m_schema(0)
,m_keytab(0)
,m_tabbarSessionsCommands(0)
,m_signals(0)
,m_help(0)
,m_rightButton(0)
,m_zmodemUpload(0)
,monitorActivity(0)
,monitorSilence(0)
,masterMode(0)
,showMenubar(0)
,m_fullscreen(0)
,selectSize(0)
,selectFont(0)
,selectScrollbar(0)
,selectTabbar(0)
,selectBell(0)
,selectSetEncoding(0)
,m_clearHistory(0)
,m_findHistory(0)
,m_saveHistory(0)
,m_detachSession(0)
,m_moveSessionLeft(0)
,m_moveSessionRight(0)
,bookmarkHandler(0)
,bookmarkHandlerSession(0)
,m_finddialog(0)
,m_find_pattern("")
,cmd_serial(0)
,cmd_first_screen(-1)
,n_keytab(0)
,n_defaultKeytab(0)
,n_render(0)
,curr_schema(0)
,wallpaperSource(0)
,sessionIdCounter(0)
,monitorSilenceSeconds(10)
,s_tdeconfigSchema("")
,m_tabViewMode(ShowIconAndText)
,b_dynamicTabHide(false)
,b_autoResizeTabs(false)
,b_installBitmapFonts(false)
,b_framevis(true)
,b_metaAsAlt(false)
,b_fullscreen(false)
,m_menuCreated(false)
,b_warnQuit(false)
,b_allowResize(true) // Whether application may resize
,b_fixedSize(false) // Whether user may resize
,b_addToUtmp(true)
,b_xonXoff(false)
,b_bidiEnabled(false)
,b_fullScripting(false)
,b_showstartuptip(true)
,b_sessionShortcutsEnabled(false)
,b_sessionShortcutsMapped(false)
,b_matchTabWinTitle(false)
,m_histSize(DEFAULT_HISTORY_SIZE)
,m_separator_id(-1)
,m_newSessionButton(0)
,m_removeSessionButton(0)
,sessionNumberMapper(0)
,sl_sessionShortCuts(0)
,s_workDir(workdir)
,m_filterData(0)
{
isRestored = b_inRestore;
connect( &m_closeTimeout, TQT_SIGNAL(timeout()), this, TQT_SLOT(slotCouldNotClose()));
no2command.setAutoDelete(true);
menubar = menuBar();
TDEAcceleratorManager::setNoAccel( menubar );
sessionNumberMapper = new TQSignalMapper( TQT_TQOBJECT(this) );
connect( sessionNumberMapper, TQT_SIGNAL( mapped( int ) ),
this, TQT_SLOT( newSessionTabbar( int ) ) );
colors = new ColorSchemaList();
colors->checkSchemas();
colors->sort();
KeyTrans::loadAll();
// create applications /////////////////////////////////////////////////////
// read and apply default values ///////////////////////////////////////////
resize(321, 321); // Dummy.
TQSize currentSize = size();
TDEConfig * config = TDEGlobal::config();
config->setDesktopGroup();
applyMainWindowSettings(config);
if (currentSize != size())
defaultSize = size();
KSimpleConfig *co;
if (!type.isEmpty())
setDefaultSession(type+".desktop");
co = defaultSession();
co->setDesktopGroup();
TQString schema = co->readEntry("Schema");
readProperties(config, schema, false);
makeBasicGUI();
setMenuAcceleratos();
if (isRestored) {
n_tabbar = wanted_tabbar;
TDEConfig *c = TDEApplication::kApplication()->sessionConfig();
// c->setDesktopGroup(); // Reads from wrong group
b_dynamicTabHide = c->readBoolEntry("DynamicTabHide", false);
}
if (!tabbaron)
n_tabbar = TabNone;
makeTabWidget();
setCentralWidget(tabwidget);
if (b_dynamicTabHide || n_tabbar==TabNone)
tabwidget->setTabBarHidden(true);
if (!histon)
b_histEnabled=false;
if (!menubaron)
menubar->hide();
if (!frameon) {
b_framevis=false;
if (te) te->setFrameStyle( TQFrame::NoFrame );
}
if (!scrollbaron) {
n_scroll = TEWidget::SCRNONE;
if (te) te->setScrollbarLocation(TEWidget::SCRNONE);
}
// connect(kapp, TQT_SIGNAL(tdedisplayFontChanged()), this, TQT_SLOT(slotFontChanged()));
kapp->dcopClient()->setDefaultObject( "konsole" );
// Signal that we want to be transparent to the desktop, not to windows behind us...
Atom kde_wm_transparent_to_desktop;
kde_wm_transparent_to_desktop = XInternAtom(tqt_xdisplay(), "_TDE_TRANSPARENT_TO_DESKTOP", False);
XChangeProperty(tqt_xdisplay(), winId(), kde_wm_transparent_to_desktop, XA_INTEGER, 32, PropModeReplace, (unsigned char *) "TRUE", 1L);
}
Konsole::~Konsole()
{
delete m_filterData;
sessions.first();
while(sessions.current())
{
sessions.current()->closeSession();
sessions.next();
}
// Wait a bit for all childs to clean themselves up.
while(sessions.count() && TDEProcessController::theTDEProcessController->waitForProcessExit(1))
;
sessions.setAutoDelete(true);
resetScreenSessions();
if (no2command.isEmpty())
delete m_defaultSession;
delete colors;
colors=0;
delete kWinModule;
kWinModule = 0;
}
void Konsole::setAutoClose(bool on)
{
if (sessions.first())
sessions.first()->setAutoClose(on);
}
void Konsole::showTip()
{
KTipDialog::showTip(this,TQString::null,true);
}
void Konsole::showTipOnStart()
{
if (b_showstartuptip)
KTipDialog::showTip(this);
}
/* ------------------------------------------------------------------------- */
/* Make menu */
/* ------------------------------------------------------------------------- */
void Konsole::updateRMBMenu()
{
if (!m_rightButton) return;
int index = 0;
if (!showMenubar->isChecked() && m_options)
{
// Only show when menubar is hidden
if (!showMenubar->isPlugged( m_rightButton ))
{
showMenubar->plug ( m_rightButton, index );
m_rightButton->insertSeparator( index+1 );
}
index = 2;
m_rightButton->setItemVisible(POPUP_NEW_SESSION_ID,true);
if (m_separator_id != -1)
m_rightButton->setItemVisible(m_separator_id,true);
m_rightButton->setItemVisible(POPUP_SETTINGS_ID,true);
}
else
{
if (showMenubar->isPlugged( m_rightButton ))
{
showMenubar->unplug ( m_rightButton );
m_rightButton->removeItemAt(index);
}
index = 0;
m_rightButton->setItemVisible(POPUP_NEW_SESSION_ID,false);
m_rightButton->setItemVisible(m_separator_id,false);
m_rightButton->setItemVisible(POPUP_SETTINGS_ID,false);
}
if (!m_fullscreen)
return;
if (b_fullscreen)
{
if (!m_fullscreen->isPlugged( m_rightButton ))
{
m_fullscreen->plug ( m_rightButton, index );
m_rightButton->insertSeparator( index+1 );
}
}
else
{
if (m_fullscreen->isPlugged( m_rightButton ))
{
m_fullscreen->unplug ( m_rightButton );
m_rightButton->removeItemAt(index);
}
}
}
// Be carefull !!
// This function consumes a lot of time, that's why it is called delayed on demand.
// Be careful not to introduce function calls which lead to the execution of this
// function when starting konsole
// Be careful not to access stuff which is created in this function before this
// function was called ! you can check this using m_menuCreated, aleXXX
void Konsole::makeGUI()
{
if (m_menuCreated) return;
if (m_tabbarSessionsCommands)
disconnect(m_tabbarSessionsCommands,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
disconnect(m_session,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_options)
disconnect(m_options,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_help)
disconnect(m_help,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_rightButton)
disconnect(m_rightButton,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
disconnect(m_edit,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
disconnect(m_view,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_bookmarks)
disconnect(m_bookmarks,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_bookmarksSession)
disconnect(m_bookmarksSession,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_tabbarSessionsCommands)
connect(m_tabbarSessionsCommands,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(loadScreenSessions()));
connect(m_session,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(loadScreenSessions()));
m_menuCreated=true;
// Remove the empty separator Qt inserts if the menu is empty on popup,
// not sure if this will be "fixed" in Qt, for now use this hack (malte)
if(!(isRestored)) {
if (sender() && sender()->inherits(TQPOPUPMENU_OBJECT_NAME_STRING) &&
static_cast<const TQPopupMenu *>(sender())->count() == 1)
const_cast<TQPopupMenu *>(static_cast<const TQPopupMenu *>(sender()))->removeItemAt(0);
}
TDEActionCollection* actions = actionCollection();
// Send Signal Menu -------------------------------------------------------------
if (kapp->authorizeTDEAction("send_signal"))
{
m_signals = new TDEPopupMenu(this);
m_signals->insertItem( i18n( "&Suspend Task" ) + " (STOP)", SIGSTOP);
m_signals->insertItem( i18n( "&Continue Task" ) + " (CONT)", SIGCONT);
m_signals->insertItem( i18n( "&Hangup" ) + " (HUP)", SIGHUP);
m_signals->insertItem( i18n( "&Interrupt Task" ) + " (INT)", SIGINT);
m_signals->insertItem( i18n( "&Terminate Task" ) + " (TERM)", SIGTERM);
m_signals->insertItem( i18n( "&Kill Task" ) + " (KILL)", SIGKILL);
m_signals->insertItem( i18n( "User Signal &1") + " (USR1)", SIGUSR1);
m_signals->insertItem( i18n( "User Signal &2") + " (USR2)", SIGUSR2);
connect(m_signals, TQT_SIGNAL(activated(int)), TQT_SLOT(sendSignal(int)));
TDEAcceleratorManager::manage( m_signals );
}
// Edit Menu ----------------------------------------------------------------
m_copyClipboard->plug(m_edit);
m_pasteClipboard->plug(m_edit);
m_edit->setCheckable(true);
if (m_signals)
m_edit->insertItem( i18n("&Send Signal"), m_signals );
if ( m_zmodemUpload ) {
m_edit->insertSeparator();
m_zmodemUpload->plug( m_edit );
}
m_edit->insertSeparator();
m_clearTerminal->plug(m_edit);
m_resetClearTerminal->plug(m_edit);
m_edit->insertSeparator();
m_findHistory->plug(m_edit);
m_findNext->plug(m_edit);
m_findPrevious->plug(m_edit);
m_saveHistory->plug(m_edit);
m_edit->insertSeparator();
m_clearHistory->plug(m_edit);
m_clearAllSessionHistories->plug(m_edit);
// View Menu
m_detachSession->plug(m_view);
m_renameSession->plug(m_view);
m_view->insertSeparator();
monitorActivity->plug ( m_view );
monitorSilence->plug ( m_view );
masterMode->plug ( m_view );
m_view->insertSeparator();
m_moveSessionLeft->setEnabled( false );
m_moveSessionLeft->plug(m_view);
m_moveSessionRight->setEnabled( false );
m_moveSessionRight->plug(m_view);
m_view->insertSeparator();
TDERadioAction *ra = session2action.find(se);
if (ra!=0) ra->plug(m_view);
//bookmarks menu
if (bookmarkHandler)
connect( bookmarkHandler, TQT_SIGNAL( openURL( const TQString&, const TQString& )),
TQT_SLOT( enterURL( const TQString&, const TQString& )));
if (bookmarkHandlerSession)
connect( bookmarkHandlerSession, TQT_SIGNAL( openURL( const TQString&, const TQString& )),
TQT_SLOT( newSession( const TQString&, const TQString& )));
if (m_bookmarks)
connect(m_bookmarks, TQT_SIGNAL(aboutToShow()), TQT_SLOT(bookmarks_menu_check()));
if (m_bookmarksSession)
connect(m_bookmarksSession, TQT_SIGNAL(aboutToShow()), TQT_SLOT(bookmarks_menu_check()));
// Schema Options Menu -----------------------------------------------------
m_schema = new TDEPopupMenu(this);
m_schema->setCheckable(true);
TDEAcceleratorManager::manage( m_schema );
connect(m_schema, TQT_SIGNAL(activated(int)), TQT_SLOT(schema_menu_activated(int)));
connect(m_schema, TQT_SIGNAL(aboutToShow()), TQT_SLOT(schema_menu_check()));
// Keyboard Options Menu ---------------------------------------------------
m_keytab = new TDEPopupMenu(this);
m_keytab->setCheckable(true);
TDEAcceleratorManager::manage( m_keytab );
connect(m_keytab, TQT_SIGNAL(activated(int)), TQT_SLOT(keytab_menu_activated(int)));
//options menu
if (m_options)
{
// Menubar on/off
showMenubar->plug ( m_options );
// Tabbar
selectTabbar = new TDESelectAction(i18n("&Tab Bar"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotSelectTabbar()), actions, "tabbar" );
TQStringList tabbaritems;
tabbaritems << i18n("&Hide") << i18n("&Top") << i18n("&Bottom");
selectTabbar->setItems(tabbaritems);
selectTabbar->plug(m_options);
// Scrollbar
selectScrollbar = new TDESelectAction(i18n("Sc&rollbar"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotSelectScrollbar()), actions, "scrollbar" );
TQStringList scrollitems;
scrollitems << i18n("&Hide") << i18n("&Left") << i18n("&Right");
selectScrollbar->setItems(scrollitems);
selectScrollbar->plug(m_options);
// Fullscreen
m_options->insertSeparator();
if (m_fullscreen)
{
m_fullscreen->plug(m_options);
m_options->insertSeparator();
}
// Select Bell
selectBell = new TDESelectAction(i18n("&Bell"), SmallIconSet( "bell"), 0 , TQT_TQOBJECT(this),
TQT_SLOT(slotSelectBell()), actions, "bell");
TQStringList bellitems;
bellitems << i18n("System &Bell")
<< i18n("System &Notification")
<< i18n("&Visible Bell")
<< i18n("N&one");
selectBell->setItems(bellitems);
selectBell->plug(m_options);
checkBitmapFonts();
TDEActionMenu* m_fontsizes = new TDEActionMenu( i18n( "Font" ),
SmallIconSet( "text" ),
actions, 0L );
m_fontsizes->insert( new TDEAction( i18n( "&Enlarge Font" ),
SmallIconSet( "fontsizeup" ), 0, TQT_TQOBJECT(this),
TQT_SLOT( biggerFont() ), actions,
"enlarge_font" ) );
m_fontsizes->insert( new TDEAction( i18n( "&Shrink Font" ),
SmallIconSet( "fontsizedown" ), 0, TQT_TQOBJECT(this),
TQT_SLOT( smallerFont() ), actions,
"shrink_font" ) );
m_fontsizes->insert( new TDEAction( i18n( "Se&lect..." ),
SmallIconSet( "font" ), 0, TQT_TQOBJECT(this),
TQT_SLOT( slotSelectFont() ), actions,
"select_font" ) );
if ( b_installBitmapFonts )
{
m_fontsizes->insert( new TDEAction( i18n( "&Install Bitmap..." ),
SmallIconSet( "font" ), 0, TQT_TQOBJECT(this),
TQT_SLOT( slotInstallBitmapFonts() ), actions,
"install_fonts" ) );
}
m_fontsizes->plug(m_options);
// encoding menu, start with default checked !
selectSetEncoding = new TDESelectAction( i18n( "&Encoding" ), SmallIconSet( "charset" ), 0, TQT_TQOBJECT(this), TQT_SLOT(slotSetEncoding()), actions, "set_encoding" );
TQStringList list = TDEGlobal::charsets()->descriptiveEncodingNames();
list.prepend( i18n( "Default" ) );
selectSetEncoding->setItems(list);
selectSetEncoding->setCurrentItem (0);
selectSetEncoding->plug(m_options);
if (kapp->authorizeTDEAction("keyboard"))
m_options->insertItem( SmallIconSet( "key_bindings" ), i18n( "&Keyboard" ), m_keytab );
// Schema
if (kapp->authorizeTDEAction("schema"))
m_options->insertItem( SmallIconSet( "colorize" ), i18n( "Sch&ema" ), m_schema);
// Select size
if (!b_fixedSize)
{
selectSize = new KonsoleFontSelectAction(i18n("S&ize"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotSelectSize()), actions, "size");
TQStringList sizeitems;
sizeitems << i18n("40x15 (&Small)")
<< i18n("80x24 (&VT100)")
<< i18n("80x25 (&IBM PC)")
<< i18n("80x40 (&XTerm)")
<< i18n("80x52 (IBM V&GA)")
<< ""
<< i18n("&Custom...");
selectSize->setItems(sizeitems);
selectSize->plug(m_options);
}
TDEAction *historyType = new TDEAction(i18n("Hist&ory..."), "history", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotHistoryType()), actions, "history");
historyType->plug(m_options);
m_options->insertSeparator();
TDEAction *save_settings = new TDEAction(i18n("&Save as Default"), "filesave", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotSaveSettings()), actions, "save_default");
save_settings->plug(m_options);
m_options->insertSeparator();
m_saveProfile->plug(m_options);
m_options->insertSeparator();
KStdAction::configureNotifications(TQT_TQOBJECT(this), TQT_SLOT(slotConfigureNotifications()), actionCollection())->plug(m_options);
KStdAction::keyBindings(TQT_TQOBJECT(this), TQT_SLOT(slotConfigureKeys()), actionCollection())->plug(m_options);
TDEAction *configure = KStdAction::preferences(TQT_TQOBJECT(this), TQT_SLOT(slotConfigure()), actions);
configure->plug(m_options);
if (TDEGlobalSettings::insertTearOffHandle())
m_options->insertTearOffHandle();
}
//help menu
if (m_help)
{
m_help->insertSeparator(1);
m_help->insertItem(SmallIcon( "idea" ), i18n("&Tip of the Day"),
this, TQT_SLOT(showTip()), 0, -1, 2);
}
//the different session menus
buildSessionMenus();
connect(m_session, TQT_SIGNAL(activated(int)), TQT_SLOT(newSession(int)));
// Right mouse button menu
if (m_rightButton)
{
updateRMBMenu(); // show menubar / exit fullscreen
TDEAction* selectionEnd = new TDEAction(i18n("Set Selection End"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotSetSelectionEnd()), actions, "selection_end");
selectionEnd->plug(m_rightButton);
m_copyClipboard->plug(m_rightButton);
m_pasteClipboard->plug(m_rightButton);
m_openSelection = new TDEPopupMenu(this);
m_rightButton->insertItem( i18n("&Open.."), m_openSelection );
connect(m_openSelection, TQT_SIGNAL(aboutToShow()), TQT_SLOT(slotOpenSelection()));
if (m_signals)
m_rightButton->insertItem(i18n("&Send Signal"), m_signals);
m_rightButton->insertSeparator();
if (m_tabbarSessionsCommands)
m_rightButton->insertItem( i18n("New Sess&ion"), m_tabbarSessionsCommands, POPUP_NEW_SESSION_ID );
m_detachSession->plug(m_rightButton);
m_renameSession->plug(m_rightButton);
if (m_bookmarks)
{
m_rightButton->insertSeparator();
m_rightButton->insertItem(i18n("&Bookmarks"), m_bookmarks);
}
if (m_options)
{
m_separator_id=m_rightButton->insertSeparator();
m_rightButton->insertItem(i18n("S&ettings"), m_options, POPUP_SETTINGS_ID);
}
m_rightButton->insertSeparator();
m_closeSession->plug(m_rightButton );
if (TDEGlobalSettings::insertTearOffHandle())
m_rightButton->insertTearOffHandle();
}
delete colors;
colors = new ColorSchemaList();
colors->checkSchemas();
colors->sort();
updateSchemaMenu();
ColorSchema *sch=colors->find(s_schema);
if (sch)
curr_schema=sch->numb();
else
curr_schema = 0;
for (uint i=0; i<m_schema->count(); i++)
m_schema->setItemChecked(i,false);
m_schema->setItemChecked(curr_schema,true);
while (se == NULL) {}
se->setSchemaNo(curr_schema);
// insert keymaps into menu
// This sorting seems a bit cumbersome; but it is not called often.
TQStringList kt_titles;
typedef TQMap<TQString,KeyTrans*> QStringKeyTransMap;
QStringKeyTransMap kt_map;
for (int i = 0; i < KeyTrans::count(); i++)
{
KeyTrans* ktr = KeyTrans::find(i);
assert( ktr );
TQString title=ktr->hdr().lower();
kt_titles << title;
kt_map[title] = ktr;
}
kt_titles.sort();
for ( TQStringList::Iterator it = kt_titles.begin(); it != kt_titles.end(); ++it ) {
KeyTrans* ktr = kt_map[*it];
assert( ktr );
TQString title=ktr->hdr();
m_keytab->insertItem(title.replace('&',"&&"),ktr->numb());
}
applySettingsToGUI();
isRestored = false;
// Fill tab context menu
m_tabPopupMenu = new TDEPopupMenu( this );
TDEAcceleratorManager::manage( m_tabPopupMenu );
if (!m_detachSession)
{
m_detachSession = new TDEAction(i18n("&Detach Session"), SmallIconSet("tab_breakoff"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotDetachSession()), m_shortcuts, "detach_session");
}
m_detachSession->plug(m_tabPopupMenu);
m_tabPopupMenu->insertItem( i18n("&Rename Session..."), TQT_TQOBJECT(this),
TQT_SLOT(slotTabRenameSession()) );
m_tabPopupMenu->insertSeparator();
m_tabMonitorActivity = new TDEToggleAction ( i18n( "Monitor for &Activity" ),
SmallIconSet("activity"), 0, TQT_TQOBJECT(this), TQT_SLOT( slotTabToggleMonitor() ), TQT_TQOBJECT(this) );
m_tabMonitorActivity->setCheckedState( KGuiItem( i18n( "Stop Monitoring for &Activity" ) ) );
m_tabMonitorActivity->plug(m_tabPopupMenu);
m_tabMonitorSilence = new TDEToggleAction ( i18n( "Monitor for &Silence" ),
SmallIconSet("silence"), 0, TQT_TQOBJECT(this), TQT_SLOT( slotTabToggleMonitor() ), TQT_TQOBJECT(this) );
m_tabMonitorSilence->setCheckedState( KGuiItem( i18n( "Stop Monitoring for &Silence" ) ) );
m_tabMonitorSilence->plug(m_tabPopupMenu);
m_tabMasterMode = new TDEToggleAction ( i18n( "Send &Input to All Sessions" ), "remote", 0, TQT_TQOBJECT(this),
TQT_SLOT( slotTabToggleMasterMode() ), TQT_TQOBJECT(this));
m_tabMasterMode->plug(m_tabPopupMenu);
m_tabPopupMenu->insertSeparator();
if (!m_moveSessionLeft)
{
m_moveSessionLeft = new TDEAction(i18n("&Move Session Left"), TQApplication::reverseLayout() ? "forward" : "back",
TQApplication::reverseLayout() ? Qt::CTRL+Qt::SHIFT+Qt::Key_Right : Qt::CTRL+Qt::SHIFT+Qt::Key_Left, TQT_TQOBJECT(this),
TQT_SLOT(moveSessionLeft()), m_shortcuts, "move_session_left");
}
m_moveSessionLeft->plug(m_tabPopupMenu);
if (!m_moveSessionRight)
{
m_moveSessionRight = new TDEAction(i18n("M&ove Session Right"), TQApplication::reverseLayout() ? "back" : "forward",
TQApplication::reverseLayout() ? Qt::CTRL+Qt::SHIFT+Qt::Key_Left : Qt::CTRL+Qt::SHIFT+Qt::Key_Right, TQT_TQOBJECT(this),
TQT_SLOT(moveSessionRight()), m_shortcuts, "move_session_right");
}
m_moveSessionRight->plug(m_tabPopupMenu);
m_tabPopupMenu->insertSeparator();
m_tabPopupMenu->insertItem( SmallIconSet("colors"), i18n("Select &Tab Color..."), TQT_TQOBJECT(this), TQT_SLOT(slotTabSelectColor()) );
m_tabPopupMenu->insertSeparator();
m_tabPopupTabsMenu = new TDEPopupMenu( m_tabPopupMenu );
m_tabPopupMenu->insertItem( i18n("Switch to Tab" ), m_tabPopupTabsMenu );
connect( m_tabPopupTabsMenu, TQT_SIGNAL( activated ( int ) ),
TQT_SLOT( activateSession( int ) ) );
m_tabPopupMenu->insertSeparator();
m_tabPopupMenu->insertItem( SmallIcon("fileclose"), i18n("C&lose Session"), TQT_TQOBJECT(this),
TQT_SLOT(slotTabCloseSession()) );
if (m_options) {
// Fill tab bar context menu
m_tabbarPopupMenu = new TDEPopupMenu( this );
TDEAcceleratorManager::manage( m_tabbarPopupMenu );
selectTabbar->plug(m_tabbarPopupMenu);
TDESelectAction *viewOptions = new TDESelectAction(TQT_TQOBJECT(this));
viewOptions->setText(i18n("Tab &Options"));
TQStringList options;
options << i18n("&Text && Icons") << i18n("Text &Only") << i18n("&Icons Only");
viewOptions->setItems(options);
viewOptions->setCurrentItem(m_tabViewMode);
viewOptions->plug(m_tabbarPopupMenu);
connect(viewOptions, TQT_SIGNAL(activated(int)), TQT_TQOBJECT(this), TQT_SLOT(slotTabSetViewOptions(int)));
slotTabSetViewOptions(m_tabViewMode);
TDEToggleAction *dynamicTabHideOption = new TDEToggleAction ( i18n( "&Dynamic Hide" ), 0, TQT_TQOBJECT(this),
TQT_SLOT( slotTabbarToggleDynamicHide() ), TQT_TQOBJECT(this));
dynamicTabHideOption->setChecked(b_dynamicTabHide);
dynamicTabHideOption->plug(m_tabbarPopupMenu);
TDEToggleAction *m_autoResizeTabs = new TDEToggleAction( i18n("&Auto Resize Tabs"),
0, TQT_TQOBJECT(this), TQT_SLOT( slotToggleAutoResizeTabs() ), TQT_TQOBJECT(this));
m_autoResizeTabs->setChecked(b_autoResizeTabs);
m_autoResizeTabs->plug(m_tabbarPopupMenu);
}
}
// Called via menu
void Konsole::slotSetEncoding()
{
if (!se) return;
TQTextCodec * qtc;
if (selectSetEncoding->currentItem() == 0)
{
qtc = TQTextCodec::codecForLocale();
}
else
{
bool found;
TQString enc = TDEGlobal::charsets()->encodingForName(selectSetEncoding->currentText());
qtc = TDEGlobal::charsets()->codecForName(enc, found);
// BR114535 : Remove jis7 due to infinite loop.
if ( enc == "jis7" ) {
kdWarning()<<"Encoding Japanese (jis7) currently does not work! BR114535"<<endl;
qtc = TQTextCodec::codecForLocale();
selectSetEncoding->setCurrentItem( 0 );
}
if(!found)
{
kdWarning() << "Codec " << selectSetEncoding->currentText() << " not found! Using default..." << endl;
qtc = TQTextCodec::codecForLocale();
selectSetEncoding->setCurrentItem( 0 );
}
}
se->setEncodingNo(selectSetEncoding->currentItem());
se->getEmulation()->setCodec(qtc);
}
void Konsole::makeTabWidget()
{
tabwidget = new KTabWidget(this);
tabwidget->setTabReorderingEnabled(true);
tabwidget->setAutomaticResizeTabs(b_autoResizeTabs);
tabwidget->setTabCloseActivatePrevious(true);
tabwidget->setMouseWheelScroll(b_mouseWheelScroll);
if (n_tabbar==TabTop)
tabwidget->setTabPosition(TQTabWidget::Top);
else
tabwidget->setTabPosition(TQTabWidget::Bottom);
TDEAcceleratorManager::setNoAccel( tabwidget );
connect(tabwidget, TQT_SIGNAL(movedTab(int,int)), TQT_SLOT(slotMovedTab(int,int)));
connect(tabwidget, TQT_SIGNAL(mouseDoubleClick(TQWidget*)), TQT_SLOT(slotRenameSession()));
connect(tabwidget, TQT_SIGNAL(currentChanged(TQWidget*)), TQT_SLOT(activateSession(TQWidget*)));
connect(tabwidget, TQT_SIGNAL(contextMenu(TQWidget*, const TQPoint &)),
TQT_SLOT(slotTabContextMenu(TQWidget*, const TQPoint &)));
connect(tabwidget, TQT_SIGNAL(contextMenu(const TQPoint &)),
TQT_SLOT(slotTabbarContextMenu(const TQPoint &)));
if (kapp->authorize("shell_access")) {
connect(tabwidget, TQT_SIGNAL(mouseDoubleClick()), TQT_SLOT(newSession()));
m_newSessionButton = new TQToolButton( tabwidget );
TQToolTip::add(m_newSessionButton,i18n("Click for new standard session\nClick and hold for session menu"));
m_newSessionButton->setIconSet( SmallIcon( "tab_new" ) );
m_newSessionButton->adjustSize();
m_newSessionButton->setPopup( m_tabbarSessionsCommands );
connect(m_newSessionButton, TQT_SIGNAL(clicked()), TQT_SLOT(newSession()));
tabwidget->setCornerWidget( m_newSessionButton, BottomLeft );
m_newSessionButton->installEventFilter(this);
m_removeSessionButton = new TQToolButton( tabwidget );
TQToolTip::add(m_removeSessionButton,i18n("Close the current session"));
m_removeSessionButton->setIconSet( SmallIconSet( "tab_remove" ) );
m_removeSessionButton->adjustSize();
m_removeSessionButton->setEnabled(false);
connect(m_removeSessionButton, TQT_SIGNAL(clicked()), TQT_SLOT(confirmCloseCurrentSession()));
tabwidget->setCornerWidget( m_removeSessionButton, BottomRight );
}
}
bool Konsole::eventFilter( TQObject *o, TQEvent *ev )
{
if (TQT_BASE_OBJECT(o) == TQT_BASE_OBJECT(m_newSessionButton))
{
// Popup the menu when the left mousebutton is pressed and the mouse
// is moved by a small distance.
if (ev->type() == TQEvent::MouseButtonPress)
{
TQMouseEvent* mev = TQT_TQMOUSEEVENT(ev);
m_newSessionButtonMousePressPos = mev->pos();
}
else if (ev->type() == TQEvent::MouseMove)
{
TQMouseEvent* mev = TQT_TQMOUSEEVENT(ev);
if ((mev->pos() - m_newSessionButtonMousePressPos).manhattanLength()
> TDEGlobalSettings::dndEventDelay())
{
m_newSessionButton->openPopup();
return true;
}
}
else if (ev->type() == TQEvent::ContextMenu)
{
TQMouseEvent* mev = TQT_TQMOUSEEVENT(ev);
slotTabbarContextMenu(mev->globalPos());
return true;
}
}
return TDEMainWindow::eventFilter(o, ev);
}
void Konsole::makeBasicGUI()
{
if (kapp->authorize("shell_access")) {
m_tabbarSessionsCommands = new TDEPopupMenu( this );
TDEAcceleratorManager::manage( m_tabbarSessionsCommands );
connect(m_tabbarSessionsCommands, TQT_SIGNAL(activated(int)), TQT_SLOT(newSessionTabbar(int)));
}
m_session = new TDEPopupMenu(this);
TDEAcceleratorManager::manage( m_session );
m_edit = new TDEPopupMenu(this);
TDEAcceleratorManager::manage( m_edit );
m_view = new TDEPopupMenu(this);
TDEAcceleratorManager::manage( m_view );
if (kapp->authorizeTDEAction("bookmarks"))
{
bookmarkHandler = new KonsoleBookmarkHandler( this, true );
m_bookmarks = bookmarkHandler->menu();
// call manually to disable accelerator c-b for add-bookmark initially.
bookmarks_menu_check();
}
if (kapp->authorizeTDEAction("settings")) {
m_options = new TDEPopupMenu(this);
TDEAcceleratorManager::manage( m_options );
}
if (kapp->authorizeTDEAction("help"))
m_help = helpMenu(0, false);
if (kapp->authorizeTDEAction("konsole_rmb")) {
m_rightButton = new TDEPopupMenu(this);
TDEAcceleratorManager::manage( m_rightButton );
}
if (kapp->authorizeTDEAction("bookmarks"))
{
// Bookmarks that open new sessions.
bookmarkHandlerSession = new KonsoleBookmarkHandler( this, false );
m_bookmarksSession = bookmarkHandlerSession->menu();
}
// For those who would like to add shortcuts here, be aware that
// ALT-key combinations are heavily used by many programs. Thus,
// activating shortcuts here means deactivating them in the other
// programs.
if (m_tabbarSessionsCommands)
connect(m_tabbarSessionsCommands,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
connect(m_session,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_options)
connect(m_options,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_help)
connect(m_help,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_rightButton)
connect(m_rightButton,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
connect(m_edit,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
connect(m_view,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_bookmarks)
connect(m_bookmarks,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
if (m_bookmarksSession)
connect(m_bookmarksSession,TQT_SIGNAL(aboutToShow()),this,TQT_SLOT(makeGUI()));
m_session_id=menubar->insertItem(m_session_string , m_session);
m_edit_id=menubar->insertItem(m_edit_string, m_edit);
m_view_id=menubar->insertItem(m_view_string, m_view);
if (m_bookmarks)
m_bookmarks_id=menubar->insertItem(m_bookmarks_string, m_bookmarks);
if (m_options)
m_options_id=menubar->insertItem(m_options_string, m_options);
if (m_help)
m_help_id=menubar->insertItem(m_help_string, m_help);
m_shortcuts = new TDEActionCollection(this);
m_copyClipboard = new TDEAction(i18n("&Copy"), "editcopy", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotCopyClipboard()), m_shortcuts, "edit_copy");
m_pasteClipboard = new TDEAction(i18n("&Paste"), "editpaste", Qt::SHIFT+Qt::Key_Insert, TQT_TQOBJECT(this),
TQT_SLOT(slotPasteClipboard()), m_shortcuts, "edit_paste");
m_pasteSelection = new TDEAction(i18n("Paste Selection"), Qt::CTRL+Qt::SHIFT+Qt::Key_Insert, TQT_TQOBJECT(this),
TQT_SLOT(slotPasteSelection()), m_shortcuts, "pasteselection");
m_clearTerminal = new TDEAction(i18n("C&lear Terminal"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotClearTerminal()), m_shortcuts, "clear_terminal");
m_resetClearTerminal = new TDEAction(i18n("&Reset && Clear Terminal"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotResetClearTerminal()), m_shortcuts, "reset_clear_terminal");
m_findHistory = new TDEAction(i18n("&Find in History..."), "find", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotFindHistory()), m_shortcuts, "find_history");
m_findHistory->setEnabled(b_histEnabled);
m_findNext = new TDEAction(i18n("Find &Next"), "go-next", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotFindNext()), m_shortcuts, "find_next");
m_findNext->setEnabled(b_histEnabled);
m_findPrevious = new TDEAction(i18n("Find Pre&vious"), "go-previous", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotFindPrevious()), m_shortcuts, "find_previous");
m_findPrevious->setEnabled( b_histEnabled );
m_saveHistory = new TDEAction(i18n("S&ave History As..."), "filesaveas", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotSaveHistory()), m_shortcuts, "save_history");
m_saveHistory->setEnabled(b_histEnabled );
m_clearHistory = new TDEAction(i18n("Clear &History"), "history_clear", 0, TQT_TQOBJECT(this),
TQT_SLOT(slotClearHistory()), m_shortcuts, "clear_history");
m_clearHistory->setEnabled(b_histEnabled);
m_clearAllSessionHistories = new TDEAction(i18n("Clear All H&istories"), "history_clear", 0,
TQT_TQOBJECT(this), TQT_SLOT(slotClearAllSessionHistories()), m_shortcuts, "clear_all_histories");
if (!m_detachSession)
{
m_detachSession = new TDEAction(i18n("&Detach Session"), SmallIconSet("tab_breakoff"), 0, TQT_TQOBJECT(this),
TQT_SLOT(slotDetachSession()), m_shortcuts, "detach_session");
}
m_detachSession->setEnabled(false);
m_renameSession = new TDEAction(i18n("&Rename Session..."), Qt::CTRL+Qt::SHIFT+Qt::Key_R, TQT_TQOBJECT(this),
TQT_SLOT(slotRenameSession()), m_shortcuts, "rename_session");
if (kapp->authorizeTDEAction("zmodem_upload"))
m_zmodemUpload = new TDEAction( i18n( "&ZModem Upload..." ),
Qt::CTRL+Qt::ALT+Qt::Key_U, TQT_TQOBJECT(this),
TQT_SLOT( slotZModemUpload() ),
m_shortcuts, "zmodem_upload" );
monitorActivity = new TDEToggleAction ( i18n( "Monitor for &Activity" ),
SmallIconSet("activity"), 0, TQT_TQOBJECT(this),
TQT_SLOT( slotToggleMonitor() ), m_shortcuts, "monitor_activity" );
monitorActivity->setCheckedState( KGuiItem( i18n( "Stop Monitoring for &Activity" ) ) );
monitorSilence = new TDEToggleAction ( i18n( "Monitor for &Silence" ),
SmallIconSet("silence"), 0, TQT_TQOBJECT(this),
TQT_SLOT( slotToggleMonitor() ), m_shortcuts, "monitor_silence" );
monitorSilence->setCheckedState( KGuiItem( i18n( "Stop Monitoring for &Silence" ) ) );
masterMode = new TDEToggleAction ( i18n( "Send &Input to All Sessions" ), "remote", 0, TQT_TQOBJECT(this),
TQT_SLOT( slotToggleMasterMode() ), m_shortcuts, "send_input_to_all_sessions" );
showMenubar = new TDEToggleAction ( i18n( "Show &Menubar" ), "showmenu", Qt::CTRL+Qt::SHIFT+Qt::ALT+Qt::Key_M, TQT_TQOBJECT(this),
TQT_SLOT( slotToggleMenubar() ), m_shortcuts, "show_menubar" );
showMenubar->setCheckedState( KGuiItem( i18n("Hide &Menubar"), "showmenu", TQString::null, TQString::null ) );
m_fullscreen = KStdAction::fullScreen(0, 0, m_shortcuts, this );
connect( m_fullscreen,TQT_SIGNAL(toggled(bool)), TQT_TQOBJECT(this),TQT_SLOT(updateFullScreen(bool)));
m_fullscreen->setChecked(b_fullscreen);
m_saveProfile = new TDEAction( i18n( "Save Sessions &Profile..." ), SmallIconSet("filesaveas"), 0, TQT_TQOBJECT(this),
TQT_SLOT( slotSaveSessionsProfile() ), m_shortcuts, "save_sessions_profile" );
//help menu
if (m_help)
m_help->setAccel(TQKeySequence(),m_help->idAt(0));
// Don't steal F1 (handbook) accel (esp. since it not visible in
// "Configure Shortcuts").
m_closeSession = new TDEAction(i18n("C&lose Session"), "fileclose", 0, TQT_TQOBJECT(this),
TQT_SLOT(confirmCloseCurrentSession()), m_shortcuts, "close_session");
m_print = new TDEAction(i18n("&Print Screen..."), "fileprint", 0, TQT_TQOBJECT(this), TQT_SLOT( slotPrint() ), m_shortcuts, "file_print");
m_quit = new TDEAction(i18n("&Quit"), "system-log-out", 0, TQT_TQOBJECT(this), TQT_SLOT( close() ), m_shortcuts, "file_quit");
TDEShortcut shortcut(Qt::CTRL+Qt::ALT+Qt::Key_N);
shortcut.append(TDEShortcut(Qt::CTRL+Qt::SHIFT+Qt::Key_N));
new TDEAction(i18n("New Session"), shortcut, TQT_TQOBJECT(this), TQT_SLOT(newSession()), m_shortcuts, "new_session");
new TDEAction(i18n("Activate Menu"), Qt::CTRL+Qt::ALT+Qt::Key_M, TQT_TQOBJECT(this), TQT_SLOT(activateMenu()), m_shortcuts, "activate_menu");
new TDEAction(i18n("List Sessions"), 0, TQT_TQOBJECT(this), TQT_SLOT(listSessions()), m_shortcuts, "list_sessions");
if (!m_moveSessionLeft)
{
m_moveSessionLeft = new TDEAction(i18n("&Move Session Left"), TQApplication::reverseLayout() ? "forward" : "back",
TQApplication::reverseLayout() ? Qt::CTRL+Qt::SHIFT+Qt::Key_Right : Qt::CTRL+Qt::SHIFT+Qt::Key_Left, TQT_TQOBJECT(this),
TQT_SLOT(moveSessionLeft()), m_shortcuts, "move_session_left");
}
if (!m_moveSessionRight)
{
m_moveSessionRight = new TDEAction(i18n("M&ove Session Right"), TQApplication::reverseLayout() ? "back" : "forward",
TQApplication::reverseLayout() ? Qt::CTRL+Qt::SHIFT+Qt::Key_Left : Qt::CTRL+Qt::SHIFT+Qt::Key_Right, TQT_TQOBJECT(this),
TQT_SLOT(moveSessionRight()), m_shortcuts, "move_session_right");
}
new TDEAction(i18n("Go to Previous Session"), TQApplication::reverseLayout() ? Qt::SHIFT+Qt::Key_Right : Qt::SHIFT+Qt::Key_Left,
TQT_TQOBJECT(this), TQT_SLOT(prevSession()), m_shortcuts, "previous_session");
new TDEAction(i18n("Go to Next Session"), TQApplication::reverseLayout() ? Qt::SHIFT+Qt::Key_Left : Qt::SHIFT+Qt::Key_Right,
TQT_TQOBJECT(this), TQT_SLOT(nextSession()), m_shortcuts, "next_session");
for (int i=1;i<13;i++) { // Due to 12 function keys?
new TDEAction(i18n("Switch to Session %1").arg(i), 0, TQT_TQOBJECT(this), TQT_SLOT(switchToSession()), m_shortcuts, TQString(TQString().sprintf("switch_to_session_%02d", i)).latin1());
}
new TDEAction(i18n("Enlarge Font"), 0, TQT_TQOBJECT(this), TQT_SLOT(biggerFont()), m_shortcuts, "bigger_font");
new TDEAction(i18n("Shrink Font"), 0, TQT_TQOBJECT(this), TQT_SLOT(smallerFont()), m_shortcuts, "smaller_font");
new TDEAction(i18n("Toggle Bidi"), Qt::CTRL+Qt::ALT+Qt::Key_B, TQT_TQOBJECT(this), TQT_SLOT(toggleBidi()), m_shortcuts, "toggle_bidi");
// Should we load all *.desktop files now? Required for Session shortcuts.
if ( TDEConfigGroup(TDEGlobal::config(), "General").readBoolEntry("SessionShortcutsEnabled", false) ) {
b_sessionShortcutsEnabled = true;
loadSessionCommands();
loadScreenSessions();
}
m_shortcuts->readShortcutSettings();
m_sessionList = new TDEPopupMenu(this);
TDEAcceleratorManager::manage( m_sessionList );
connect(m_sessionList, TQT_SIGNAL(activated(int)), TQT_SLOT(activateSession(int)));
}
/**
Make menubar available via escape sequence (Default: Ctrl+Alt+m)
*/
void Konsole::activateMenu()
{
menubar->activateItemAt(0);
if ( !showMenubar->isChecked() ) {
menubar->show();
showMenubar->setChecked(true);
}
}
/**
Ask for Quit confirmation - Martijn Klingens
Asks for confirmation if there are still open shells when the 'Warn on
Quit' option is set.
*/
bool Konsole::queryClose()
{
if(kapp->sessionSaving())
// saving session - do not even think about doing any kind of cleanup here
return true;
if (sessions.count() == 0)
return true;
if ( b_warnQuit)
{
if(sessions.count()>1) {
switch (
KMessageBox::warningYesNoCancel(
this,
i18n( "You have open sessions (besides the current one). "
"These will be killed if you continue.\n"
"Are you sure you want to quit?" ),
i18n("Really Quit?"),
KStdGuiItem::quit(),
KGuiItem(i18n("C&lose Session"),"fileclose")
)
) {
case KMessageBox::Yes :
break;
case KMessageBox::No :
{ closeCurrentSession();
return false;
}
break;
case KMessageBox::Cancel : return false;
}
}
}
// WABA: Don't close if there are any sessions left.
// Tell them to go away.
sessions.first();
while(sessions.current())
{
sessions.current()->closeSession();
sessions.next();
}
m_closeTimeout.start(1500, true);
return false;
}
void Konsole::slotCouldNotClose()
{
int result = KMessageBox::warningContinueCancel(this,
i18n("The application running in Konsole does not respond to the close request. "
"Do you want Konsole to close anyway?"),
i18n("Application Does Not Respond"),
KStdGuiItem::close());
if (result == KMessageBox::Continue)
{
while(sessions.first())
{
doneSession(sessions.current());
}
}
}
/**
sets application window to a size based on columns X lines of the te
guest widget. Call with (0,0) for setting default size.
*/
void Konsole::setColLin(int columns, int lines)
{
if ((columns==0) || (lines==0))
{
if (b_fixedSize || defaultSize.isEmpty())
{
// not in config file : set default value
columns = 80;
lines = 24;
}
}
if ((columns==0) || (lines==0))
{
resize(defaultSize);
}
else
{
if (b_fixedSize)
te->setFixedSize(columns, lines);
else
te->setSize(columns, lines);
adjustSize();
if (b_fixedSize)
setFixedSize(sizeHint());
notifySize(columns, lines); // set menu items
}
}
/* ------------------------------------------------------------------------- */
/* */
/* */
/* ------------------------------------------------------------------------- */
void Konsole::configureRequest(TEWidget* _te, int state, int x, int y)
{
if (!m_menuCreated)
makeGUI();
TDEPopupMenu *menu = (state & ControlButton) ? m_session : m_rightButton;
if (menu)
menu->popup(_te->mapToGlobal(TQPoint(x,y)));
}
void Konsole::slotTabContextMenu(TQWidget* _te, const TQPoint & pos)
{
if (!m_menuCreated)
makeGUI();
m_contextMenuSession = sessions.at( tabwidget->indexOf( _te ) );
m_tabMonitorActivity->setChecked( m_contextMenuSession->isMonitorActivity() );
m_tabMonitorSilence->setChecked( m_contextMenuSession->isMonitorSilence() );
m_tabMasterMode->setChecked( m_contextMenuSession->isMasterMode() );
m_tabPopupTabsMenu->clear();
int counter=0;
for (TESession *ses = sessions.first(); ses; ses = sessions.next()) {
TQString title=ses->Title();
m_tabPopupTabsMenu->insertItem(SmallIcon(ses->IconName()),title.replace('&',"&&"),counter++);
}
m_tabPopupMenu->popup( pos );
}
void Konsole::slotTabDetachSession() {
detachSession( m_contextMenuSession );
}
void Konsole::slotTabRenameSession() {
renameSession(m_contextMenuSession);
}
void Konsole::slotTabSelectColor()
{
TQColor color = tabwidget->tabColor( m_contextMenuSession->widget() );
int result = KColorDialog::getColor( color );
if ( result == KColorDialog::Accepted )
tabwidget->setTabColor(m_contextMenuSession->widget(), color);
}
void Konsole::slotTabToggleMonitor()
{
m_contextMenuSession->setMonitorActivity( m_tabMonitorActivity->isChecked() );
m_contextMenuSession->setMonitorSilence( m_tabMonitorSilence->isChecked() );
notifySessionState( m_contextMenuSession, NOTIFYNORMAL );
if (m_contextMenuSession==se) {
monitorActivity->setChecked( m_tabMonitorActivity->isChecked() );
monitorSilence->setChecked( m_tabMonitorSilence->isChecked() );
}
}
void Konsole::slotTabToggleMasterMode()
{
setMasterMode( m_tabMasterMode->isChecked(), m_contextMenuSession );
}
void Konsole::slotTabCloseSession()
{
confirmCloseCurrentSession(m_contextMenuSession);
}
void Konsole::slotTabbarContextMenu(const TQPoint & pos)
{
if (!m_menuCreated)
makeGUI();
if ( m_tabbarPopupMenu ) m_tabbarPopupMenu->popup( pos );
}
void Konsole::slotTabSetViewOptions(int mode)
{
m_tabViewMode = TabViewModes(mode);
for(int i = 0; i < tabwidget->count(); i++) {
TQWidget *page = tabwidget->page(i);
TQIconSet icon = iconSetForSession(sessions.at(i));
TQString title;
if (b_matchTabWinTitle)
title = sessions.at(i)->fullTitle();
else
title = sessions.at(i)->Title();
title=title.replace('&',"&&");
switch(mode) {
case ShowIconAndText:
tabwidget->changeTab(page, icon, title);
break;
case ShowTextOnly:
tabwidget->changeTab(page, TQIconSet(), title);
break;
case ShowIconOnly:
tabwidget->changeTab(page, icon, TQString::null);
break;
}
}
}
void Konsole::slotToggleAutoResizeTabs()
{
b_autoResizeTabs = !b_autoResizeTabs;
tabwidget->setAutomaticResizeTabs( b_autoResizeTabs );
}
void Konsole::slotTabbarToggleDynamicHide()
{
b_dynamicTabHide=!b_dynamicTabHide;
if (b_dynamicTabHide && tabwidget->count()==1)
tabwidget->setTabBarHidden(true);
else
tabwidget->setTabBarHidden(false);
}
/* ------------------------------------------------------------------------- */
/* */
/* Configuration */
/* */
/* ------------------------------------------------------------------------- */
void Konsole::slotSaveSessionsProfile()
{
bool ok;
TQString prof = KInputDialog::getText( i18n( "Save Sessions Profile" ),
i18n( "Enter name under which the profile should be saved:" ),
TQString::null, &ok, this );
if ( ok ) {
TQString path = locateLocal( "data",
TQString::fromLatin1( "konsole/profiles/" ) + prof,
TDEGlobal::instance() );
if ( TQFile::exists( path ) )
TQFile::remove( path );
KSimpleConfig cfg( path );
savePropertiesInternal(&cfg,1);
saveMainWindowSettings(&cfg);
}
}
void Konsole::saveProperties(TDEConfig* config) {
uint counter=0;
uint active=0;
TQString key;
if (config != TDEGlobal::config())
{
// called by the session manager
config->writeEntry("numSes",sessions.count());
sessions.first();
while(counter < sessions.count())
{
key = TQString("Title%1").arg(counter);
config->writeEntry(key, sessions.current()->Title());
key = TQString("Schema%1").arg(counter);
config->writeEntry(key, colors->find( sessions.current()->schemaNo() )->relPath());
key = TQString("Encoding%1").arg(counter);
config->writeEntry(key, sessions.current()->encodingNo());
key = TQString("Args%1").arg(counter);
config->writeEntry(key, sessions.current()->getArgs());
key = TQString("Pgm%1").arg(counter);
config->writeEntry(key, sessions.current()->getPgm());
key = TQString("SessionFont%1").arg(counter);
config->writeEntry(key, (sessions.current()->widget())->getVTFont());
key = TQString("Term%1").arg(counter);
config->writeEntry(key, sessions.current()->Term());
key = TQString("KeyTab%1").arg(counter);
config->writeEntry(key, sessions.current()->keymap());
key = TQString("Icon%1").arg(counter);
config->writeEntry(key, sessions.current()->IconName());
key = TQString("MonitorActivity%1").arg(counter);
config->writeEntry(key, sessions.current()->isMonitorActivity());
key = TQString("MonitorSilence%1").arg(counter);
config->writeEntry(key, sessions.current()->isMonitorSilence());
key = TQString("MasterMode%1").arg(counter);
config->writeEntry(key, sessions.current()->isMasterMode());
key = TQString("TabColor%1").arg(counter);
config->writeEntry(key, tabwidget->tabColor((sessions.current())->widget()));
key = TQString("History%1").arg(counter);
config->writeEntry(key, sessions.current()->history().getSize());
key = TQString("HistoryEnabled%1").arg(counter);
config->writeEntry(key, sessions.current()->history().isOn());
TQString cwd=sessions.current()->getCwd();
if (cwd.isEmpty())
cwd=sessions.current()->getInitial_cwd();
key = TQString("Cwd%1").arg(counter);
config->writePathEntry(key, cwd);
if (sessions.current()==se)
active=counter;
sessions.next();
counter++;
}
}
else
{
config->setDesktopGroup();
config->writeEntry("TabColor", tabwidget->tabColor(se->widget()));
}
config->writeEntry("Fullscreen",b_fullscreen);
config->writeEntry("defaultfont", (se->widget())->getVTFont());
s_tdeconfigSchema = colors->find( se->schemaNo() )->relPath();
config->writeEntry("schema",s_tdeconfigSchema);
config->writeEntry("scrollbar",n_scroll);
config->writeEntry("tabbar",n_tabbar);
config->writeEntry("bellmode",n_bell);
config->writeEntry("keytab",KeyTrans::find(n_defaultKeytab)->id());
config->writeEntry("ActiveSession", active);
config->writeEntry("DefaultSession", m_defaultSessionFilename);
config->writeEntry("TabViewMode", int(m_tabViewMode));
config->writeEntry("DynamicTabHide", b_dynamicTabHide);
config->writeEntry("AutoResizeTabs", b_autoResizeTabs);
if (selectSetEncoding)
{
TQString encoding = TDEGlobal::charsets()->encodingForName(selectSetEncoding->currentText());
config->writeEntry("EncodingName", encoding);
} else { // This will not always work (ie 'winsami' saves as 'ws2')
if (se) config->writeEntry("EncodingName", se->encoding());
}
if (se) {
config->writeEntry("history", se->history().getSize());
config->writeEntry("historyenabled", b_histEnabled);
}
config->writeEntry("class",name());
if (config != TDEGlobal::config())
{
saveMainWindowSettings(config);
}
if (!s_workDir.isEmpty())
config->writePathEntry("workdir", s_workDir);
// Set the new default font
defaultFont = se->widget()->getVTFont();
}
// Called by constructor (with config = TDEGlobal::config())
// and by session-management (with config = sessionconfig).
// So it has to apply the settings when reading them.
void Konsole::readProperties(TDEConfig* config)
{
readProperties(config, TQString::null, false);
}
// If --type option was given, load the corresponding schema instead of
// default
//
// When globalConfigOnly is true only the options that are shared among all
// konsoles are being read.
void Konsole::readProperties(TDEConfig* config, const TQString &schema, bool globalConfigOnly)
{
if (config==TDEGlobal::config())
{
config->setDesktopGroup();
b_warnQuit=config->readBoolEntry( "WarnQuit", true );
b_allowResize=config->readBoolEntry( "AllowResize", false);
b_bidiEnabled = config->readBoolEntry("EnableBidi",false);
s_word_seps= config->readEntry("wordseps",":@-./_~");
b_framevis = config->readBoolEntry("has frame",true);
b_metaAsAlt = config->readBoolEntry("metaAsAltMode",false);
TQPtrList<TEWidget> tes = activeTEs();
for (TEWidget *_te = tes.first(); _te; _te = tes.next()) {
_te->setWordCharacters(s_word_seps);
_te->setTerminalSizeHint( config->readBoolEntry("TerminalSizeHint",false) );
_te->setFrameStyle( b_framevis?(TQFrame::WinPanel|TQFrame::Sunken):TQFrame::NoFrame );
_te->setBlinkingCursor(config->readBoolEntry("BlinkingCursor",false));
_te->setCtrlDrag(config->readBoolEntry("CtrlDrag",true));
_te->setCutToBeginningOfLine(config->readBoolEntry("CutToBeginningOfLine",false));
_te->setLineSpacing( config->readUnsignedNumEntry( "LineSpacing", 0 ) );
_te->setBidiEnabled(b_bidiEnabled);
}
monitorSilenceSeconds=config->readUnsignedNumEntry("SilenceSeconds", 10);
for (TESession *ses = sessions.first(); ses; ses = sessions.next())
{
ses->setMetaAsAltMode(b_metaAsAlt);
ses->setMonitorSilenceSeconds(monitorSilenceSeconds);
}
b_xonXoff = config->readBoolEntry("XonXoff",false);
b_matchTabWinTitle = config->readBoolEntry("MatchTabWinTitle",false);
b_mouseWheelScroll = config->readBoolEntry("TabsCycleWheel",true);
b_menuAccelerators = config->readBoolEntry("MenuAccelerators",false);
config->setGroup("UTMP");
b_addToUtmp = config->readBoolEntry("AddToUtmp",true);
config->setDesktopGroup();
// Do not set a default value; this allows the System-wide Scheme
// to set the tab text color.
m_tabColor = config->readColorEntry("TabColor");
}
if (!globalConfigOnly)
{
n_defaultKeytab=KeyTrans::find(config->readEntry("keytab","default"))->numb(); // act. the keytab for this session
b_fullscreen = config->readBoolEntry("Fullscreen",false);
n_scroll = TQMIN(config->readUnsignedNumEntry("scrollbar",TEWidget::SCRRIGHT),2);
n_tabbar = TQMIN(config->readUnsignedNumEntry("tabbar",TabBottom),2);
n_bell = TQMIN(config->readUnsignedNumEntry("bellmode",TEWidget::BELLSYSTEM),3);
// Options that should be applied to all sessions /////////////
// (1) set menu items and Konsole members
TQFont tmpFont = TDEGlobalSettings::fixedFont();
defaultFont = config->readFontEntry("defaultfont", &tmpFont);
//set the schema
s_tdeconfigSchema=config->readEntry("schema");
ColorSchema* sch = colors->find(schema.isEmpty() ? s_tdeconfigSchema : schema);
if (!sch)
{
sch = (ColorSchema*)colors->at(0); //the default one
kdWarning() << "Could not find schema named " <<s_tdeconfigSchema<<"; using "<<sch->relPath()<<endl;
s_tdeconfigSchema = sch->relPath();
}
if (sch->hasSchemaFileChanged()) sch->rereadSchemaFile();
s_schema = sch->relPath();
curr_schema = sch->numb();
pmPath = sch->imagePath();
if (te) {
if (sch->useTransparency())
{
if (!argb_visual) {
if (!rootxpms[te])
rootxpms.insert( te, new KRootPixmap(te) );
rootxpms[te]->setFadeEffect(sch->tr_x(), TQColor(sch->tr_r(), sch->tr_g(), sch->tr_b()));
}
else {
te->setBlendColor(tqRgba(sch->tr_r(), sch->tr_g(), sch->tr_b(), int(sch->tr_x() * 255)));
te->setErasePixmap( TQPixmap() ); // make sure any background pixmap is unset
}
}
else
{
if (rootxpms[te]) {
delete rootxpms[te];
rootxpms.remove(te);
}
pixmap_menu_activated(sch->alignment());
}
te->setColorTable(sch->table()); //FIXME: set twice here to work around a bug
te->setColorTable(sch->table());
te->setScrollbarLocation(n_scroll);
te->setBellMode(n_bell);
}
// History
m_histSize = config->readNumEntry("history",DEFAULT_HISTORY_SIZE);
b_histEnabled = config->readBoolEntry("historyenabled",true);
// Tab View Mode
m_tabViewMode = TabViewModes(config->readNumEntry("TabViewMode", ShowIconAndText));
b_dynamicTabHide = config->readBoolEntry("DynamicTabHide", false);
b_autoResizeTabs = config->readBoolEntry("AutoResizeTabs", false);
s_encodingName = config->readEntry( "EncodingName", "" ).lower();
// The scrollbar location only needs to be changed when the given
// profile scrollbar entry differs from the konsolerc scrollbar entry.
TQPtrList<TEWidget> tes = activeTEs();
for (TEWidget *_te = tes.first(); _te; _te = tes.next()) {
if (_te->getScrollbarLocation() != n_scroll)
_te->setScrollbarLocation(n_scroll);
}
}
if (m_menuCreated)
{
applySettingsToGUI();
activateSession();
};
}
void Konsole::applySettingsToGUI()
{
if (!m_menuCreated) return;
if (m_options)
{
// setFont();
notifySize(te->Columns(), te->Lines());
selectTabbar->setCurrentItem(n_tabbar);
showMenubar->setChecked(!menuBar()->isHidden());
selectScrollbar->setCurrentItem(n_scroll);
selectBell->setCurrentItem(n_bell);
selectSetEncoding->setCurrentItem( se->encodingNo() );
updateRMBMenu();
}
updateKeytabMenu();
tabwidget->setAutomaticResizeTabs( b_autoResizeTabs );
}
/* ------------------------------------------------------------------------- */
/* */
/* */
/* ------------------------------------------------------------------------- */
void Konsole::bookmarks_menu_check()
{
bool state = false;
if ( se )
state = !(se->getCwd().isEmpty());
TDEAction *addBookmark = actionCollection()->action( "add_bookmark" );
if ( !addBookmark )
{
return;
}
addBookmark->setEnabled( state );
}
void Konsole::pixmap_menu_activated(int item, TEWidget* tewidget)
{
if (!tewidget)
tewidget=te;
if (item <= 1) pmPath = "";
TQPixmap pm(pmPath);
if (pm.isNull()) {
pmPath = "";
item = 1;
tewidget->setBackgroundColor(tewidget->getDefaultBackColor());
return;
}
// FIXME: respect scrollbar (instead of te->size)
n_render= item;
switch (item)
{
case 1: // none
case 2: // tile
tewidget->setBackgroundPixmap(pm);
break;
case 3: // center
{ TQPixmap bgPixmap;
bgPixmap.resize(tewidget->size());
bgPixmap.fill(tewidget->getDefaultBackColor());
bitBlt( &bgPixmap, ( tewidget->size().width() - pm.width() ) / 2,
( tewidget->size().height() - pm.height() ) / 2,
&pm, 0, 0,
pm.width(), pm.height() );
tewidget->setBackgroundPixmap(bgPixmap);
}
break;
case 4: // full
{
float sx = (float)tewidget->size().width() / pm.width();
float sy = (float)tewidget->size().height() / pm.height();
TQWMatrix matrix;
matrix.scale( sx, sy );
tewidget->setBackgroundPixmap(pm.xForm( matrix ));
}
break;
default: // oops
n_render = 1;
}
}
void Konsole::slotSelectBell() {
n_bell = selectBell->currentItem();
te->setBellMode(n_bell);
}
void Konsole::slotSelectScrollbar() {
if (m_menuCreated)
n_scroll = selectScrollbar->currentItem();
TQPtrList<TEWidget> tes = activeTEs();
for (TEWidget *_te = tes.first(); _te; _te = tes.next())
_te->setScrollbarLocation(n_scroll);
activateSession(); // maybe helps in bg
}
void Konsole::checkBitmapFonts()
{
{
TQFont f;
f.setRawName("-misc-console-medium-r-normal--16-160-72-72-c-80-iso10646-1");
TQFontInfo fi( f );
if ( !fi.exactMatch() )
b_installBitmapFonts = true;
}
{
TQFont f;
f.setRawName("-misc-fixed-medium-r-normal--15-140-75-75-c-90-iso10646-1");
TQFontInfo fi( f );
if ( !fi.exactMatch() )
b_installBitmapFonts = true;
}
}
// In KDE 3.5, Konsole only allows the user to pick a font via
// TDEFontDialog. This causes problems with the bdf/pcf files
// distributed with Konsole (console8x16 and 9x15).
void Konsole::slotInstallBitmapFonts()
{
if ( !b_installBitmapFonts )
return;
TQStringList sl_installFonts;
{
TQFont f;
f.setRawName("-misc-console-medium-r-normal--16-160-72-72-c-80-iso10646-1");
TQFontInfo fi( f );
if ( !fi.exactMatch() )
sl_installFonts << "console8x16.pcf.gz";
}
{
TQFont f;
f.setRawName("-misc-fixed-medium-r-normal--15-140-75-75-c-90-iso10646-1");
TQFontInfo fi( f );
if ( !fi.exactMatch() )
sl_installFonts << "9x15.pcf.gz";
}
if ( !sl_installFonts.isEmpty() )
{
if ( KMessageBox::questionYesNoList( this,
i18n( "If you want to use the bitmap fonts distributed with Konsole, they must be installed. After installation, you must restart Konsole to use them. Do you want to install the fonts listed below into fonts:/Personal?" ),
sl_installFonts,
i18n( "Install Bitmap Fonts?" ),
KGuiItem( i18n("&Install" ) ),
i18n("Do Not Install") ) == KMessageBox::Yes )
{
for ( TQStringList::iterator it = sl_installFonts.begin();
it != sl_installFonts.end(); ++it )
{
TQString sf = "fonts/" + *it;
if ( TDEIO::NetAccess::copy( locate( "appdata", sf ),
"fonts:/Personal/", 0 ) )
{
b_installBitmapFonts = false;
// TODO: Remove the Install from the Fonts sub-menu.
} else {
KMessageBox::error( this, i18n( "Could not install %1 into fonts:/Personal/" ).arg( *it ), i18n( "Error" ) );
}
}
}
}
}
void Konsole::slotSelectFont() {
if ( !se ) return;
TQFont font = se->widget()->getVTFont();
if ( TDEFontDialog::getFont( font, true ) != TQDialog::Accepted )
return;
se->widget()->setVTFont( font );
// activateSession(); // activates the current
}
void Konsole::schema_menu_activated(int item)
{
if (!se) return;
setSchema(item);
activateSession(); // activates the current
}
/* slot */ void Konsole::schema_menu_check()
{
if (colors->checkSchemas())
{
colors->sort();
updateSchemaMenu();
}
}
void Konsole::updateSchemaMenu()
{
m_schema->clear();
for (int i = 0; i < (int) colors->count(); i++)
{
ColorSchema* s = (ColorSchema*)colors->at(i);
assert( s );
TQString title=s->title();
m_schema->insertItem(title.replace('&',"&&"),s->numb(),0);
}
if (te && se)
{
m_schema->setItemChecked(se->schemaNo(),true);
}
}
void Konsole::updateKeytabMenu()
{
if (m_menuCreated)
{
m_keytab->setItemChecked(n_keytab,false);
m_keytab->setItemChecked(se->keymapNo(),true);
};
n_keytab = se->keymapNo();
}
void Konsole::keytab_menu_activated(int item)
{
se->setKeymapNo(item);
n_defaultKeytab = item;
updateKeytabMenu();
}
/**
Toggle the Menubar visibility
*/
void Konsole::slotToggleMenubar() {
if ( showMenubar->isChecked() )
menubar->show();
else
menubar->hide();
if (b_fixedSize)
{
adjustSize();
setFixedSize(sizeHint());
}
if (!showMenubar->isChecked()) {
setCaption(i18n("Use the right mouse button to bring back the menu"));
TQTimer::singleShot(5000,this,TQT_SLOT(updateTitle()));
}
updateRMBMenu();
}
void Konsole::initTEWidget(TEWidget* new_te, TEWidget* default_te)
{
new_te->setWordCharacters(default_te->wordCharacters());
new_te->setTerminalSizeHint(default_te->isTerminalSizeHint());
new_te->setTerminalSizeStartup(false);
new_te->setFrameStyle(b_framevis?(TQFrame::WinPanel|TQFrame::Sunken):TQFrame::NoFrame);
new_te->setBlinkingCursor(default_te->blinkingCursor());
new_te->setCtrlDrag(default_te->ctrlDrag());
new_te->setCutToBeginningOfLine(default_te->cutToBeginningOfLine());
new_te->setLineSpacing(default_te->lineSpacing());
new_te->setBidiEnabled(b_bidiEnabled);
new_te->setVTFont(default_te->font());
new_te->setScrollbarLocation(n_scroll);
new_te->setBellMode(default_te->bellMode());
new_te->setMinimumSize(150,70);
}
void Konsole::createSessionTab(TEWidget *widget, const TQIconSet &iconSet,
const TQString &text, int index)
{
switch(m_tabViewMode) {
case ShowIconAndText:
tabwidget->insertTab(widget, iconSet, text, index);
break;
case ShowTextOnly:
tabwidget->insertTab(widget, TQIconSet(), text, index);
break;
case ShowIconOnly:
tabwidget->insertTab(widget, iconSet, TQString::null, index);
break;
}
if ( m_tabColor.isValid() )
tabwidget->setTabColor(widget, m_tabColor);
}
TQIconSet Konsole::iconSetForSession(TESession *session) const
{
if (m_tabViewMode == ShowTextOnly)
return TQIconSet();
return SmallIconSet(session->isMasterMode() ? "remote" : session->IconName());
}
/**
Toggle the Tabbar visibility
*/
void Konsole::slotSelectTabbar() {
if (m_menuCreated)
n_tabbar = selectTabbar->currentItem();
if ( n_tabbar == TabNone ) { // Hide tabbar
tabwidget->setTabBarHidden( true );
} else {
if ( tabwidget->isTabBarHidden() )
tabwidget->setTabBarHidden( false );
if ( n_tabbar == TabTop )
tabwidget->setTabPosition( TQTabWidget::Top );
else
tabwidget->setTabPosition( TQTabWidget::Bottom );
}
/* FIXME: Still necessary ? */
TQPtrDictIterator<KRootPixmap> it(rootxpms);
for (;it.current();++it)
it.current()->repaint(true);
if (b_fixedSize)
{
adjustSize();
setFixedSize(sizeHint());
}
}
void Konsole::slotSaveSettings()
{
TDEConfig *config = TDEGlobal::config();
config->setDesktopGroup();
saveProperties(config);
saveMainWindowSettings(config);
config->sync();
}
void Konsole::slotConfigureNotifications()
{
KNotifyDialog::configure(this, "Notification Configuration Dialog");
}
void Konsole::slotConfigureKeys()
{
KKeyDialog::configure(m_shortcuts);
m_shortcuts->writeShortcutSettings();
TQStringList ctrlKeys;
for ( uint i = 0; i < m_shortcuts->count(); i++ )
{
TDEShortcut shortcut = (m_shortcuts->action( i ))->shortcut();
for( uint j = 0; j < shortcut.count(); j++)
{
const KKey &key = shortcut.seq(j).key(0); // First Key of KeySequence
if (key.modFlags() == KKey::CTRL)
ctrlKeys += key.toString();
}
// Are there any shortcuts for Session Menu entries?
if ( !b_sessionShortcutsEnabled &&
m_shortcuts->action( i )->shortcut().count() &&
TQString(m_shortcuts->action( i )->name()).startsWith("SSC_") ) {
b_sessionShortcutsEnabled = true;
TDEConfigGroup group(TDEGlobal::config(), "General");
group.writeEntry("SessionShortcutsEnabled", true);
}
}
if (!ctrlKeys.isEmpty())
{
ctrlKeys.sort();
KMessageBox::informationList( this, i18n( "You have chosen one or more Ctrl+<key> combinations to be used as shortcuts. "
"As a result these key combinations will no longer be passed to the command shell "
"or to applications that run inside Konsole. "
"This can have the unintended consequence that functionality that would otherwise be "
"bound to these key combinations is no longer accessible."
"\n\n"
"You may wish to reconsider your choice of keys and use Alt+Ctrl+<key> or Ctrl+Shift+<key> instead."
"\n\n"
"You are currently using the following Ctrl+<key> combinations:" ),
ctrlKeys,
i18n( "Choice of Shortcut Keys" ), 0);
}
}
void Konsole::slotConfigure()
{
TQStringList args;
args << "kcmkonsole";
TDEApplication::tdeinitExec( "tdecmshell", args );
}
void Konsole::reparseConfiguration()
{
TDEGlobal::config()->reparseConfiguration();
readProperties(TDEGlobal::config(), TQString::null, true);
// The .desktop files may have been changed by user...
b_sessionShortcutsMapped = false;
// Mappings may have to be changed...get a fresh mapper.
disconnect( sessionNumberMapper, TQT_SIGNAL( mapped( int ) ),
this, TQT_SLOT( newSessionTabbar( int ) ) );
delete sessionNumberMapper;
sessionNumberMapper = new TQSignalMapper( TQT_TQOBJECT(this) );
connect( sessionNumberMapper, TQT_SIGNAL( mapped( int ) ),
this, TQT_SLOT( newSessionTabbar( int ) ) );
sl_sessionShortCuts.clear();
buildSessionMenus();
// FIXME: Should be a better way to traverse TDEActionCollection
uint count = m_shortcuts->count();
for ( uint i = 0; i < count; i++ )
{
TDEAction* action = m_shortcuts->action( i );
bool b_foundSession = false;
if ( TQString(action->name()).startsWith("SSC_") ) {
TQString name = TQString(action->name());
// Check to see if shortcut's session has been loaded.
for ( TQStringList::Iterator it = sl_sessionShortCuts.begin(); it != sl_sessionShortCuts.end(); ++it ) {
if ( TQString::compare( *it, name ) == 0 ) {
b_foundSession = true;
break;
}
}
if ( ! b_foundSession ) {
action->setShortcut( TDEShortcut() ); // Clear shortcut
m_shortcuts->writeShortcutSettings();
delete action; // Remove Action and Accel
if ( i == 0 ) i = 0; // Reset index
else i--;
count--; // = m_shortcuts->count();
}
}
}
m_shortcuts->readShortcutSettings();
// User may have changed Schema->Set as default schema
s_tdeconfigSchema = TDEGlobal::config()->readEntry("schema");
ColorSchema* sch = colors->find(s_tdeconfigSchema);
if (!sch)