summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-02-08 10:48:19 +0000
committerDana Jansens <danakj@orodu.net>2003-02-08 10:48:19 +0000
commit9e05db9518c528ac0d2d44311cde267d9886b36a (patch)
treea5e8f8d8dfa3629dd4a52b4502a528fb3d338058 /src
parentc54d92b784036a4d9e829592aab938e661287fca (diff)
remove includes for widgetbase.hh. fix bug with circular modal pointer.
Diffstat (limited to 'src')
-rw-r--r--src/actions.hh1
-rw-r--r--src/client.cc3
-rw-r--r--src/screen.cc3
-rw-r--r--src/screen.hh3
4 files changed, 5 insertions, 5 deletions
diff --git a/src/actions.hh b/src/actions.hh
index f8f03d0f..f18696a1 100644
--- a/src/actions.hh
+++ b/src/actions.hh
@@ -6,7 +6,6 @@
@brief The action interface for user-available actions
*/
-#include "widgetbase.hh"
#include "otk/point.hh"
#include "otk/rect.hh"
#include "otk/eventhandler.hh"
diff --git a/src/client.cc b/src/client.cc
index d5be00d0..e78336d3 100644
--- a/src/client.cc
+++ b/src/client.cc
@@ -821,6 +821,7 @@ void Client::setModal(bool modal)
Client *c = this;
while (c->_transient_for) {
c = c->_transient_for;
+ if (c == this) break; // circular?
if (c->_modal_child) break; // already has a modal child
c->_modal_child = this;
}
@@ -836,7 +837,9 @@ void Client::setModal(bool modal)
c = this;
while (c->_transient_for) {
c = c->_transient_for;
+ if (c == this) break; // circular?
if (c->_modal_child != this) break; // has a different modal child
+ if (c == replacement) break; // found the replacement itself
c->_modal_child = replacement;
}
}
diff --git a/src/screen.cc b/src/screen.cc
index 41cc6e4c..4878d7b6 100644
--- a/src/screen.cc
+++ b/src/screen.cc
@@ -47,8 +47,7 @@ namespace ob {
Screen::Screen(int screen)
- : WidgetBase(WidgetBase::Type_Root),
- _number(screen)
+ : _number(screen)
{
assert(screen >= 0); assert(screen < ScreenCount(**otk::display));
_info = otk::display->screenInfo(screen);
diff --git a/src/screen.hh b/src/screen.hh
index db8c26d1..9244bb2d 100644
--- a/src/screen.hh
+++ b/src/screen.hh
@@ -10,7 +10,6 @@ extern "C" {
#include <X11/Xlib.h>
}
-#include "widgetbase.hh"
#include "otk/strut.hh"
#include "otk/rect.hh"
#include "otk/screeninfo.hh"
@@ -28,7 +27,7 @@ class Client;
//! Manages a single screen
/*!
*/
-class Screen : public otk::EventHandler, public WidgetBase {
+class Screen : public otk::EventHandler {
public:
//! Holds a list of otk::Strut objects
typedef std::list<otk::Strut*> StrutList;