diff options
-rw-r--r-- | XMonad/Util/XSelection.hs | 101 |
1 files changed, 51 insertions, 50 deletions
diff --git a/XMonad/Util/XSelection.hs b/XMonad/Util/XSelection.hs index fb9c620..fef9b3f 100644 --- a/XMonad/Util/XSelection.hs +++ b/XMonad/Util/XSelection.hs @@ -1,22 +1,20 @@ ------------------------------------------------------------------------------ --- | --- Module : XMonad.Util.XSelection --- Copyright : (C) 2007 Andrea Rossato, Matthew Sackman --- License : BSD3 --- --- Maintainer : Andrea Rossato <andrea.rossato@unibz.it>, --- Matthew Sackman <matthew@wellquite.org> --- Stability : unstable --- Portability : unportable --- --- A module for accessing and manipulating the X Window mouse selection (used in copy and pasting). --- getSelection and putSelection are adaptations of Hxsel.hs and Hxput.hs from XMonad-utils, available: --- --- $ darcs get <http://gorgias.mine.nu/repos/xmonad-utils> ------------------------------------------------------------------------------ - -module XMonad.Util.XSelection ( - -- * Usage +{- | +Module : XMonad.Util.XSelection +Copyright : (C) 2007 Andrea Rossato, Matthew Sackman +License : BSD3 + +Maintainer : Andrea Rossato <andrea.rossato@unibz.it>, + Matthew Sackman <matthew@wellquite.org> +Stability : unstable +Portability : unportable + +A module for accessing and manipulating X Window's mouse selection (the buffer used in copy and pasting). +'getSelection' and 'putSelection' are adaptations of Hxsel.hs and Hxput.hs from the XMonad-utils, available: + +> $ darcs get <http://gorgias.mine.nu/repos/xmonad-utils> +-} + +module XMonad.Util.XSelection ( -- * Usage -- $usage getSelection, promptSelection, @@ -34,26 +32,28 @@ import XMonad import XMonad.Util.Run (safeSpawn, unsafeSpawn) {- $usage - Add 'import XMonad.Util.XSelection' to the top of Config.hs - Then make use of getSelection or promptSelection as needed; if - one wanted to run Firefox with the selection as an argument (say, - the selection is an URL you just highlighted), then one could add - to the Config.hs a line like thus: - -> , ((modMask .|. shiftMask, xK_b ), promptSelection "firefox") - - TODO: - * Fix Unicode handling. Currently it's still better than calling - 'chr' to translate to ASCII, though. - As near as I can tell, the mangling happens when the String is - outputted somewhere, such as via promptSelection's passing through - the shell, or GHCi printing to the terminal. utf-string has IO functions - which can fix this, though I do not know have to use them here. It's - a complex issue; see - <http://www.haskell.org/pipermail/xmonad/2007-September/001967.html> - and <http://www.haskell.org/pipermail/xmonad/2007-September/001966.html>. - - * Possibly add some more elaborate functionality: Emacs' registers are nice. -} + Add @import XMonad.Util.XSelection@ to the top of Config.hs + Then make use of getSelection or promptSelection as needed; if + one wanted to run Firefox with the selection as an argument (perhaps + the selection string is an URL you just highlighted), then one could add + to the xmonad.hs a line like thus: + + > , ((modMask .|. shiftMask, xK_b), promptSelection "firefox") + + There are a number of known problems with XSelection: + + * Unicode handling is busted. But it's still better than calling + 'chr' to translate to ASCII, at least. + As near as I can tell, the mangling happens when the String is + outputted somewhere, such as via promptSelection's passing through + the shell, or GHCi printing to the terminal. utf-string has IO functions + which can fix this, though I do not know have to use them here. It's + a complex issue; see + <http://www.haskell.org/pipermail/xmonad/2007-September/001967.html> + and <http://www.haskell.org/pipermail/xmonad/2007-September/001966.html>. + + * Needs more elaborate functionality: Emacs' registers are nice; if you + don't know what they are, see <http://www.gnu.org/software/emacs/manual/html_node/emacs/Registers.html#Registers> -} -- | Returns a String corresponding to the current mouse selection in X; if there is none, an empty string is returned. Note that this is -- really only reliable for ASCII text and currently escapes or otherwise mangles more complex UTF-8 characters. @@ -79,7 +79,7 @@ getSelection = io $ do return $ decode . map fromIntegral . fromMaybe [] $ res else destroyWindow dpy win >> return "" --- | Set the current X Selection to a given String. +-- | Set the current X Selection to a specified string. putSelection :: MonadIO m => String -> m () putSelection text = io $ do dpy <- openDisplay "" @@ -116,24 +116,27 @@ putSelection text = io $ do print ev processEvent dpy ty text e -{- | A wrapper around getSelection. Makes it convenient to run a program with the current selection as an argument. +{- | A wrapper around 'getSelection'. Makes it convenient to run a program with the current selection as an argument. This is convenient for handling URLs, in particular. For example, in your Config.hs you could bind a key to @promptSelection \"firefox\"@; this would allow you to highlight a URL string and then immediately open it up in Firefox. -promptSelection passes strings through the shell; if you do not wish your selected text to be interpreted/mangled -by the shell, use safePromptSelection which will bypass the shell using safeSpawn from Run.hs; see Run.hs for more -details on the advantages/disadvantages of this. -} +'promptSelection' passes strings through the system shell, \/bin\/sh; if you do not wish your selected text +to be interpreted or mangled by the shell, use 'safePromptSelection'. safePromptSelection will bypass the +shell using 'safeSpawn' from "XMonad.Util.Run"; see its documentation for more +details on the advantages and disadvantages of using safeSpawn. -} promptSelection, safePromptSelection, unsafePromptSelection :: String -> X () promptSelection = unsafePromptSelection safePromptSelection app = join $ io $ liftM (safeSpawn app) (getSelection) unsafePromptSelection app = join $ io $ liftM unsafeSpawn $ fmap (\x -> app ++ " " ++ x) getSelection {- | Decode a UTF8 string packed into a list of Word8 values, directly to - String; does not deal with CChar, hence you will want the counter-intuitive 'map fromIntegral'. - UTF-8 decoding for internal use in getSelection. This code is copied from Eric Mertens's utf-string library - <http://code.haskell.org/utf8-string/> (version 0.1), which is BSD-3 licensed, as is this module. - It'd be better to just import Codec.Binary.UTF8.String (decode), but then users of this would need to install it; Xmonad has enough + String; does not deal with CChar, hence you will want the counter-intuitive @map fromIntegral@ + UTF-8 decoding for internal use in getSelection. + + This code is copied from Eric Mertens's "utf-string" library <http://code.haskell.org/utf8-string/> + (as of version 0.1),\which is BSD-3 licensed like this module. + It'd be better to just @import Codec.Binary.UTF8.String (decode)@, but then users of this would need to install it; XMonad has enough dependencies already. -} decode :: [Word8] -> String decode [ ] = "" @@ -159,9 +162,7 @@ decode (c:cs) (acc < 0xd800 || 0xdfff < acc) && (acc < 0xfffe || 0xffff < acc) = chr acc : decode rs | otherwise = replacement_character : decode rs - aux n (r:rs) acc | r .&. 0xc0 == 0x80 = aux (n-1) rs $ shiftL acc 6 .|. fromEnum (r .&. 0x3f) - aux _ rs _ = replacement_character : decode rs |