add the new '-remote' option. let the dispatchEvents loop work in 'local' or 'remote' mode.

This commit is contained in:
Dana Jansens 2003-02-19 00:58:59 +00:00
parent d8429b31b4
commit d647de97be
4 changed files with 45 additions and 6 deletions

View file

@ -34,11 +34,32 @@ void EventDispatcher::clearHandler(Window id)
_map.erase(id); _map.erase(id);
} }
void EventDispatcher::dispatchEvents(void) void EventDispatcher::dispatchEvents(bool remote)
{ {
XEvent e; XEvent e;
while (XPending(**display)) { while (true) {
/*
There are slightly different event retrieval semantics here for local (or
high bandwidth) versus remote (or low bandwidth) connections to the
display/Xserver.
*/
if (remote) {
if (!XPending(**display))
return;
} else {
/*
This XSync allows for far more compression of events, which makes
things like Motion events perform far far better. Since it also means
network traffic for every event instead of every X events (where X is
the number retrieved at a time), it probably should not be used for
setups where Openbox is running on a remote/low bandwidth
display/Xserver.
*/
XSync(**display, false);
if (!XEventsQueued(**display, QueuedAlready))
return;
}
XNextEvent(**display, &e); XNextEvent(**display, &e);
#if 0//defined(DEBUG) #if 0//defined(DEBUG)

View file

@ -19,7 +19,17 @@ public:
virtual void clearAllHandlers(void); virtual void clearAllHandlers(void);
virtual void registerHandler(Window id, EventHandler *handler); virtual void registerHandler(Window id, EventHandler *handler);
virtual void clearHandler(Window id); virtual void clearHandler(Window id);
virtual void dispatchEvents(void); //! Dispatch events from the X server to the appropriate EventHandlers
/*!
@param remote Is the Xserver on a remote (low bandwidth) connection or on a
local (high bandwidth) connection. This allows you to specify
'false' in which case slightly different semantics are used
for event retrieval.<br>
The default is 'true' since this should generally be used,
only the Openbox window manager should need to specify
'false' here.
*/
virtual void dispatchEvents(bool remote = true);
inline void setFallbackHandler(EventHandler *fallback) inline void setFallbackHandler(EventHandler *fallback)
{ _fallback = fallback; } { _fallback = fallback; }

View file

@ -95,6 +95,7 @@ Openbox::Openbox(int argc, char **argv)
_focused_client = 0; _focused_client = 0;
_sync = false; _sync = false;
_single = false; _single = false;
_remote = false;
parseCommandLine(argc, argv); parseCommandLine(argc, argv);
@ -274,6 +275,8 @@ void Openbox::parseCommandLine(int argc, char **argv)
_sync = true; _sync = true;
} else if (arg == "-single") { } else if (arg == "-single") {
_single = true; _single = true;
} else if (arg == "-remote") {
_remote = true;
} else if (arg == "-version") { } else if (arg == "-version") {
showVersion(); showVersion();
::exit(0); ::exit(0);
@ -305,7 +308,8 @@ void Openbox::showHelp()
// print program usage and command line options // print program usage and command line options
printf(_("Usage: %s [OPTIONS...]\n\ printf(_("Usage: %s [OPTIONS...]\n\
Options:\n\ Options:\n\
-display <string> use display connection.\n\ -remote optimize for a remote (low bandwidth) connection to the\n\
display/Xserver.\n\
-single run on a single screen (default is to run every one).\n\ -single run on a single screen (default is to run every one).\n\
-rc <string> use alternate resource file.\n\ -rc <string> use alternate resource file.\n\
-menu <string> use alternate menu file.\n\ -menu <string> use alternate menu file.\n\
@ -349,8 +353,10 @@ void Openbox::showHelp()
void Openbox::eventLoop() void Openbox::eventLoop()
{ {
while (true) { while (true) {
dispatchEvents(); // from otk::EventDispatcher dispatchEvents(false); // from otk::EventDispatcher
XFlush(**otk::display); // flush here before we go wait for timers // XFlush(**otk::display); // flush here before we go wait for timers
// .. the XPending() should have done this last
// already, it does a flush when it returns 0
// don't wait if we're to shutdown // don't wait if we're to shutdown
if (_shutdown) break; if (_shutdown) break;
otk::Timer::dispatchTimers(!_sync); // wait if not in sync mode otk::Timer::dispatchTimers(!_sync); // wait if not in sync mode

View file

@ -94,6 +94,8 @@ private:
bool _sync; bool _sync;
//! Should Openbox run on a single screen or on all available screens? //! Should Openbox run on a single screen or on all available screens?
bool _single; bool _single;
//! Optimize for a remote/low-bandwidth connection to the display?
bool _remote;
//! A list of all managed clients //! A list of all managed clients
ClientMap _clients; ClientMap _clients;