mirror of
https://github.com/xmonad/xmonad-contrib.git
synced 2025-07-30 19:51:51 -07:00
ShellPrompt: a graphical shell prompt
This module requires readline and so a modification to xmonad.cabal. See usage for instructions.
This commit is contained in:
82
ShellPrompt.hs
Normal file
82
ShellPrompt.hs
Normal file
@@ -0,0 +1,82 @@
|
||||
-----------------------------------------------------------------------------
|
||||
-- |
|
||||
-- Module : XMonadContrib.ShellPrompt
|
||||
-- Copyright : (C) 2007 Andrea Rossato
|
||||
-- License : BSD3
|
||||
--
|
||||
-- Maintainer : andrea.rossato@unibz.it
|
||||
-- Stability : unstable
|
||||
-- Portability : unportable
|
||||
--
|
||||
-- A shell prompt for XMonad
|
||||
--
|
||||
-----------------------------------------------------------------------------
|
||||
|
||||
module XMonadContrib.ShellPrompt (
|
||||
-- * Usage
|
||||
-- $usage
|
||||
shellPrompt
|
||||
) where
|
||||
{-
|
||||
usage:
|
||||
1. In xmonad.cabal change:
|
||||
build-depends: base>=2.0, X11>=1.2.1, X11-extras>=0.2, mtl>=1.0, unix>=1.0
|
||||
to
|
||||
build-depends: base>=2.0, X11>=1.2.1, X11-extras>=0.2, mtl>=1.0, unix>=1.0, readline >= 1.0
|
||||
|
||||
2. In Config.hs add:
|
||||
> import XMonadContrib.ShellPrompt
|
||||
|
||||
3. In your keybindings add something like:
|
||||
|
||||
> , ((modMask .|. controlMask, xK_x), shellPrompt defaultPromptConfig)
|
||||
|
||||
-}
|
||||
|
||||
import XMonad
|
||||
import XMonadContrib.XPrompt
|
||||
|
||||
import Control.Monad
|
||||
import Data.List
|
||||
import System.Console.Readline
|
||||
import System.Environment
|
||||
|
||||
data Shell = Shell
|
||||
|
||||
instance XPrompt Shell where
|
||||
showXPrompt Shell = "Run: "
|
||||
|
||||
|
||||
shellPrompt :: XPConfig -> X ()
|
||||
shellPrompt c = mkXPrompt Shell c getShellCompl spawn
|
||||
|
||||
getShellCompl :: String -> IO [String]
|
||||
getShellCompl s
|
||||
| s /= "" && last s /= ' ' = do
|
||||
fl <- filenameCompletionFunction (last . words $ s)
|
||||
c <- commandCompletionFunction (last . words $ s)
|
||||
return $ sort . nub $ fl ++ c
|
||||
| otherwise = return []
|
||||
|
||||
commandCompletionFunction :: String -> IO [String]
|
||||
commandCompletionFunction str
|
||||
| '/' `elem` str = return []
|
||||
| otherwise = do
|
||||
p <- getEnv "PATH"
|
||||
cl p
|
||||
where
|
||||
cl = liftM (nub . rmPath . concat) . mapM fCF . map addToPath . split ':'
|
||||
addToPath = flip (++) ("/" ++ str)
|
||||
fCF = filenameCompletionFunction
|
||||
rmPath [] = []
|
||||
rmPath s = map (last . split '/') s
|
||||
|
||||
split :: Eq a => a -> [a] -> [[a]]
|
||||
split _ [] = []
|
||||
split e l =
|
||||
f : split e (rest ls)
|
||||
where
|
||||
(f,ls) = span (/=e) l
|
||||
rest s | s == [] = []
|
||||
| otherwise = tail s
|
||||
|
Reference in New Issue
Block a user