この関数を期待どおりに機能させるのに問題があります。
setScreenAndWorkspace i =
windows (viewOnScreen screenId workspaceId)
where
screenId = ((i-1) `mod` numberOfScreens)
-- workspaceId = show i -- doesn't work for some reason
workspaceId =
case i of
1 -> "1"
2 -> "2"
3 -> "3"
4 -> "4"
5 -> "5"
6 -> "6"
7 -> "7"
8 -> "8"
9 -> "9"
私は次のように関数を呼び出しています:
myKeys =
[
("M-1" , setScreenAndWorkspace 1),
("M-2" , setScreenAndWorkspace 2),
("M-3" , setScreenAndWorkspace 3),
("M-4" , setScreenAndWorkspace 4),
("M-5" , setScreenAndWorkspace 5),
("M-6" , setScreenAndWorkspace 6),
("M-7" , setScreenAndWorkspace 7),
("M-8" , setScreenAndWorkspace 8),
("M-9" , setScreenAndWorkspace 9)
]
まず、showiはのケースiと同じようには見えません。私はいくつかの基本的なHaskellのことを誤解しているに違いありません。show iを使用すると、xmonadがワークスペースを見つけることができないようです。
2番目の問題は、関数が機能するが、常にフォーカスを転送するとは限らないことです。画面を設定し、ワークスペースを設定し、そのワークスペースにフォーカスを設定するには、キーシーケンスを2回押す必要があります。