Parcourir la source

add Xmonad configuration

Jean-Christophe Bach il y a 1 an
Parent
commit
1d8cfab62e
4 fichiers modifiés avec 1850 ajouts et 0 suppressions
  1. 464 0
      .xmonad/xmonad-azerty.hs
  2. 468 0
      .xmonad/xmonad-bepo.hs
  3. 459 0
      .xmonad/xmonad-qwerty.hs
  4. 459 0
      .xmonad/xmonad.hs

+ 464 - 0
.xmonad/xmonad-azerty.hs

@@ -0,0 +1,464 @@
+--
+-- 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"
+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 $ myTerminology)
+    , ((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)
+    
+    -- 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)
+
+    -- 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,
+        --layoutHook         = smartBorders . 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.
+

+ 468 - 0
.xmonad/xmonad-bepo.hs

@@ -0,0 +1,468 @@
+--
+-- 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.
+

+ 459 - 0
.xmonad/xmonad-qwerty.hs

@@ -0,0 +1,459 @@
+--
+-- 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"
+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 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)]]
+    ++
+
+    --
+    -- 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,
+        --layoutHook         = smartBorders . 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.
+

+ 459 - 0
.xmonad/xmonad.hs

@@ -0,0 +1,459 @@
+--
+-- 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"
+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 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)]]
+    ++
+
+    --
+    -- 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,
+        --layoutHook         = smartBorders . 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.
+