summaryrefslogtreecommitdiff
path: root/util/epist/parser.cc
diff options
context:
space:
mode:
authorScott Moynes <smoynes@nexus.carleton.ca>2002-08-08 03:10:54 +0000
committerScott Moynes <smoynes@nexus.carleton.ca>2002-08-08 03:10:54 +0000
commit97e86c912ee33e9e75e68f9c193d78879f91d542 (patch)
tree7238344d0c7ed0f52300e36b21f5c543129aeee9 /util/epist/parser.cc
parent90ee16fc8664f38683edf3b2eb4dd376a572f4ce (diff)
A few bug fixes and change the config to case insensitive and be more
tolerant of errors.
Diffstat (limited to 'util/epist/parser.cc')
-rw-r--r--util/epist/parser.cc68
1 files changed, 34 insertions, 34 deletions
diff --git a/util/epist/parser.cc b/util/epist/parser.cc
index bbf5dad1..1bea940e 100644
--- a/util/epist/parser.cc
+++ b/util/epist/parser.cc
@@ -1,14 +1,13 @@
extern "C" {
#include <stdio.h>
+#include <string.h>
}
#include "parser.hh"
-
#include <string>
using std::string;
-
parser::parser(keytree *kt)
: _kt(kt), _mask(0), _action(Action::noaction), _key(""), _arg("")
{
@@ -35,7 +34,7 @@ void parser::parse(string rc_file)
void parser::setAction(string act)
{
struct {
- string str;
+ const char* str;
Action::ActionType act;
}
actions[] = {
@@ -47,36 +46,36 @@ void parser::setAction(string act)
{ "close", Action::close },
{ "toggleshade", Action::toggleshade },
{ "toggleomnipresent", Action::toggleomnipresent },
- { "moveWindowUp", Action::moveWindowUp },
- { "moveWindowDown", Action::moveWindowDown },
- { "moveWindowLeft", Action::moveWindowLeft },
- { "moveWindowRight", Action::moveWindowRight },
- { "resizeWindowWidth", Action::resizeWindowWidth },
- { "resizeWindowHeight", Action::resizeWindowHeight },
- { "toggleMaximizeFull", Action::toggleMaximizeFull },
- { "toggleMaximizeVertical", Action::toggleMaximizeVertical },
- { "toggleMaximizeHorizontal", Action::toggleMaximizeHorizontal },
- { "sendToWorkspace", Action::sendToWorkspace },
- { "nextWindow", Action::nextWindow },
- { "prevWindow", Action::prevWindow },
- { "nextWindowOnAllWorkspaces", Action::nextWindowOnAllWorkspaces },
- { "prevWindowOnAllWorkspaces", Action::prevWindowOnAllWorkspaces },
- { "nextWindowOnAllScreens", Action::nextWindowOnAllScreens },
- { "prevWindowOnAllScreens", Action::prevWindowOnAllScreens },
- { "nextWindowOfClass", Action::nextWindowOfClass },
- { "prevWindowOfClass", Action::prevWindowOfClass },
- { "nextWindowOfClassOnAllWorkspaces", Action::nextWindowOfClassOnAllWorkspaces },
- { "prevWindowOfClassOnAllWorkspaces", Action::prevWindowOfClassOnAllWorkspaces },
- { "changeWorkspace", Action::changeWorkspace },
- { "nextWorkspace", Action::nextWorkspace },
- { "prevWorkspace", Action::prevWorkspace },
- { "nextScreen", Action::nextScreen },
- { "prevScreen", Action::prevScreen },
- { "showRootMenu", Action::showRootMenu },
- { "showWorkspaceMenu", Action::showWorkspaceMenu },
- { "stringChain", Action::stringChain },
- { "keyChain", Action::keyChain },
- { "numberChain", Action::numberChain },
+ { "movewindowup", Action::moveWindowUp },
+ { "movewindowdown", Action::moveWindowDown },
+ { "movewindowleft", Action::moveWindowLeft },
+ { "movewindowright", Action::moveWindowRight },
+ { "resizewindowwidth", Action::resizeWindowWidth },
+ { "resizewindowheight", Action::resizeWindowHeight },
+ { "togglemaximizefull", Action::toggleMaximizeFull },
+ { "togglemaximizevertical", Action::toggleMaximizeVertical },
+ { "togglemaximizehorizontal", Action::toggleMaximizeHorizontal },
+ { "sendtoworkspace", Action::sendToWorkspace },
+ { "nextwindow", Action::nextWindow },
+ { "prevwindow", Action::prevWindow },
+ { "nextwindowonallworkspaces", Action::nextWindowOnAllWorkspaces },
+ { "prevwindowonallworkspaces", Action::prevWindowOnAllWorkspaces },
+ { "nextwindowonallscreens", Action::nextWindowOnAllScreens },
+ { "prevwindowonallscreens", Action::prevWindowOnAllScreens },
+ { "nextwindowofclass", Action::nextWindowOfClass },
+ { "prevwindowofclass", Action::prevWindowOfClass },
+ { "nextwindowofclassonallworkspaces", Action::nextWindowOfClassOnAllWorkspaces },
+ { "prevwindowofclassonallworkspaces", Action::prevWindowOfClassOnAllWorkspaces },
+ { "changeworkspace", Action::changeWorkspace },
+ { "nextworkspace", Action::nextWorkspace },
+ { "prevworkspace", Action::prevWorkspace },
+ { "nextscreen", Action::nextScreen },
+ { "prevscreen", Action::prevScreen },
+ { "showrootmenu", Action::showRootMenu },
+ { "showworkspacemenu", Action::showWorkspaceMenu },
+ { "stringchain", Action::stringChain },
+ { "keychain", Action::keyChain },
+ { "numberchain", Action::numberChain },
{ "cancel", Action::cancel },
{ "", Action::noaction }
};
@@ -84,7 +83,7 @@ void parser::setAction(string act)
bool found = false;
for (int i = 0; actions[i].str != ""; ++i) {
- if (actions[i].str == act) {
+ if ( strcasecmp(actions[i].str, act.c_str()) == 0 ) {
_action = actions[i].act;
found = true;
}
@@ -104,6 +103,7 @@ void parser::addModifier(string mod)
{ "Mod1", Mod1Mask },
{ "Mod2", Mod2Mask },
{ "Mod3", Mod3Mask },
+ { "Mod4", Mod4Mask },
{ "Control", ControlMask },
{ "Shift", ShiftMask },
{ "", 0 }