aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad
diff options
context:
space:
mode:
Diffstat (limited to 'XMonad')
-rw-r--r--XMonad/Prompt.hs55
1 files changed, 31 insertions, 24 deletions
diff --git a/XMonad/Prompt.hs b/XMonad/Prompt.hs
index 2377261..8b58922 100644
--- a/XMonad/Prompt.hs
+++ b/XMonad/Prompt.hs
@@ -19,8 +19,6 @@ module XMonad.Prompt
mkXPrompt
, mkXPromptWithReturn
, defaultXPConfig
- , mkComplFunFromList
- , mkComplFunFromList'
, XPType (..)
, XPPosition (..)
, XPConfig (..)
@@ -32,8 +30,12 @@ module XMonad.Prompt
, fillDrawable
-- * Other Utilities
-- $utils
- , getNextCompletion
+ , mkComplFunFromList
+ , mkComplFunFromList'
+ -- * @nextCompletion@ implementations
, getNextOfLastWord
+ , getNextCompletion
+ -- * List utilities
, getLastWord
, skipLastWord
, splitInSubListsAt
@@ -134,15 +136,17 @@ class XPrompt t where
nextCompletion t c l = getNextOfLastWord t c l
-- | If the prompt is using 'getNextOfLastWord' for implementing
- -- 'nextCompletion' (the default implementation), this is used to
- -- generate the string to be passed to the completion function.
+ -- 'nextCompletion' (the default implementation), this method is
+ -- used to generate the string to be passed to the completion
+ -- function.
commandToComplete :: t -> String -> String
commandToComplete _ c = getLastWord c
-- | If the prompt is using 'getNextOfLastWord' for implementing
- -- 'nextCompletion' (the default implementation), this is used to
- -- generate the string to compare each completion with the
- -- command presently in the command line.
+ -- 'nextCompletion' (the default implementation), this method is
+ -- used to process each completion in order to generate the string
+ -- that will be compared with the command presently displayed in
+ -- the command line.
completionToCommand :: t -> String -> String
completionToCommand _ c = c
@@ -718,6 +722,25 @@ mkComplFunFromList' l [] = return l
mkComplFunFromList' l s =
return $ filter (\x -> take (length s) x == s) l
+
+-- | Given the prompt type, the command line and the completion list,
+-- return the next completion in the list for the last word of the
+-- command line. This is the default 'nextCompletion' implementation.
+getNextOfLastWord :: XPrompt t => t -> String -> [String] -> String
+getNextOfLastWord t c l = skipLastWord c ++ completionToCommand t (l !! ni)
+ where ni = case commandToComplete t c `elemIndex` map (completionToCommand t) l of
+ Just i -> if i >= length l - 1 then 0 else i + 1
+ Nothing -> 0
+
+-- | An alternative 'nextCompletion' implementation: given a command
+-- and a completion list, get the next completion in the list matching
+-- the whole command line.
+getNextCompletion :: String -> [String] -> String
+getNextCompletion c l = l !! idx
+ where idx = case c `elemIndex` l of
+ Just i -> if i >= length l - 1 then 0 else i + 1
+ Nothing -> 0
+
-- Lift an IO action into the XP
io :: IO a -> XP a
io = liftIO
@@ -732,22 +755,6 @@ splitInSubListsAt _ [] = []
splitInSubListsAt i x = f : splitInSubListsAt i rest
where (f,rest) = splitAt i x
--- | Given a command and a completion list, get the next completion in
--- the list.
-getNextCompletion :: String -> [String] -> String
-getNextCompletion c l = l !! idx
- where idx = case c `elemIndex` l of
- Just i -> if i >= length l - 1 then 0 else i + 1
- Nothing -> 0
-
--- | Given a completion and a list of possible completions, returns the
--- the next completion in the list
-getNextOfLastWord :: XPrompt t => t -> String -> [String] -> String
-getNextOfLastWord t c l = skipLastWord c ++ completionToCommand t (l !! ni)
- where ni = case commandToComplete t c `elemIndex` map (completionToCommand t) l of
- Just i -> if i >= length l - 1 then 0 else i + 1
- Nothing -> 0
-
-- | Gets the last word of a string or the whole string if formed by
-- only one word
getLastWord :: String -> String