我想要切换之间的xmobar配置动态使用键组合。我天真地将以下内容标记在我的其他关键模块上:
, ((controlMask, xK_l), xmproc <- spawnPipe "/usr/bin/xmobar /home/tony/.xmobarLrc")
, ((controlMask, xK_w), xmproc <- spawnPipe "/usr/bin/xmobar /home/tony/.xmobarWrc")编译器在<-。你也许可以在代码中读懂我的意图。我不是Haskell专家,我正在用乐高的方法慢慢地建立我想要的环境,但是我在这里失败了。
我哪里出问题了?
提亚
发布于 2013-12-11 20:33:11
好吧,做你想做的事很复杂。您可以使用xmonad-contrib图书馆中的可扩展状态模块。
为此,必须在xmonad配置文件的顶部添加一个语言语用:
{-#语言DeriveDataTypeable #-}
您需要它来派生存储xmobar句柄的数据类型的可键入实例。
newtype XMobarHandle = XMobarHandle { xmhandle :: Maybe Handle } deriving Typeable
instance ExtensionClass XMobarHandle where
initialValue = XMobarHandle Nothing现在您可以定义键绑定,它从可扩展状态检索当前xmobar句柄,如果不是,关闭它,生成一个新句柄并将其放入状态。
((controlMask, xK_l), do
mh <- xmhandle `fmap` XS.get
maybe (return ()) (io . hClose) mh
xmproc <- spawnPipe "/usr/bin/xmobar /home/tony/.xmobarLrc"
XS.put $ XMobarHandle (Just xmproc)
)如果愿意,可以在绑定中为do块创建一个函数。另一个键的绑定是作为练习留下的!
要使其编译,您仍然需要用于此代码中的模块的导入语句。(不过,我可能忘了一个!)
import XMonad.Util.Run
import System.IO
import qualified XMonad.Util.ExtensibleState as XS你也必须编辑你的logHook。在这里,您必须从可扩展状态中提取句柄,就像在keybind中一样,并将其作为函数xmobarlog的参数。
https://stackoverflow.com/questions/19285278
复制相似问题