aboutsummaryrefslogtreecommitdiff
path: root/configs
diff options
context:
space:
mode:
authortoni <matzeton@googlemail.com>2013-05-02 01:04:15 +0200
committertoni <matzeton@googlemail.com>2013-05-02 01:04:15 +0200
commitbaa0998095617705612d734ab1a9f8be5b45e126 (patch)
tree77755cda6d0e74cd4f28c01376c78d195ed2006b /configs
parente33b5930923a439f4c73b6dd64253578c4131420 (diff)
xmonad related configs
copy_so.sh: copy shared libs needed by a binary to a specified location
Diffstat (limited to 'configs')
-rw-r--r--configs/xinitrc18
-rw-r--r--configs/xmobarrc16
-rw-r--r--configs/xmonad.hs359
3 files changed, 393 insertions, 0 deletions
diff --git a/configs/xinitrc b/configs/xinitrc
new file mode 100644
index 0000000..d36476a
--- /dev/null
+++ b/configs/xinitrc
@@ -0,0 +1,18 @@
+#!/bin/sh
+
+unclutter -idle 1 -root & # hide cursor when unused
+
+# Turn CapsLock into Control
+xmodmap -e "clear lock" -e "keycode 66 = Control_R" -e "add Control = Control_R"
+
+# minimal GTK+ traybar
+trayer --edge bottom --align left --SetDockType true --SetPartialStrut false --expand true --width 10 --height 25 &
+
+# starting gpg daemon
+gpg-agent --daemon --use-standard-socket
+
+konsole &
+kmail &
+firefox &
+
+exec ck-launch-session dbus-launch xmonad
diff --git a/configs/xmobarrc b/configs/xmobarrc
new file mode 100644
index 0000000..91b9e97
--- /dev/null
+++ b/configs/xmobarrc
@@ -0,0 +1,16 @@
+Config { font = "-misc-fixed-*-*-*-*-18-*-*-*-*-*-*-*"
+ , bgColor = "black"
+ , fgColor = "grey"
+ , position = TopW L 85
+ , commands = [ Run Thermal "THRM" [] 10
+ , Run Network "eth0" ["-L","0","-H","32","--normal","green","--high","red"] 10
+ , Run Cpu ["-L","15","-H","50","--normal","green","--high","red"] 10
+ , Run Memory ["Mem: %"] 10
+ , Run Swap [] 10
+ , Run Date "%a %b %_d %Y %H:%M:%S" "date" 10
+ , Run StdinReader
+ ]
+ , sepChar = "%"
+ , alignSep = "}{"
+ , template = "%StdinReader% }{ %THRM% | %cpu% | %memory% * %swap% | %eth0% | %date%"
+ }
diff --git a/configs/xmonad.hs b/configs/xmonad.hs
new file mode 100644
index 0000000..76955f2
--- /dev/null
+++ b/configs/xmonad.hs
@@ -0,0 +1,359 @@
+-- xmonad config used by Vic Fryzel
+-- Author: Vic Fryzel
+-- http://github.com/vicfryzel/xmonad-config
+
+import System.IO
+import System.Exit
+import XMonad
+import XMonad.Hooks.DynamicLog
+import XMonad.Hooks.ManageDocks
+import XMonad.Hooks.ManageHelpers
+import XMonad.Hooks.SetWMName
+import XMonad.Layout.NoBorders
+import XMonad.Layout.Spiral
+import XMonad.Layout.Tabbed
+import XMonad.Util.Run(spawnPipe)
+import XMonad.Util.EZConfig(additionalKeys)
+import qualified XMonad.StackSet as W
+import qualified Data.Map as M
+
+
+------------------------------------------------------------------------
+-- Terminal
+-- The preferred terminal program, which is used in a binding below and by
+-- certain contrib modules.
+--
+myTerminal = "/usr/bin/konsole"
+
+
+------------------------------------------------------------------------
+-- Workspaces
+-- The default number of workspaces (virtual screens) and their names.
+--
+myWorkspaces = ["1:term","2:web","3:code","4:vm","5:media"] ++ map show [6..9]
+
+
+------------------------------------------------------------------------
+-- 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 =? "Google-chrome" --> doShift "2:web"
+ , resource =? "desktop_window" --> doIgnore
+ , className =? "Galculator" --> doFloat
+ , className =? "Steam" --> doFloat
+ , className =? "Gimp" --> doFloat
+ , resource =? "gpicview" --> doFloat
+ , className =? "MPlayer" --> doFloat
+ , className =? "VirtualBox" --> doShift "4:vm"
+ , className =? "Xchat" --> doShift "5:media"
+ , isFullscreen --> (doF W.focusDown <+> doFullFloat)]
+
+
+------------------------------------------------------------------------
+-- Layouts
+-- You can specify and transform your layouts by modifying these values.
+-- If you change layout bindings be sure to use 'mod-shift-space' after
+-- restarting (with 'mod-q') to reset your layout state to the new
+-- defaults, as xmonad preserves your old layout settings by default.
+--
+-- The available layouts. Note that each layout is separated by |||,
+-- which denotes layout choice.
+--
+myLayout = avoidStruts (
+ Tall 1 (3/100) (1/2) |||
+ Mirror (Tall 1 (3/100) (1/2)) |||
+ tabbed shrinkText tabConfig |||
+ Full |||
+ spiral (6/7))
+
+
+------------------------------------------------------------------------
+-- Colors and borders
+-- Currently based on the ir_black theme.
+--
+myNormalBorderColor = "#7c7c7c"
+myFocusedBorderColor = "#ffb6b0"
+
+-- Colors for text and backgrounds of each tab when in "Tabbed" layout.
+tabConfig = defaultTheme {
+ activeBorderColor = "#7C7C7C",
+ activeTextColor = "#CEFFAC",
+ activeColor = "#000000",
+ inactiveBorderColor = "#7C7C7C",
+ inactiveTextColor = "#EEEEEE",
+ inactiveColor = "#000000"
+}
+
+-- Color of current window title in xmobar.
+xmobarTitleColor = "#FFB6B0"
+
+-- Color of current workspace in xmobar.
+xmobarCurrentWorkspaceColor = "#CEFFAC"
+
+-- Width of the window border in pixels.
+myBorderWidth = 1
+
+
+------------------------------------------------------------------------
+-- Key bindings
+--
+-- 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
+
+myKeys conf@(XConfig {XMonad.modMask = modMask}) = M.fromList $
+ ----------------------------------------------------------------------
+ -- Custom key bindings
+ --
+
+ -- Start a terminal. Terminal to start is specified by myTerminal variable.
+ [ ((modMask .|. shiftMask, xK_Return),
+ spawn $ XMonad.terminal conf)
+
+ -- Lock the screen using xscreensaver.
+ , ((modMask .|. controlMask, xK_l),
+ spawn "xscreensaver-command -lock")
+
+ -- Launch dmenu via yeganesh.
+ -- Use this to launch programs without a key binding.
+ , ((modMask, xK_p),
+ spawn "exe=`dmenu_path_c | yeganesh` && eval \"exec $exe\"")
+
+ -- Take a screenshot in select mode.
+ -- After pressing this key binding, click a window, or draw a rectangle with
+ -- the mouse.
+ , ((modMask .|. shiftMask, xK_p),
+ spawn "select-screenshot")
+
+ -- Take full screenshot in multi-head mode.
+ -- That is, take a screenshot of everything you see.
+ , ((modMask .|. controlMask .|. shiftMask, xK_p),
+ spawn "screenshot")
+
+ -- Mute volume.
+ , ((modMask .|. controlMask, xK_m),
+ spawn "amixer -q set Master toggle")
+
+ -- Decrease volume.
+ , ((modMask .|. controlMask, xK_j),
+ spawn "amixer -q set Master 10%-")
+
+ -- Increase volume.
+ , ((modMask .|. controlMask, xK_k),
+ spawn "amixer -q set Master 10%+")
+
+ -- Audio previous.
+ , ((0, 0x1008FF16),
+ spawn "")
+
+ -- Play/pause.
+ , ((0, 0x1008FF14),
+ spawn "")
+
+ -- Audio next.
+ , ((0, 0x1008FF17),
+ spawn "")
+
+ -- Eject CD tray.
+ , ((0, 0x1008FF2C),
+ spawn "eject -T")
+
+ --------------------------------------------------------------------
+ -- "Standard" xmonad key bindings
+ --
+
+ -- Close focused window.
+ , ((modMask .|. shiftMask, xK_c),
+ kill)
+
+ -- Cycle through the available layout algorithms.
+ , ((modMask, xK_space),
+ sendMessage NextLayout)
+
+ -- Reset the layouts on the current workspace to default.
+ , ((modMask .|. shiftMask, xK_space),
+ setLayout $ XMonad.layoutHook conf)
+
+ -- Resize viewed windows to the correct size.
+ , ((modMask, xK_n),
+ refresh)
+
+ -- Move focus to the next window.
+ , ((modMask, xK_Tab),
+ windows W.focusDown)
+
+ -- Move focus to the next window.
+ , ((modMask, xK_j),
+ windows W.focusDown)
+
+ -- Move focus to the previous window.
+ , ((modMask, xK_k),
+ windows W.focusUp )
+
+ -- Move focus to the master window.
+ , ((modMask, xK_m),
+ windows W.focusMaster )
+
+ -- Swap the focused window and the master window.
+ , ((modMask, xK_Return),
+ windows W.swapMaster)
+
+ -- Swap the focused window with the next window.
+ , ((modMask .|. shiftMask, xK_j),
+ windows W.swapDown )
+
+ -- Swap the focused window with the previous window.
+ , ((modMask .|. shiftMask, xK_k),
+ windows W.swapUp )
+
+ -- Shrink the master area.
+ , ((modMask, xK_h),
+ sendMessage Shrink)
+
+ -- Expand the master area.
+ , ((modMask, xK_l),
+ sendMessage Expand)
+
+ -- Push window back into tiling.
+ , ((modMask, xK_t),
+ withFocused $ windows . W.sink)
+
+ -- Increment the number of windows in the master area.
+ , ((modMask, xK_comma),
+ sendMessage (IncMasterN 1))
+
+ -- Decrement the number of windows in the master area.
+ , ((modMask, 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)
+ ]
+ ++
+
+ -- 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)]]
+ ++
+
+ -- 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)]]
+
+
+------------------------------------------------------------------------
+-- Mouse bindings
+--
+-- Focus rules
+-- True if your focus should follow your mouse cursor.
+myFocusFollowsMouse :: Bool
+myFocusFollowsMouse = False
+
+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)
+ ]
+
+
+------------------------------------------------------------------------
+-- 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
+--
+
+
+------------------------------------------------------------------------
+-- 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 ()
+
+
+------------------------------------------------------------------------
+-- Run xmonad with all the defaults we set up.
+--
+main = do
+ xmproc <- spawnPipe "/usr/bin/xmobar ~/.xmobarrc"
+ xmonad $ defaults {
+ logHook = dynamicLogWithPP $ xmobarPP {
+ ppOutput = hPutStrLn xmproc
+ , ppTitle = xmobarColor xmobarTitleColor "" . shorten 100
+ , ppCurrent = xmobarColor xmobarCurrentWorkspaceColor ""
+ , ppSep = " "}
+ , manageHook = manageDocks <+> myManageHook
+ , startupHook = setWMName "LG3D"
+ }
+
+
+------------------------------------------------------------------------
+-- Combine it all together
+-- A structure containing your configuration settings, overriding
+-- fields in the default config. Any you don't override, will
+-- use the defaults defined in xmonad/XMonad/Config.hs
+--
+-- No need to modify this.
+--
+defaults = defaultConfig {
+ -- simple stuff
+ terminal = myTerminal,
+ focusFollowsMouse = myFocusFollowsMouse,
+ borderWidth = myBorderWidth,
+ modMask = myModMask,
+ workspaces = myWorkspaces,
+ normalBorderColor = myNormalBorderColor,
+ focusedBorderColor = myFocusedBorderColor,
+
+ -- key bindings
+ keys = myKeys,
+ mouseBindings = myMouseBindings,
+
+ -- hooks, layouts
+ layoutHook = smartBorders $ myLayout,
+ manageHook = myManageHook,
+ startupHook = myStartupHook
+}