Make no focus stealing prevention really do nothing, and change
the rule for it to specify new level instead of adjustment. svn path=/trunk/kdebase/kwin/; revision=319664
This commit is contained in:
parent
0f972d789f
commit
7e35926c37
4 changed files with 15 additions and 12 deletions
|
@ -594,13 +594,13 @@ KAdvancedConfig::KAdvancedConfig (bool _standAlone, KConfig *_config, QWidget *p
|
||||||
"caused by unexpected activation of new windows. (Note: This feature does not "
|
"caused by unexpected activation of new windows. (Note: This feature does not "
|
||||||
"work with the Focus Under Mouse or Focus Strictly Under Mouse focus policies.)"
|
"work with the Focus Under Mouse or Focus Strictly Under Mouse focus policies.)"
|
||||||
"<ul>"
|
"<ul>"
|
||||||
"<li><em>None:</em> The standard old behavior - prevention is turned off "
|
"<li><em>None:</em> Prevention is turned off "
|
||||||
"and new windows always become activated.</li>"
|
"and new windows always become activated.</li>"
|
||||||
"<li><em>Low:</em> Prevention is enabled; when some window does not have support "
|
"<li><em>Low:</em> Prevention is enabled; when some window does not have support "
|
||||||
"for the underlying mechanism and KWin cannot reliably decide whether to "
|
"for the underlying mechanism and KWin cannot reliably decide whether to "
|
||||||
"activate the window or not, it will be activated. This setting may have both "
|
"activate the window or not, it will be activated. This setting may have both "
|
||||||
"worse and better results than normal level, depending on the applications.</li>"
|
"worse and better results than normal level, depending on the applications.</li>"
|
||||||
"<li><em>Normal:</em> Prevention is enabled; the default setting.</li>"
|
"<li><em>Normal:</em> Prevention is enabled.</li>"
|
||||||
"<li><em>High:</em> New windows get activated only if no window is currently active "
|
"<li><em>High:</em> New windows get activated only if no window is currently active "
|
||||||
"or if they belong to the currently active application. This setting is probably "
|
"or if they belong to the currently active application. This setting is probably "
|
||||||
"not really usable when not using mouse focus policy.</li>"
|
"not really usable when not using mouse focus policy.</li>"
|
||||||
|
|
|
@ -416,8 +416,11 @@ bool Client::manage( Window w, bool isMapped )
|
||||||
if( isNormalWindow())
|
if( isNormalWindow())
|
||||||
Notify::raise( Notify::New );
|
Notify::raise( Notify::New );
|
||||||
|
|
||||||
|
bool allow = workspace()->allowClientActivation( this, userTime(), false, session && session->active );
|
||||||
|
|
||||||
// if session saving, force showing new windows (i.e. "save file?" dialogs etc.)
|
// if session saving, force showing new windows (i.e. "save file?" dialogs etc.)
|
||||||
if( workspace()->sessionSaving() && !isOnCurrentDesktop())
|
// also force if activation is allowed
|
||||||
|
if( !isOnCurrentDesktop() && !isMapped && ( allow || workspace()->sessionSaving()))
|
||||||
workspace()->setCurrentDesktop( desktop());
|
workspace()->setCurrentDesktop( desktop());
|
||||||
|
|
||||||
if( isOnCurrentDesktop())
|
if( isOnCurrentDesktop())
|
||||||
|
@ -431,7 +434,7 @@ bool Client::manage( Window w, bool isMapped )
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if( workspace()->allowClientActivation( this, userTime(), false, session && session->active ))
|
if( allow )
|
||||||
{
|
{
|
||||||
workspace()->raiseClient( this );
|
workspace()->raiseClient( this );
|
||||||
rawShow();
|
rawShow();
|
||||||
|
|
12
rules.cpp
12
rules.cpp
|
@ -50,7 +50,7 @@ WindowRules::WindowRules()
|
||||||
, belowrule( DontCareRule )
|
, belowrule( DontCareRule )
|
||||||
, fullscreenrule( DontCareRule )
|
, fullscreenrule( DontCareRule )
|
||||||
, noborderrule( DontCareRule )
|
, noborderrule( DontCareRule )
|
||||||
, fspleveladjustrule( DontCareRule )
|
, fsplevelrule( DontCareRule )
|
||||||
, acceptfocusrule( DontCareRule )
|
, acceptfocusrule( DontCareRule )
|
||||||
, moveresizemoderule( DontCareRule )
|
, moveresizemoderule( DontCareRule )
|
||||||
, closeablerule( DontCareRule )
|
, closeablerule( DontCareRule )
|
||||||
|
@ -95,6 +95,8 @@ WindowRules::WindowRules( KConfig& cfg )
|
||||||
readFromCfg( cfg );
|
readFromCfg( cfg );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int limit0to4( int i ) { return QMAX( 0, QMIN( 4, i )); }
|
||||||
|
|
||||||
void WindowRules::readFromCfg( KConfig& cfg )
|
void WindowRules::readFromCfg( KConfig& cfg )
|
||||||
{
|
{
|
||||||
wmclass = cfg.readEntry( "wmclass" ).lower().latin1();
|
wmclass = cfg.readEntry( "wmclass" ).lower().latin1();
|
||||||
|
@ -129,7 +131,7 @@ void WindowRules::readFromCfg( KConfig& cfg )
|
||||||
READ_SET_RULE( below, Bool, );
|
READ_SET_RULE( below, Bool, );
|
||||||
READ_SET_RULE( fullscreen, Bool, );
|
READ_SET_RULE( fullscreen, Bool, );
|
||||||
READ_SET_RULE( noborder, Bool, );
|
READ_SET_RULE( noborder, Bool, );
|
||||||
READ_FORCE_RULE( fspleveladjust, Num, );
|
READ_FORCE_RULE( fsplevel, Num, limit0to4 ); // fsp is 0-4
|
||||||
READ_FORCE_RULE( acceptfocus, Bool, );
|
READ_FORCE_RULE( acceptfocus, Bool, );
|
||||||
READ_FORCE_RULE( moveresizemode, , Options::stringToMoveResizeMode );
|
READ_FORCE_RULE( moveresizemode, , Options::stringToMoveResizeMode );
|
||||||
READ_FORCE_RULE( closeable, Bool, );
|
READ_FORCE_RULE( closeable, Bool, );
|
||||||
|
@ -200,7 +202,7 @@ void WindowRules::write( KConfig& cfg ) const
|
||||||
WRITE_SET_RULE( below, );
|
WRITE_SET_RULE( below, );
|
||||||
WRITE_SET_RULE( fullscreen, );
|
WRITE_SET_RULE( fullscreen, );
|
||||||
WRITE_SET_RULE( noborder, );
|
WRITE_SET_RULE( noborder, );
|
||||||
WRITE_SET_RULE( fspleveladjust, );
|
WRITE_SET_RULE( fsplevel, );
|
||||||
WRITE_SET_RULE( acceptfocus, );
|
WRITE_SET_RULE( acceptfocus, );
|
||||||
WRITE_SET_RULE( moveresizemode, Options::moveResizeModeToString );
|
WRITE_SET_RULE( moveresizemode, Options::moveResizeModeToString );
|
||||||
WRITE_SET_RULE( closeable, );
|
WRITE_SET_RULE( closeable, );
|
||||||
|
@ -412,9 +414,7 @@ bool WindowRules::checkNoBorder( bool noborder, bool init ) const
|
||||||
|
|
||||||
int WindowRules::checkFSP( int fsp ) const
|
int WindowRules::checkFSP( int fsp ) const
|
||||||
{
|
{
|
||||||
if( !checkForceRule( fspleveladjustrule ))
|
return checkForceRule( fsplevelrule ) ? this->fsplevel : fsp;
|
||||||
return fsp;
|
|
||||||
return QMIN( 4, QMAX( 0, fsp + fspleveladjust ));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WindowRules::checkAcceptFocus( bool focus ) const
|
bool WindowRules::checkAcceptFocus( bool focus ) const
|
||||||
|
|
4
rules.h
4
rules.h
|
@ -124,8 +124,8 @@ class WindowRules
|
||||||
SettingRule fullscreenrule;
|
SettingRule fullscreenrule;
|
||||||
bool noborder;
|
bool noborder;
|
||||||
SettingRule noborderrule;
|
SettingRule noborderrule;
|
||||||
int fspleveladjust;
|
int fsplevel;
|
||||||
SettingRule fspleveladjustrule;
|
SettingRule fsplevelrule;
|
||||||
bool acceptfocus;
|
bool acceptfocus;
|
||||||
SettingRule acceptfocusrule;
|
SettingRule acceptfocusrule;
|
||||||
Options::MoveResizeMode moveresizemode;
|
Options::MoveResizeMode moveresizemode;
|
||||||
|
|
Loading…
Reference in a new issue