diff options
author | Adam Vogt <vogt.adam@gmail.com> | 2009-11-14 23:37:26 +0100 |
---|---|---|
committer | Adam Vogt <vogt.adam@gmail.com> | 2009-11-14 23:37:26 +0100 |
commit | 10a0cd4e7f614fb0e67a7e0e49483752c13b7642 (patch) | |
tree | 5aec4025cafcf8ba1ff5adbcec6875f87941ac95 | |
parent | dfb15478f05280486f694ffc648d0f6b12670f6f (diff) | |
download | XMonadContrib-10a0cd4e7f614fb0e67a7e0e49483752c13b7642.tar.gz XMonadContrib-10a0cd4e7f614fb0e67a7e0e49483752c13b7642.tar.xz XMonadContrib-10a0cd4e7f614fb0e67a7e0e49483752c13b7642.zip |
Bypass more of stringToKeysym in U.Paste
Ignore-this: 617c922647e9f49f5ecefa0eb1c65d3c
darcs-hash:20091114223726-1499c-aac00e2ea1780619f15462df90216eba005ba8d1.gz
-rw-r--r-- | XMonad/Util/EZConfig.hs | 4 | ||||
-rw-r--r-- | XMonad/Util/Paste.hs | 6 |
2 files changed, 8 insertions, 2 deletions
diff --git a/XMonad/Util/EZConfig.hs b/XMonad/Util/EZConfig.hs index 299138b..aa219f8 100644 --- a/XMonad/Util/EZConfig.hs +++ b/XMonad/Util/EZConfig.hs @@ -27,7 +27,9 @@ module XMonad.Util.EZConfig ( -- * Emacs-style keybinding specifications mkKeymap, checkKeymap, - mkNamedKeymap + mkNamedKeymap, + + parseKey -- used by XMonad.Util.Paste ) where import XMonad diff --git a/XMonad/Util/Paste.hs b/XMonad/Util/Paste.hs index ac7358b..d6a5467 100644 --- a/XMonad/Util/Paste.hs +++ b/XMonad/Util/Paste.hs @@ -28,8 +28,11 @@ import Graphics.X11.Xlib.Extras (none, setEventType, setKeyEvent) import Control.Monad.Reader (asks) import XMonad.Operations (withFocused) import Data.Char (isUpper) +import Data.Maybe (listToMaybe) import Graphics.X11.Xlib.Misc (stringToKeysym) import XMonad.Util.XSelection (getSelection) +import XMonad.Util.EZConfig (parseKey) +import Text.ParserCombinators.ReadP (readP_to_S) {- $usage @@ -70,7 +73,8 @@ pasteString = mapM_ (\x -> if isUpper x then pasteChar shiftMask x else pasteCha have trouble with any 'Char' outside ASCII. -} pasteChar :: KeyMask -> Char -> X () -pasteChar m c = sendKey m $ stringToKeysym [c] +pasteChar m c = sendKey m $ maybe (stringToKeysym [c]) fst + $ listToMaybe $ readP_to_S parseKey [c] sendKey :: KeyMask -> KeySym -> X () sendKey = (withFocused .) . sendKeyWindow |