123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468 |
- --
- -- xmonad example config file.
- --
- -- A template showing all available configuration hooks,
- -- and how to override the defaults in your own xmonad.hs conf file.
- --
- -- Normally, you'd only override those defaults you care about.
- --
- import XMonad
- import System.Exit
- import System.IO
- import XMonad.Util.Run
- import XMonad.Util.Scratchpad
- import XMonad.Util.Loggers
- import XMonad.Actions.WindowBringer
- import XMonad.Layout.WindowNavigation
- import XMonad.Config.Azerty
- import XMonad.Hooks.DynamicLog
- import XMonad.Hooks.ManageDocks
- --import XMonad.Util.EZConfig(additionalKeys)
- import Graphics.X11.ExtraTypes.XF86
- import XMonad.Hooks.EwmhDesktops
- import XMonad.Hooks.SetWMName
- import XMonad.Hooks.ManageHelpers
- import XMonad.Layout.MosaicAlt
- import XMonad.Layout.ResizableTile
- import XMonad.Layout.Tabbed
- import XMonad.Layout.NoBorders
- import XMonad.Layout.Grid
- --import XMonad.Layout.TwoPane
- import XMonad.Layout.Fullscreen
- import XMonad.Layout.Maximize
- -- fullscreen attempt:
- --import XMonad.Layout.Spacing
- --import XMonad.Layout.Gaps
- --import XMonad.Layout.ResizableTile
- -----import XMonad.Layout.NoBorders
- --import XMonad.Layout.Fullscreen (fullscreenFull)
- --import XMonad.Layout.Cross(simpleCross)
- --import XMonad.Layout.Spiral(spiral)
- --import XMonad.Layout.ThreeColumns
- --import XMonad.Layout.MultiToggle
- --import XMonad.Layout.MultiToggle.Instances
- --import XMonad.Layout.IndependentScreens
- -- import System.Cmd
- import System.Process
- import qualified XMonad.StackSet as W
- import qualified Data.Map as M
- -- The preferred terminal program, which is used in a binding below and by
- -- certain contrib modules.
- --
- myTerminal = "uxterm -bg \"grey10\" -fg grey +sb"
- --myTerminology = "terminology"
- myUrxvt = "urxvt -bg \"grey10\" -fg grey +sb"
- myBrowser = "firefox"
- myChat = "pidgin"
- myExecuteCommand = "gmrun"
- myPassCommand = "passmenu"
- myFileManager = "ranger"
- myMail = "uxterm -e mutt" -- -F ~/.muttrc.enstb"
- myLock = "xautolock -time 3 -locker 'i3lock -d -i ~/images/gentoo/gentoo-larry-bg-1280x800.png -t' & xautolock -locknow -locker 'i3lock -d -i ~/images/gentoo/gentoo-larry-bg-1280x800.png -t'"
- myImgurScreenshot = "imgur-screenshot.sh" -- && mplayer /usr/share/sounds/freedesktop/stereo/screen-capture.oga"
- myPointer = "find-cursor --size 150 --distance 40 --wait 400 --line-width 4 --color red"
- -- Width of the window border in pixels.
- --
- myBorderWidth = 1
- -- modMask lets you specify which modkey you want to use. The default
- -- is mod1Mask ("left alt"). You may also consider using mod3Mask
- -- ("right alt"), which does not conflict with emacs keybindings. The
- -- "windows key" is usually mod4Mask.
- --
- myModMask = mod1Mask
- myAltModMask = mod4Mask
- -- The mask for the numlock key. Numlock status is "masked" from the
- -- current modifier status, so the keybindings will work with numlock on or
- -- off. You may need to change this on some systems.
- --
- -- You can find the numlock modifier by running "xmodmap" and looking for a
- -- modifier with Num_Lock bound to it:
- --
- -- > $ xmodmap | grep Num
- -- > mod2 Num_Lock (0x4d)
- --
- -- Set numlockMask = 0 if you don't have a numlock key, or want to treat
- -- numlock status separately.
- --
- myNumlockMask = mod2Mask
- -- The default number of workspaces (virtual screens) and their names.
- -- By default we use numeric strings, but any string may be used as a
- -- workspace name. The number of workspaces is determined by the length
- -- of this list.
- --
- -- A tagging example:
- --
- -- > workspaces = ["web", "irc", "code" ] ++ map show [4..9]
- --
- --myWorkspaces = ["1","2","3","4","5","utils","web","mail","chat"]
- myWorkspaces = ["1","2","3","4","5","6","7","8","9"]
- --myWorkspaces = ["\61612","\61899","\61947","\61635","\61502","\61501","\61705","\61564","\62150","\61872"]
- -- Border colors for unfocused and focused windows, respectively.
- --
- myNormalBorderColor = "#006633" --"#0033cc" -- "#dddddd"
- myFocusedBorderColor = "#ff0000"
- ------------------------------------------------------------------------
- -- Key bindings. Add, modify or remove key bindings here.
- --
- myKeys conf@(XConfig {XMonad.modMask = modMask}) = M.fromList $
- -- launch a terminal
- [ ((modMask .|. shiftMask, xK_Return), spawn $ XMonad.terminal conf)
- , ((myAltModMask .|. shiftMask, xK_Return), spawn $ XMonad.terminal conf)
- -- my custom bindings
- , ((myAltModMask, xK_u), spawn $ XMonad.terminal conf)
- , ((myAltModMask, xK_a), spawn $ myUrxvt)
- , ((myAltModMask, xK_f), spawn $ myBrowser)
- -- , ((myAltModMask, xK_k), spawn $ myBrowser2)
- -- , ((myAltModMask, xK_c), spawn $ myBrowser3)
- , ((myAltModMask, xK_g), spawn $ myChat)
- , ((myAltModMask, xK_t), spawn $ myMail)
- -- , ((myAltModMask .|. shiftMask, xK_s), spawn $ mySSH)
- , ((myAltModMask, xK_x), spawn $ myExecuteCommand)
- , ((myAltModMask, xK_z), spawn $ myPassCommand )
- , ((myAltModMask, xK_m), spawn $ myFileManager)
- , ((myAltModMask, xK_l), spawn $ myLock)
- -- attempt to have something with fullscreen:
- -- , ((myAltModMask, xK_b), sendMessage ToggleGaps >> spawn "polybar-msg cmd toggle")
- , ((myAltModMask, xK_c), spawn $ myImgurScreenshot)
- , ((myAltModMask, xK_p), spawn $ myPointer)
- -- touche "courriel" sur un bépo TypeMatrix 2030
- , ((0, 0x1008ff19), spawn $ myPointer)
- -- touche PrintScr keysym 0xff61, Print
- , ((0, 0xff61), spawn $ myPointer)
- -- https://superuser.com/questions/389737/how-do-you-make-volume-keys-and-mute-key-work-in-xmonad
- -- launch dmenu
- , ((modMask, xK_p ), spawn "exe=`dmenu_path | dmenu` && eval \"exec $exe\"")
- -- scratch pad
- , ((modMask, xK_backslash), scratchpadSpawnAction conf)
- , ((modMask, xK_0), scratchpadSpawnAction conf)
- , ((myAltModMask, xK_backslash), scratchpadSpawnAction conf)
- , ((myAltModMask, xK_0), scratchpadSpawnAction conf)
- --"zooming" (import Maximize
- , ((modMask, xK_b), withFocused ( sendMessage . maximizeRestore))
- , ((myAltModMask, xK_b), withFocused ( sendMessage . maximizeRestore))
- --test
- , ((myAltModMask, 0x69), scratchpadSpawnAction conf)
- --, ((myAltModMask, 0xffeb), scratchpadSpawnAction conf)
- , ((myAltModMask, 0xe0), scratchpadSpawnAction conf)
- , ((modMask, 0xe0), scratchpadSpawnAction conf)
- -- window navigation
- --, ((modMask, xK_Right), sendMessage $ Go R)
- --, ((modMask, xK_Left ), sendMessage $ Go L)
- --, ((modMask, xK_Up ), sendMessage $ Go U)
- --, ((modMask, xK_Down ), sendMessage $ Go D)
- --, ((modMask .|. controlMask, xK_Right), sendMessage $ Swap R)
- --, ((modMask .|. controlMask, xK_Left ), sendMessage $ Swap L)
- --, ((modMask .|. controlMask, xK_Up ), sendMessage $ Swap U)
- --, ((modMask .|. controlMask, xK_Down ), sendMessage $ Swap D)
- -- launch xlock
- , ((modMask .|. controlMask, xK_l ), spawn myLock)
- , ((myAltModMask .|. controlMask, xK_l ), spawn myLock)
- -- launch gmrun
- , ((modMask .|. shiftMask, xK_x ), spawn "gmrun")
- -- imgur-screenshot
- , ((modMask .|. shiftMask, xK_c ), spawn myImgurScreenshot)
- -- find-cursor
- , ((modMask .|. shiftMask, xK_p ), spawn myPointer)
- -- close focused window
- , ((modMask .|. shiftMask, xK_c ), kill)
- --, ((myAltModMask .|. shiftMask, xK_c ), kill)
- -- Rotate through the available layout algorithms
- , ((modMask, xK_space ), sendMessage NextLayout)
- --, ((myAltModMask, xK_space ), sendMessage NextLayout)
- -- Reset the layouts on the current workspace to default
- , ((modMask .|. shiftMask, xK_space ), setLayout $ XMonad.layoutHook conf)
- --, ((myAltModMask .|. shiftMask, xK_space ), setLayout $ XMonad.layoutHook conf)
- -- Resize viewed windows to the correct size
- , ((modMask, xK_n ), refresh)
- --, ((myAltModMask, xK_n ), refresh)
- -- Move focus to the next window
- , ((modMask, xK_Tab ), windows W.focusDown)
- --, ((myAltModMask, xK_Tab ), windows W.focusDown)
- -- Move focus to the next window
- , ((modMask, xK_j ), windows W.focusDown)
- --, ((myAltModMask, xK_j ), windows W.focusDown)
- -- Move focus to the previous window
- , ((modMask, xK_k ), windows W.focusUp )
- --, ((myAltModMask, xK_k ), windows W.focusUp )
- -- Move focus to the master window
- , ((modMask, xK_m ), windows W.focusMaster )
- --, ((myAltModMask, xK_m ), windows W.focusMaster )
- -- Swap the focused window and the master window
- , ((modMask, xK_Return), windows W.swapMaster)
- -- ((myAltModMask, xK_Return), windows W.swapMaster)
- -- Swap the focused window with the next window
- , ((modMask .|. shiftMask, xK_j ), windows W.swapDown )
- --, ((myAltModMask .|. shiftMask, xK_j ), windows W.swapDown )
- -- Swap the focused window with the previous window
- , ((modMask .|. shiftMask, xK_k ), windows W.swapUp )
- --, ((myAltModMask .|. shiftMask, xK_k ), windows W.swapUp )
- -- Shrink the master area
- , ((modMask, xK_h ), sendMessage Shrink)
- --, ((myAltModMask, xK_h ), sendMessage Shrink)
- -- Expand the master area
- , ((modMask, xK_l ), sendMessage Expand)
- --, ((myAltModMask, xK_l ), sendMessage Expand)
- -- Push window back into tiling
- , ((modMask, xK_t ), withFocused $ windows . W.sink)
- --, ((myAltModMask, xK_t ), withFocused $ windows . W.sink)
- -- Increment the number of windows in the master area
- , ((modMask , xK_comma ), sendMessage (IncMasterN 1))
- --, ((myAltModMask, xK_comma ), sendMessage (IncMasterN 1))
- -- Deincrement the number of windows in the master area
- , ((modMask , xK_period), sendMessage (IncMasterN (-1)))
- --, ((myAltModMask, xK_period), sendMessage (IncMasterN (-1)))
- -- toggle the status bar gap
- -- TODO, update this binding with avoidStruts , ((modMask , xK_b ),
- -- Quit xmonad
- , ((modMask .|. shiftMask, xK_q ), io (exitWith ExitSuccess))
- -- Restart xmonad
- , ((modMask , xK_q ), restart "xmonad" True)
- ]
- ++
- -- function keys
- [(( 0, xF86XK_AudioLowerVolume ), spawn "amixer set Master 2-")
- , ((0, xF86XK_AudioRaiseVolume ), spawn "amixer set Master 2+")
- , ((0, xF86XK_AudioMute ), spawn "amixer set Master toggle")
- --, ((0, xF86XK_AudioMicMute ), spawn "amixer set ")
- , ((0, xF86XK_MonBrightnessUp ), spawn "xbacklight -inc 5")
- , ((0, xF86XK_MonBrightnessDown), spawn "xbacklight -dec 5")
- ]
- ++
- --
- -- mod-[1..9], Switch to workspace N
- -- mod-shift-[1..9], Move client to workspace N
- --
- [((m .|. modMask, k), windows $ f i)
- | (i, k) <- zip (XMonad.workspaces conf) [xK_1 .. xK_9]
- , (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask)]]
- ++
- [((m .|. myAltModMask, k), windows $ f i)
- | (i, k) <- zip (XMonad.workspaces conf) [xK_1 .. xK_9]
- , (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask)]]
- ++
- -- bépo conf
- [((m .|. myAltModMask, k), windows $ f i)
- -- | (i, k) <- zip (XMonad.workspaces conf) [0x26,0xe9,0x22,0x27,0x28,0x2d,0xe8,0x5f,0xe7,0xe0,xK_a,xK_z,xK_e,xK_r] --azerty
- | (i, k) <- zip (XMonad.workspaces conf) [0x22,0xab,0xbb,0x28,0x29,0x40,0x2b,0x2d,0x2f,0x2a,xK_a,xK_z,xK_e,xK_r] --bepo
- , (f, m) <- [(W.greedyView, 0), (W.shift, shiftMask)]]
- ++
- --
- -- 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
- --
- [((m .|. modMask, key), screenWorkspace sc >>= flip whenJust (windows . f))
- | (key, sc) <- zip [xK_w, xK_e, xK_r] [0..]
- , (f, m) <- [(W.view, 0), (W.shift, shiftMask)]]
- ++
- [((m .|. myAltModMask, key), screenWorkspace sc >>= flip whenJust (windows . f))
- | (key, sc) <- zip [xK_w, xK_e, xK_r] [0..]
- , (f, m) <- [(W.view, 0), (W.shift, shiftMask)]]
- ------------------------------------------------------------------------
- -- Mouse bindings: default actions bound to mouse events
- --
- myMouseBindings (XConfig {XMonad.modMask = modMask}) = M.fromList $
- -- mod-button1, Set the window to floating mode and move by dragging
- [ ((modMask, button1), (\w -> focus w >> mouseMoveWindow w))
- -- mod-button2, Raise the window to the top of the stack
- , ((modMask, button2), (\w -> focus w >> windows W.swapMaster))
- -- mod-button3, Set the window to floating mode and resize by dragging
- , ((modMask, button3), (\w -> focus w >> mouseResizeWindow w))
- -- 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 = smartBorders $ maximize (tiled ||| Mirror tiled ||| simpleTabbed ||| Full) -- ||| Grid
- -- fullscreen attempt
- --myLayout = spacingRaw True (Border 0 5 5 5) True (Border 5 5 5 5) True $ mkToggle (NBFULL ?? NOBORDERS ?? EOT) $ tiled ||| Mirror tiled ||| spiral (6/7) ||| ThreeColMid 1 (3/100) (1/2) ||| Full
- --myLayout = avoidStruts (tiled ||| Mirror tiled ||| Full) ||| Full
- where
- -- default tiling algorithm partitions the screen into two panes
- tiled = Tall nmaster delta ratio
- -- The default number of windows in the master pane
- nmaster = 1
- -- Default proportion of screen occupied by master pane
- ratio = 1/2
- -- Percent of screen to increment by when resizing panes
- delta = 3/100
- ------------------------------------------------------------------------
- -- 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
- [ className =? "MPlayer" --> doFloat
- , className =? "Gimp" --> doFloat
- , className =? "Gmrun" --> doFloat
- , className =? "stalonetray" --> doIgnore
- , resource =? "desktop_window" --> doIgnore
- , resource =? "kdesktop" --> doIgnore ]
- -- Whether focus follows the mouse pointer.
- myFocusFollowsMouse :: Bool
- myFocusFollowsMouse = True
- ------------------------------------------------------------------------
- -- Status bars and logging
- -- Perform an arbitrary action on each internal state change or X event.
- -- See the 'DynamicLog' extension for examples.
- --
- -- To emulate dwm's status bar
- --
- -- > logHook = dynamicLogDzen
- myLogHook dest = do
- dynamicLogWithPP $ xmobarPP
- { ppOutput = hPutStrLn dest
- , ppTitle = xmobarColor "green" "" . shorten 100 --50
- , ppSort = fmap (. scratchpadFilterOutWorkspace) $ ppSort xmobarPP
- , ppVisible = \x -> ""
- , ppHidden = \x -> ""
- , ppLayout = \x -> ""
- }
- ------------------------------------------------------------------------
- -- 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 ()
- -- old way to lie to Java about what window manager is used. Warning: break
- -- recent version of gtk3, use _JAVA_AWT_WM_NONREPARENTING=1 variable instead
- -- myStartupHook = setWMName "LG3D"
- myStartupHook = do
- spawn "xsetroot -cursor_name right_ptr"
- spawn "feh --bg-tile /home/jcbach/.wallpapers/wallpaper.jpg"
- -- spawn "sh ~/.TouchScreen.sh stop"
- spawn "[[ -f ~/.Xresources ]] && xrdb -merge ~/.Xresources"
- spawn "xmodmap ~/.Xmodmap"
- spawn "$HOME/keyboards.sh"
- spawn "xhost +local:root"
- -- location = IMTA (Plouzane)
- spawn "ps cax | grep redshift &>1 ; if ! [ $? -eq 0 ]; then redshift -l 48.35865:-4.57096 -t 6500:3700; fi"
- spawn "ps cax | grep stalonetray ; if ! [ $? -eq 0 ]; then stalonetray; fi"
- spawn "xautolock -time 3 -locker 'i3lock -d -i ~/images/gentoo/gentoo-larry-bg-1280x800.png -t'"
- -- spawn "ps cax | grep ssh-agent &>1 ; if ! [ $? -eq 0 ]; then ssh-agent;fi"
- spawn "nm-applet"
- ------------------------------------------------------------------------
- -- Now run xmonad with all the defaults we set up.
- -- Run xmonad with the settings you specify. No need to modify this.
- --
- main = do
- xmproc <- spawnPipe "xmobar $XDG_CONFIG_HOME/xmobar/xmobarrc"
- xmonad $ fullscreenSupport $ def {
- -- simple stuff
- terminal = myTerminal,
- focusFollowsMouse = myFocusFollowsMouse,
- borderWidth = myBorderWidth,
- modMask = myModMask,
- --numlockMask = myNumlockMask,
- workspaces = myWorkspaces,
- normalBorderColor = myNormalBorderColor,
- focusedBorderColor = myFocusedBorderColor,
- -- key bindings
- keys = myKeys,
- mouseBindings = myMouseBindings,
- -- hooks, layouts
- manageHook = myManageHook,
- layoutHook = avoidStruts myLayout,
- handleEventHook = mconcat [ handleEventHook def ],
- logHook = myLogHook xmproc,
- --logHook = dynamicLogWithPP $ xmobarPP {
- startupHook = myStartupHook
- }
- -- 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.
|