KWin rule for adjusting focus stealing prevention level.

svn path=/trunk/kdebase/kwin/; revision=318991
This commit is contained in:
Luboš Luňák 2004-06-09 08:29:35 +00:00
parent 83657d963d
commit 76f21da02b
3 changed files with 31 additions and 13 deletions

View file

@ -26,6 +26,7 @@ License. See the file "COPYING" for the exact licensing terms.
#include "notifications.h"
#include "atoms.h"
#include "group.h"
#include "rules.h"
extern Time qt_x_time;
@ -465,8 +466,8 @@ bool Workspace::allowClientActivation( const Client* c, Time time, bool focus_in
// 4 - extreme - no window gets focus without user intervention
if( time == -1U )
time = c->userTime();
if( session_saving
&& options->focusStealingPreventionLevel <= 2 ) // <= normal
int level = c->rules()->checkFSP( options->focusStealingPreventionLevel );
if( session_saving && level <= 2 ) // <= normal
{
return true;
}
@ -481,9 +482,9 @@ bool Workspace::allowClientActivation( const Client* c, Time time, bool focus_in
}
if( time == 0 ) // explicitly asked not to get focus
return false;
if( options->focusStealingPreventionLevel == 0 ) // none
if( level == 0 ) // none
return true;
if( options->focusStealingPreventionLevel == 4 ) // extreme
if( level == 4 ) // extreme
return false;
if( c->ignoreFocusStealing())
return true;
@ -498,7 +499,7 @@ bool Workspace::allowClientActivation( const Client* c, Time time, bool focus_in
kdDebug( 1212 ) << "Activation: Belongs to active application" << endl;
return true;
}
if( options->focusStealingPreventionLevel == 3 ) // high
if( level == 3 ) // high
return false;
if( time == -1U ) // no time known
if( session_active )
@ -506,14 +507,14 @@ bool Workspace::allowClientActivation( const Client* c, Time time, bool focus_in
else
{
kdDebug( 1212 ) << "Activation: No timestamp at all" << endl;
if( options->focusStealingPreventionLevel == 1 ) // low
if( level == 1 ) // low
return true;
// no timestamp at all, don't activate - because there's also creation timestamp
// done on CreateNotify, this case should happen only in case application
// maps again already used window, i.e. this won't happen after app startup
return false;
}
// options->focusStealingPreventionLevel == 2 // normal
// level == 2 // normal
Time user_time = ac->userTime();
kdDebug( 1212 ) << "Activation, compared:" << c << ":" << time << ":" << user_time
<< ":" << ( timestampCompare( time, user_time ) >= 0 ) << endl;
@ -526,15 +527,15 @@ bool Workspace::allowClientActivation( const Client* c, Time time, bool focus_in
// to the same application
bool Workspace::allowFullClientRaising( const Client* c, Time time )
{
if( session_saving
&& options->focusStealingPreventionLevel <= 2 ) // <= normal
int level = c->rules()->checkFSP( options->focusStealingPreventionLevel );
if( session_saving && level <= 2 ) // <= normal
{
return true;
}
Client* ac = mostRecentlyActivatedClient();
if( options->focusStealingPreventionLevel == 0 ) // none
if( level == 0 ) // none
return true;
if( options->focusStealingPreventionLevel == 4 ) // extreme
if( level == 4 ) // extreme
return false;
if( ac == NULL || ac->isDesktop())
{
@ -549,7 +550,7 @@ bool Workspace::allowFullClientRaising( const Client* c, Time time )
kdDebug( 1212 ) << "Raising: Belongs to active application" << endl;
return true;
}
if( options->focusStealingPreventionLevel == 3 ) // high
if( level == 3 ) // high
return false;
Time user_time = ac->userTime();
kdDebug( 1212 ) << "Raising, compared:" << time << ":" << user_time

View file

@ -46,6 +46,7 @@ WindowRules::WindowRules()
, belowrule( DontCareRule )
, fullscreenrule( DontCareRule )
, noborderrule( DontCareRule )
, fspleveladjustrule( DontCareRule )
{
}
@ -61,6 +62,10 @@ WindowRules::WindowRules()
var = func ( cfg.read##type##Entry( #var ), funcarg ); \
var##rule = readRule( cfg, #var "rule" );
#define READ_FORCE_RULE( var, type, func ) \
var = func ( cfg.read##type##Entry( #var )); \
var##rule = readForceRule( cfg, #var "rule" );
WindowRules::WindowRules( KConfig& cfg )
{
wmclass = cfg.readEntry( "wmclass" ).lower().latin1();
@ -95,12 +100,14 @@ WindowRules::WindowRules( KConfig& cfg )
READ_SET_RULE( below, Bool, );
READ_SET_RULE( fullscreen, Bool, );
READ_SET_RULE( noborder, Bool, );
READ_FORCE_RULE( fspleveladjust, Num, );
kdDebug() << "READ RULE:" << wmclass << endl;
}
#undef READ_MATCH_STRING
#undef READ_SET_RULE
#undef READ_SET_RULE_2
#undef READ_FORCE_RULE
#define WRITE_MATCH_STRING( var, cast ) \
if( !var.isEmpty()) \
@ -161,6 +168,7 @@ void WindowRules::write( KConfig& cfg ) const
WRITE_SET_RULE( below, );
WRITE_SET_RULE( fullscreen, );
WRITE_SET_RULE( noborder, );
WRITE_SET_RULE( fspleveladjust, );
}
#undef WRITE_MATCH_STRING
@ -365,6 +373,12 @@ bool WindowRules::checkNoBorder( bool noborder, bool init ) const
return checkRule( noborderrule, init ) ? this->noborder : noborder;
}
int WindowRules::checkFSP( int fsp ) const
{
if( !checkForceRule( fspleveladjustrule ))
return fsp;
return QMIN( 4, QMAX( 0, fsp + fspleveladjust ));
}
// Client

View file

@ -62,6 +62,7 @@ class WindowRules
bool checkKeepBelow( bool below, bool init = false ) const;
bool checkFullScreen( bool fs, bool init = false ) const;
bool checkNoBorder( bool noborder, bool init = false ) const;
int checkFSP( int fsp ) const;
private:
static SettingRule readRule( KConfig&, const QString& key );
static SettingRule readForceRule( KConfig&, const QString& key );
@ -114,6 +115,8 @@ class WindowRules
SettingRule fullscreenrule;
bool noborder;
SettingRule noborderrule;
int fspleveladjust;
SettingRule fspleveladjustrule;
};
inline