diff options
-rw-r--r-- | XMonad/Prompt.hs | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/XMonad/Prompt.hs b/XMonad/Prompt.hs index cbcf7a3..c8664b4 100644 --- a/XMonad/Prompt.hs +++ b/XMonad/Prompt.hs @@ -43,6 +43,7 @@ module XMonad.Prompt , uniqSort , decodeInput , encodeOutput + , historyCompletion ) where import XMonad hiding (config, io) @@ -779,3 +780,15 @@ breakAtSpace s -- | Sort a list and remove duplicates. uniqSort :: Ord a => [a] -> [a] uniqSort = toList . fromList + +-- | 'historyCompletion' provides a canned completion function much like +-- getShellCompl; you pass it to mkXPrompt, and it will make completions work +-- from the query history stored in ~/.xmonad/history. +historyCompletion :: ComplFunction +historyCompletion = \x -> liftM (filter $ isInfixOf x) readHistoryIO + +-- We need to define this locally because there is no function with the type "XP a -> IO a", and +-- 'getHistory' is uselessly of the type "XP [String]". +readHistoryIO :: IO [String] +readHistoryIO = do (hist,_) <- readHistory + return $ map command_history hist
\ No newline at end of file |