From f6acbdf28f24370a544d2fb95c238d69b37b2d5c Mon Sep 17 00:00:00 2001 From: Dmitriy Pleshevskiy Date: Sat, 18 Jun 2022 13:18:35 +0300 Subject: [PATCH] stop ibus on startup misc changes - remove unused help method - change order of functions --- programs/xmonad/xmonad.hs | 287 +++++++++++++++----------------------- 1 file changed, 115 insertions(+), 172 deletions(-) diff --git a/programs/xmonad/xmonad.hs b/programs/xmonad/xmonad.hs index 59a9c93..67f7c6a 100644 --- a/programs/xmonad/xmonad.hs +++ b/programs/xmonad/xmonad.hs @@ -68,6 +68,121 @@ myWorkspaces = ["1:web", "2:front", "3:back", "4:chat"] <> map show [5..9] myNormalBorderColor = "#444" myFocusedBorderColor = "#f00" +------------------------------------------------------------------------ +-- Now run xmonad with all the defaults we set up. + +-- Run xmonad with the settings you specify. No need to modify this. +-- +main = xmonad . ewmhFullscreen . ewmh . xmobarProp $ defaults + +-- A structure containing your configuration settings, overriding +-- fields in the default config. Any you don't override, will +-- use the defaults defined in xmonad/XMonad/Config.hs +-- +-- No need to modify this. +-- +defaults = def + -- simple stuff + { terminal = myTerminal + , focusFollowsMouse = myFocusFollowsMouse + , clickJustFocuses = myClickJustFocuses + , borderWidth = myBorderWidth + , modMask = myModMask + , workspaces = myWorkspaces + , normalBorderColor = myNormalBorderColor + , focusedBorderColor = myFocusedBorderColor + -- key bindings + , keys = myKeys + , mouseBindings = myMouseBindings + -- hooks, layouts + , layoutHook = myLayout + , manageHook = myManageHook + , handleEventHook = myEventHook + , logHook = myLogHook + , startupHook = myStartupHook + } + +------------------------------------------------------------------------ +-- Layouts: + +-- You can specify and transform your layouts by modifying these values. +-- If you change layout bindings be sure to use 'mod-shift-space' after +-- restarting (with 'mod-q') to reset your layout state to the new +-- defaults, as xmonad preserves your old layout settings by default. +-- +-- The available layouts. Note that each layout is separated by |||, +-- which denotes layout choice. +-- +myLayout = avoidStruts + $ onWorkspaces ["2:front", "3:back"] (myMirror (2/3) ||| myTall (1/2) ||| myFull ||| Grid) + $ myTall (1/2) ||| myMirror (1/2) ||| myFull ||| Grid + where + myMirror = limitWindows 5 . Mirror . myTall + + myTall = boringWindows . smartBorders . Tall 1 (3/100) + + myFull = noBorders Full + +------------------------------------------------------------------------ +-- Startup hook + +-- Perform an arbitrary action each time xmonad starts or is restarted +-- with mod-q. Used by, e.g., XMonad.Layout.PerWorkspace to initialize +-- per-workspace layout choices. +-- +-- By default, do nothing. +myStartupHook = do + spawn "ibus exit" + +------------------------------------------------------------------------ +-- Status bars and logging + +-- Perform an arbitrary action on each internal state change or X event. +-- See the 'XMonad.Hooks.DynamicLog' extension for examples. +-- +myLogHook = return () + +------------------------------------------------------------------------ +-- Event handling + +-- * EwmhDesktops users should change this to ewmhDesktopsEventHook +-- +-- Defines a custom handler function for X Events. The function should +-- return (All True) if the default handler is to be run afterwards. To +-- combine event hooks use mappend or mconcat from Data.Monoid. +-- +myEventHook = mempty + +------------------------------------------------------------------------ +-- Window rules: + +-- Execute arbitrary actions and WindowSet manipulations when managing +-- a new window. You can use this to, for example, always float a +-- particular program, or have a client always appear on a particular +-- workspace. +-- +-- To find the property name associated with a program, use +-- > xprop | grep WM_CLASS +-- and click on the client you're interested in. +-- +-- To match on the WM_NAME, you can use 'title' in the same way that +-- 'className' and 'resource' are used below. +-- +myManageHook = composeAll + [ resource =? "desktop_window" --> doIgnore + , resource =? "kdesktop" --> doIgnore + -- apps + , className =? "Gimp" --> doFloat + , className =? "Gnome-calculator" --> doFloat + , className =? "Gnome-font-viewer" --> doFloat + , className =? "Org.gnome.Nautilus" --> doFloat + , resource =? "telegram-desktop" --> doShift "4:chat" + , className =? "Thunderbird" --> doShift "4:chat" + -- my libs + , resource =? "hwt" --> doFloat + ] + + ------------------------------------------------------------------------ -- Key bindings. Add, modify or remove key bindings here. -- @@ -147,9 +262,6 @@ myKeys conf = mkKeymap conf $ -- Restart xmonad , ("M-q", spawn "xmonad --recompile; xmonad --restart") - -- Run xmessage with a summary of the default keybindings (useful for beginners) - , ("M-S-/", xmessage help) - ] ++ @@ -177,172 +289,3 @@ myMouseBindings (XConfig {XMonad.modMask = modm}) = M.fromList -- you may also bind events to the mouse scroll wheel (button4 and button5) ] - ------------------------------------------------------------------------- --- Layouts: - --- You can specify and transform your layouts by modifying these values. --- If you change layout bindings be sure to use 'mod-shift-space' after --- restarting (with 'mod-q') to reset your layout state to the new --- defaults, as xmonad preserves your old layout settings by default. --- --- The available layouts. Note that each layout is separated by |||, --- which denotes layout choice. --- -myLayout = avoidStruts - $ onWorkspaces ["2:front", "3:back"] (myMirror (2/3) ||| myTall (1/2) ||| myFull ||| Grid) - $ myTall (1/2) ||| myMirror (1/2) ||| myFull ||| Grid - where - myMirror = limitWindows 5 . Mirror . myTall - - myTall = boringWindows . smartBorders . Tall 1 (3/100) - - myFull = noBorders Full - ------------------------------------------------------------------------- --- Window rules: - --- Execute arbitrary actions and WindowSet manipulations when managing --- a new window. You can use this to, for example, always float a --- particular program, or have a client always appear on a particular --- workspace. --- --- To find the property name associated with a program, use --- > xprop | grep WM_CLASS --- and click on the client you're interested in. --- --- To match on the WM_NAME, you can use 'title' in the same way that --- 'className' and 'resource' are used below. --- -myManageHook = composeAll - [ resource =? "desktop_window" --> doIgnore - , resource =? "kdesktop" --> doIgnore - -- apps - , className =? "Gimp" --> doFloat - , className =? "Gnome-calculator" --> doFloat - , className =? "Gnome-font-viewer" --> doFloat - , className =? "Org.gnome.Nautilus" --> doFloat - , resource =? "telegram-desktop" --> doShift "4:chat" - , className =? "Thunderbird" --> doShift "4:chat" - -- my libs - , resource =? "hwt" --> doFloat - ] - ------------------------------------------------------------------------- --- Event handling - --- * EwmhDesktops users should change this to ewmhDesktopsEventHook --- --- Defines a custom handler function for X Events. The function should --- return (All True) if the default handler is to be run afterwards. To --- combine event hooks use mappend or mconcat from Data.Monoid. --- -myEventHook = mempty - ------------------------------------------------------------------------- --- Status bars and logging - --- Perform an arbitrary action on each internal state change or X event. --- See the 'XMonad.Hooks.DynamicLog' extension for examples. --- -myLogHook = return () - ------------------------------------------------------------------------- --- Startup hook - --- Perform an arbitrary action each time xmonad starts or is restarted --- with mod-q. Used by, e.g., XMonad.Layout.PerWorkspace to initialize --- per-workspace layout choices. --- --- By default, do nothing. -myStartupHook = return () - ------------------------------------------------------------------------- --- Now run xmonad with all the defaults we set up. - --- Run xmonad with the settings you specify. No need to modify this. --- -main = xmonad . ewmhFullscreen . ewmh . xmobarProp $ defaults - --- A structure containing your configuration settings, overriding --- fields in the default config. Any you don't override, will --- use the defaults defined in xmonad/XMonad/Config.hs --- --- No need to modify this. --- -defaults = def - -- simple stuff - { terminal = myTerminal - , focusFollowsMouse = myFocusFollowsMouse - , clickJustFocuses = myClickJustFocuses - , borderWidth = myBorderWidth - , modMask = myModMask - , workspaces = myWorkspaces - , normalBorderColor = myNormalBorderColor - , focusedBorderColor = myFocusedBorderColor - -- key bindings - , keys = myKeys - , mouseBindings = myMouseBindings - -- hooks, layouts - , layoutHook = myLayout - , manageHook = myManageHook - , handleEventHook = myEventHook - , logHook = myLogHook - , startupHook = myStartupHook - } - --- | Finally, a copy of the default bindings in simple textual tabular format. -help :: String -help = unlines - [ "The default modifier key is 'alt'. Default keybindings:" - , "" - , "-- launching and killing programs" - , "mod-Shift-Enter Launch 'alacritty' terminal" - , "mod-Shift-s Launch 'flameshot' to screenshot" - , "mod-p Launch 'dmenu_run'" - , "mod-Shift-c Close/kill the focused window" - , "mod-Shift-/ Show this help message with the default keybindings" - , "" - , "-- move focus up or down the window stack" - , "mod-j Move focus to the next window" - , "mod-k Move focus to the previous window" - , "mod-m Move focus to the master window" - , "" - , "-- modifying the window order" - , "mod-Return Swap the focused window and the master window" - , "mod-Shift-j Swap the focused window with the next window" - , "mod-Shift-k Swap the focused window with the previous window" - , "" - , "-- workspace layout" - , "mod-Space Rotate through the available layout algorithms" - , "mod-Shift-Space Reset the layouts on the current workspace to default" - , "mod-n Resize/refresh viewed windows to the correct size" - , "mod-h Shrink the master area" - , "mod-l Expand the master area" - , "mod-t Push window back into tiling; unfloat and re-tile it" - , "" - , "-- increase or decrease number of windows in the master area" - , "mod-comma (mod-,) Increment the number of windows in the master area" - , "mod-period (mod-.) Deincrement the number of windows in the master area" - , "" - , "-- System " - , "mod4-l Lock screen" - , "mod4-Shift-q Quit xmonad" - , "mod-q Restart xmonad" - , "" - , "-- Workspaces & screens" - , "mod-[1..9] Switch to workSpace N" - , "mod-Shift-[1..9] Move client to workspace N" - , "mod-{w,e,r} Switch to physical/Xinerama screens 1, 2, or 3" - , "mod-Shift-{w,e,r} Move client to screen 1, 2, or 3" - , "" - , "-- Mouse bindings: default actions bound to mouse events" - , "mod-button1 Set the window to floating mode and move by dragging" - , "mod-button2 Raise the window to the top of the stack" - , "mod-button3 Set the window to floating mode and resize by dragging" - , "" - , "-- Volume" - , " Mute/Unmute" - , " Increase volume by 1%" - , " Decrease volume by 1%" - ]