aboutsummaryrefslogtreecommitdiff
path: root/src/Screen.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/Screen.cc')
-rw-r--r--src/Screen.cc61
1 files changed, 6 insertions, 55 deletions
diff --git a/src/Screen.cc b/src/Screen.cc
index 55517d8..541b30a 100644
--- a/src/Screen.cc
+++ b/src/Screen.cc
@@ -373,7 +373,7 @@ BScreen::BScreen(FbTk::ResourceManager &rm,
373 m_altname(altscreenname), 373 m_altname(altscreenname),
374 m_focus_control(new FocusControl(*this)), 374 m_focus_control(new FocusControl(*this)),
375 m_placement_strategy(new ScreenPlacement(*this)), 375 m_placement_strategy(new ScreenPlacement(*this)),
376 m_cycling(false), m_typing_ahead(false), m_cycle_opts(0), 376 m_cycling(false), m_cycle_opts(0),
377 m_xinerama_headinfo(0), 377 m_xinerama_headinfo(0),
378 m_restart(false), 378 m_restart(false),
379 m_shutdown(false) { 379 m_shutdown(false) {
@@ -826,45 +826,9 @@ void BScreen::propertyNotify(Atom atom) {
826} 826}
827 827
828void BScreen::keyPressEvent(XKeyEvent &ke) { 828void BScreen::keyPressEvent(XKeyEvent &ke) {
829 if (!m_typing_ahead) { 829 WindowCmd<void>::setWindow(FocusControl::focusedFbWindow());
830 WindowCmd<void>::setWindow(FocusControl::focusedFbWindow()); 830 Fluxbox::instance()->keys()->doAction(ke.type, ke.state, ke.keycode,
831 Fluxbox::instance()->keys()->doAction(ke.type, ke.state, ke.keycode, 831 Keys::GLOBAL|Keys::ON_DESKTOP);
832 Keys::GLOBAL|Keys::ON_DESKTOP);
833 return;
834 }
835
836 KeySym ks;
837 char keychar[1];
838 XLookupString(&ke, keychar, 1, &ks, 0);
839 // a modifier key by itself doesn't do anything
840 if (IsModifierKey(ks))
841 return;
842
843 switch (ks) {
844 case XK_Escape:
845 case XK_KP_Enter:
846 case XK_Return:
847 m_type_ahead.reset();
848 FbTk::EventManager::instance()->ungrabKeyboard();
849 break;
850 case XK_BackSpace:
851 m_type_ahead.putBackSpace();
852 m_matches = m_type_ahead.matched();
853 break;
854 case XK_Tab:
855 case XK_ISO_Left_Tab:
856 m_type_ahead.seek();
857 focusControl().cycleFocus(m_matches, m_cycle_opts, (bool)(ke.state & ShiftMask));
858 break;
859 default:
860 m_matches = m_type_ahead.putCharacter(keychar[0]);
861 // if focused win doesn't match new search string, find the next one
862 if (!m_matches.empty() &&
863 std::find(m_matches.begin(), m_matches.end(),
864 FocusControl::focusedWindow()) == m_matches.end())
865 focusControl().cycleFocus(m_matches, m_cycle_opts);
866 break;
867 }
868} 832}
869 833
870void BScreen::keyReleaseEvent(XKeyEvent &ke) { 834void BScreen::keyReleaseEvent(XKeyEvent &ke) {
@@ -889,22 +853,9 @@ void BScreen::buttonPressEvent(XButtonEvent &be) {
889 853
890void BScreen::notifyUngrabKeyboard() { 854void BScreen::notifyUngrabKeyboard() {
891 m_cycling = false; 855 m_cycling = false;
892 m_typing_ahead = false;
893 m_type_ahead.reset();
894 focusControl().stopCyclingFocus(); 856 focusControl().stopCyclingFocus();
895} 857}
896 858
897void BScreen::startTypeAheadFocus(std::list<Focusable *> &winlist,
898 const ClientPattern *pat) {
899 m_type_ahead.init(winlist);
900 m_matches = winlist;
901 FbTk::EventManager *evm = FbTk::EventManager::instance();
902 if (!m_typing_ahead && !m_cycling)
903 evm->grabKeyboard(*this, rootWindow().window());
904 m_cycle_opts = pat;
905 m_typing_ahead = true;
906}
907
908void BScreen::cycleFocus(int options, const ClientPattern *pat, bool reverse) { 859void BScreen::cycleFocus(int options, const ClientPattern *pat, bool reverse) {
909 // get modifiers from event that causes this for focus order cycling 860 // get modifiers from event that causes this for focus order cycling
910 XEvent ev = Fluxbox::instance()->lastEvent(); 861 XEvent ev = Fluxbox::instance()->lastEvent();
@@ -914,7 +865,7 @@ void BScreen::cycleFocus(int options, const ClientPattern *pat, bool reverse) {
914 else if (ev.type == ButtonPress) 865 else if (ev.type == ButtonPress)
915 mods = FbTk::KeyUtil::instance().cleanMods(ev.xbutton.state); 866 mods = FbTk::KeyUtil::instance().cleanMods(ev.xbutton.state);
916 867
917 if (!m_cycling && !m_typing_ahead && mods) { 868 if (!m_cycling && mods) {
918 m_cycling = true; 869 m_cycling = true;
919 FbTk::EventManager::instance()->grabKeyboard(*this, rootWindow().window()); 870 FbTk::EventManager::instance()->grabKeyboard(*this, rootWindow().window());
920 } 871 }
@@ -922,7 +873,7 @@ void BScreen::cycleFocus(int options, const ClientPattern *pat, bool reverse) {
922 if (mods == 0) // can't stacked cycle unless there is a mod to grab 873 if (mods == 0) // can't stacked cycle unless there is a mod to grab
923 options |= FocusControl::CYCLELINEAR; 874 options |= FocusControl::CYCLELINEAR;
924 875
925 FocusControl::Focusables *win_list = 0; 876 const FocusControl::Focusables *win_list = 0;
926 if (options & FocusControl::CYCLEGROUPS) { 877 if (options & FocusControl::CYCLEGROUPS) {
927 win_list = (options & FocusControl::CYCLELINEAR) ? 878 win_list = (options & FocusControl::CYCLELINEAR) ?
928 &focusControl().creationOrderWinList() : 879 &focusControl().creationOrderWinList() :