all repos — openbox @ f586e55a8cd3d740a1b7b3a0801bad27030926f9

openbox fork - make it a bit more like ryudo

Added an action class and started the even handler.
Scott Moynes smoynes@nexus.carleton.ca
commit

f586e55a8cd3d740a1b7b3a0801bad27030926f9

parent

0326ac961fb82d8d7aab22e4da1859adeeceb2f7

M util/epist/Makefile.amutil/epist/Makefile.am

@@ -4,7 +4,7 @@ CPPFLAGS= @CPPFLAGS@ @DEBUG@

EXTRA_PROGRAMS = epist -epist_SOURCES = epist.cc window.cc screen.cc main.cc +epist_SOURCES = epist.cc window.cc screen.cc main.cc actions.cc epist_LDADD = ../../src/XAtom.o ../../src/BaseDisplay.o \ ../../src/Util.o ../../src/i18n.o \ ../../src/GCCache.o ../../src/Color.o ../../src/Texture.o \
M util/epist/actions.hhutil/epist/actions.hh

@@ -1,41 +1,62 @@

-// xOr: this is crap. -enum ActionType { - noaction = 0, - execute, - iconify, - raiseWindow, - lowerWindow, - closeWindow, - shade, - moveWindowUp, - moveWindowDown, - moveWindowLeft, - moveWindowRight, - nextWindow, - prevWindow, +#ifndef __actions_hh +#define __actions_hh +#include <list> + +extern "C" { +#include <X11/X.h> +} +class Action { +public: + // xOr: this is crap. + enum ActionType { + noaction = 0, + execute, + iconify, + raiseWindow, + lowerWindow, + closeWindow, + shade, + moveWindowUp, + moveWindowDown, + moveWindowLeft, + moveWindowRight, + + nextWindow, + prevWindow, + nextWindowOnAllDesktops, + prevWindowOnAllDesktops, - nextWindow, - prevWindow, - nextWindowOnAllDesktops, - prevWindowOnAllDesktops, + nextWindowOfClass, + prevWindowOfClass, - nextWindowOfClass, - prevWindowOfClass, + changeDesktop, + nextDesktop, + prevDesktop, - changeDesktop, - nextDesktop, - prevDesktop, + // these are openbox extensions + showRootMenu, + showWorkspaceMenu, - // these are openbox extensions - showRootMenu, - showWorkspaceMenu, + stringChain, + keyChain, + numberChain, - stringChain, - keyChain, - numberChain, + cancel, + }; - cancel, +private: + enum Action::ActionType _type; + const KeyCode _keycode; + const int _modifierMask; + +public: + inline enum ActionType type() const { return _type;} + inline const KeyCode keycode() const { return _keycode; } + inline const int modifierMask() const { return _modifierMask; } - NUM_ACTIONS + Action::Action(enum ActionType type, KeyCode keycode, int modifierMask); }; + +typedef list<Action> ActionList; +#endif
M util/epist/epist.ccutil/epist/epist.cc

@@ -75,6 +75,16 @@ if (_screens.empty()) {

cout << "No compatible window manager found on any screens. Aborting.\n"; ::exit(1); } + + _actions.push_back(Action(Action::nextDesktop, + XKeysymToKeycode(getXDisplay(), + XStringToKeysym("Tab")), + Mod1Mask)); + _actions.push_back(Action(Action::prevDesktop, + XKeysymToKeycode(getXDisplay(), + XStringToKeysym("Tab")), + ControlMask)); + activateGrabs(); }

@@ -82,7 +92,24 @@ epist::~epist() {

delete _xatom; } +// XGrabKey(_epist->getXDisplay(), XKeysymToKeycode(_epist->getXDisplay(), +// XStringToKeysym("F5")), +// Mod1Mask, _root, True, GrabModeAsync, GrabModeAsync); + +void epist::activateGrabs() { + ScreenList::const_iterator scrit, scrend = _screens.end(); + + for (scrit = _screens.begin(); scrit != scrend; ++scrit) { + ActionList::const_iterator end = _actions.end(); + + for(ActionList::const_iterator ait = _actions.begin(); + ait != end; ++ait) { + XGrabKey(getXDisplay(), ait->keycode(), ait->modifierMask(), + (*scrit)->rootWindow(), True, GrabModeAsync, GrabModeAsync); + } + } +} bool epist::handleSignal(int sig) { switch (sig) { case SIGHUP:
M util/epist/epist.hhutil/epist/epist.hh

@@ -30,6 +30,8 @@

#include <string> #include <map> +#include <actions.hh> + #include "../../src/BaseDisplay.hh" class XAtom;

@@ -49,9 +51,12 @@ typedef std::map<Window, XWindow*> WindowLookup;

typedef WindowLookup::value_type WindowLookupPair; WindowLookup _windows; + ActionList _actions; + virtual void process_event(XEvent *e); virtual bool handleSignal(int sig); + void activateGrabs(); public: epist(char **argv, char *display_name, char *rc_file); virtual ~epist();

@@ -61,6 +66,8 @@

void addWindow(XWindow *window); void removeWindow(XWindow *window); XWindow *findWindow(Window window) const; + + list<Action> actions(void) { return _actions; } }; #endif // __epist_hh
M util/epist/screen.ccutil/epist/screen.cc

@@ -137,10 +137,30 @@ updateClientList();

} break; case KeyPress: + handleKeypress(e); break; } } +void screen::handleKeypress(const XEvent &e) { + list<Action>::const_iterator it = _epist->actions().begin(); + list<Action>::const_iterator end = _epist->actions().end(); + for (; it != end; ++it) { + if (e.xkey.keycode == it->keycode() && + e.xkey.state == it->modifierMask() ) + { + switch (it->type()) { + case Action::nextDesktop: + cycleWorkspace(true); + break; + case Action::prevDesktop: + cycleWorkspace(false); + break; + } + break; + } + } +} // do we want to add this window to our list? bool screen::doAddWindow(Window window) const {

@@ -238,3 +258,35 @@ cout << "warning: couldn't set environment variable 'DISPLAY'\n";

perror("putenv()"); } */ + +void screen::cycleWorkspace(const bool forward) { + cout << "blef" << endl; + + unsigned long currentDesktop = 0; + unsigned long numDesktops = 0; + + if (_xatom->getValue(_root, XAtom::net_current_desktop, XAtom::cardinal, + currentDesktop)) { + if (forward) + ++currentDesktop; + else + --currentDesktop; + + cout << currentDesktop << endl; + + + _xatom->getValue(_root, XAtom::net_number_of_desktops, XAtom::cardinal, + numDesktops); + + if ( ( (signed)currentDesktop) == -1) + currentDesktop = numDesktops - 1; + else if (currentDesktop >= numDesktops) + currentDesktop = 0; + + + _xatom->sendClientMessage(_root, XAtom::net_current_desktop, _root, + currentDesktop); + + } +} +
M util/epist/screen.hhutil/epist/screen.hh

@@ -62,6 +62,10 @@ inline Window rootWindow() const { return _root; }

inline bool managed() const { return _managed; } void processEvent(const XEvent &e); + + void handleKeypress(const XEvent &e); + + void cycleWorkspace(const bool forward); }; #endif // __screen_hh