summaryrefslogtreecommitdiff
path: root/.config/xmonad/xmonadctl.hs
diff options
context:
space:
mode:
authorThanosApollo <[email protected]>2022-10-12 19:27:50 +0300
committerThanosApollo <[email protected]>2022-10-12 19:27:50 +0300
commit9624d231900e2318a48b844a045a12f316cd8be1 (patch)
treede8c76baf5850c27bc6b4418f90836ada52ed391 /.config/xmonad/xmonadctl.hs
parentb6b3156549337db18075291ba2e01055575cecd0 (diff)
Remove dt xmonad
Diffstat (limited to '.config/xmonad/xmonadctl.hs')
-rw-r--r--.config/xmonad/xmonadctl.hs51
1 files changed, 0 insertions, 51 deletions
diff --git a/.config/xmonad/xmonadctl.hs b/.config/xmonad/xmonadctl.hs
deleted file mode 100644
index d6180d5..0000000
--- a/.config/xmonad/xmonadctl.hs
+++ /dev/null
@@ -1,51 +0,0 @@
-import Graphics.X11.Xlib
-import Graphics.X11.Xlib.Extras
-import System.Environment
-import System.IO
-import Data.Char
-
-main :: IO ()
-main = parse True "XMONAD_COMMAND" =<< getArgs
-
-parse :: Bool -> String -> [String] -> IO ()
-parse input addr args = case args of
- ["--"] | input -> repl addr
- | otherwise -> return ()
- ("--":xs) -> sendAll addr xs
- ("-a":a:xs) -> parse input a xs
- ("-h":_) -> showHelp
- ("--help":_) -> showHelp
- ("-?":_) -> showHelp
- (a@('-':_):_) -> hPutStrLn stderr ("Unknown option " ++ a)
-
- (x:xs) -> sendCommand addr x >> parse False addr xs
- [] | input -> repl addr
- | otherwise -> return ()
-
-
-repl :: String -> IO ()
-repl addr = do e <- isEOF
- case e of
- True -> return ()
- False -> do l <- getLine
- sendCommand addr l
- repl addr
-
-sendAll :: String -> [String] -> IO ()
-sendAll addr ss = foldr (\a b -> sendCommand addr a >> b) (return ()) ss
-
-sendCommand :: String -> String -> IO ()
-sendCommand addr s = do
- d <- openDisplay ""
- rw <- rootWindow d $ defaultScreen d
- a <- internAtom d addr False
- m <- internAtom d s False
- allocaXEvent $ \e -> do
- setEventType e clientMessage
- setClientMessageEvent e rw a 32 m currentTime
- sendEvent d rw False structureNotifyMask e
- sync d False
-
-showHelp :: IO ()
-showHelp = do pn <- getProgName
- putStrLn ("Send commands to a running instance of xmonad. xmonad.hs must be configured with XMonad.Hooks.ServerMode to work.\n-a atomname can be used at any point in the command line arguments to change which atom it is sending on.\nIf sent with no arguments or only -a atom arguments, it will read commands from stdin.\nEx:\n" ++ pn ++ " cmd1 cmd2\n" ++ pn ++ " -a XMONAD_COMMAND cmd1 cmd2 cmd3 -a XMONAD_PRINT hello world\n" ++ pn ++ " -a XMONAD_PRINT # will read data from stdin.\nThe atom defaults to XMONAD_COMMAND.")