X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=util%2Fepist%2Fepist.hh;h=64970e57904872f346a47d247d287ed3d9b9ef89;hb=5dc5cc32b0c00c3bfba8ea5727599f49b56ae817;hp=6da3818188283a9c16bbde93e9eaec6c3c7dcce5;hpb=fc792813a24d22330b49eda8b3ef7054eadf20d3;p=chaz%2Fopenbox diff --git a/util/epist/epist.hh b/util/epist/epist.hh index 6da38181..64970e57 100644 --- a/util/epist/epist.hh +++ b/util/epist/epist.hh @@ -1,5 +1,5 @@ -// -*- mode: C++; indent-tabs-mode: nil; -*- -// epist.hh for Epistophy - a key handler for NETWM/EWMH window managers. +// -*- mode: C++; indent-tabs-mode: nil; c-basic-offset: 2; -*- +// epist.hh for Epistrophy - a key handler for NETWM/EWMH window managers. // Copyright (c) 2002 - 2002 Ben Jansens // // Permission is hereby granted, free of charge, to any person obtaining a @@ -31,36 +31,39 @@ extern "C" { #include #include "actions.hh" +#include "window.hh" +#include "keytree.hh" +#include "config.hh" -#include "../../src/BaseDisplay.hh" +#include "../../src/basedisplay.hh" class XAtom; class screen; -class XWindow; class epist : public BaseDisplay { private: - std::string _rc_file; - XAtom *_xatom; - char **_argv; + std::string _rc_file; + XAtom *_xatom; + char **_argv; + keytree *_ktree; + Config *_config; typedef std::vector ScreenList; - ScreenList _screens; + ScreenList _screens; typedef std::map WindowLookup; typedef WindowLookup::value_type WindowLookupPair; WindowLookup _windows; + + WindowList _clients; + WindowList::iterator _active; - ActionList _actions; + ActionList _actions; virtual void process_event(XEvent *e); virtual bool handleSignal(int sig); void activateGrabs(); - void addAction(Action::ActionType act, unsigned int modifiers, - std::string key, int number = 0); - void addAction(Action::ActionType act, unsigned int modifiers, - std::string key, std::string str); public: epist(char **argv, char *display_name, char *rc_file); @@ -72,12 +75,19 @@ public: void removeWindow(XWindow *window); XWindow *findWindow(Window window) const; + void cycleScreen(int current, bool forward) const; + void getLockModifiers(int &numlockMask, int &scrolllockMask) const { numlockMask = NumLockMask; scrolllockMask = ScrollLockMask; } const ActionList &actions(void) { return _actions; } + keytree &getKeyTree(void) { return *_ktree; } + inline const Config *getConfig(void) { return _config; } + + WindowList& clientsList() { return _clients; } + WindowList::iterator& activeWindow() { return _active; } }; #endif // __epist_hh