From 70f9d414d4205e45f5483670484739b9a02f7d6f Mon Sep 17 00:00:00 2001 From: Curtis McEnroe Date: Wed, 28 Mar 2012 20:31:55 -0400 Subject: Add Awesome configuration --- .config/awesome/autostart.sh | 4 + .config/awesome/rc.lua | 327 +++++++++++++++++++++++++++++++++++++++++++ README.md | 3 +- 3 files changed, 333 insertions(+), 1 deletion(-) create mode 100755 .config/awesome/autostart.sh create mode 100644 .config/awesome/rc.lua diff --git a/.config/awesome/autostart.sh b/.config/awesome/autostart.sh new file mode 100755 index 00000000..8b28cea5 --- /dev/null +++ b/.config/awesome/autostart.sh @@ -0,0 +1,4 @@ +xsetroot -cursor_name left_ptr & +#xcompmgr -c -f -D 3 -C & +/home/curtis/code/c/keycounter/keycounter -f -d -p /home/curtis/.keycounter.pid /home/curtis/.keycount & +gitdocs start & diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua new file mode 100644 index 00000000..8ecc54d2 --- /dev/null +++ b/.config/awesome/rc.lua @@ -0,0 +1,327 @@ +require("awful") +require("awful.autofocus") +require("awful.rules") +require("beautiful") +require("naughty") +require("vicious") + +home = os.getenv("HOME") +awesome_home = home .. "/.config/awesome" +terminal = "terminal" +editor = "gvim" + +modkey = "Mod4" + +-- Theming +beautiful.init(awesome_home .. "/themes/current/theme.lua") +naughty.config.default_preset.timeout = 3 + +-- Layouts and tags +layouts = { + awful.layout.suit.tile, + awful.layout.suit.tile.left, + awful.layout.suit.tile.bottom, + awful.layout.suit.tile.top, + awful.layout.suit.max, + awful.layout.suit.floating +} + +tags = { + names = { 1, 2, 3, 4, 5, 6, 7, 8, 9 }, + layouts = { + layouts[5], + layouts[3], + layouts[1], + layouts[1], + layouts[1], + layouts[1], + layouts[1], + layouts[1], + layouts[6] + } +} + +for s = 1, screen.count() do + tags[s] = awful.tag(tags.names, s, tags.layouts) +end + +-- disable startup-notification globally +local oldspawn = awful.util.spawn +awful.util.spawn = function (s) + oldspawn(s, false) +end + +-- {{{ Error handling +-- Check if awesome encountered an error during startup and fell back to +-- another config (This code will only ever execute for the fallback config) +if awesome.startup_errors then + naughty.notify({ preset = naughty.config.presets.critical, + title = "Oops, there were errors during startup!", + text = awesome.startup_errors }) +end + +-- Handle runtime errors after startup +do + local in_error = false + awesome.add_signal("debug::error", function (err) + -- Make sure we don't go into an endless error loop + if in_error then return end + in_error = true + + naughty.notify({ preset = naughty.config.presets.critical, + title = "Oops, an error happened!", + text = err }) + in_error = false + end) +end +-- }}} + +-- Wibox +function icon(i) + return image(awesome_home .. "/icons/" .. i .. ".png") +end + +taglist = { + buttons = awful.util.table.join( + awful.button({ }, 1, awful.tag.viewonly), + awful.button({ modkey }, 1, awful.client.movetotag), + awful.button({ }, 3, awful.tag.viewtoggle), + awful.button({ modkey }, 3, awful.client.toggletag), + awful.button({ }, 4, awful.tag.viewnext), + awful.button({ }, 5, awful.tag.viewprev)), + create = function (s) + return awful.widget.taglist(s, awful.widget.taglist.label.all, taglist.buttons) + end +} + +wibox = { + promptbox = awful.widget.prompt({ layout = awful.widget.layout.horizontal.leftright }), + clock = awful.widget.textclock({ align = "right" }, "%a %b %d, %I:%M %p"), + systray = widget({ type = "systray" }), + mpd = widget({ type = "textbox" }), + + clockicon = widget({ type = "imagebox" }), + mpdicon = widget({ type = "imagebox" }), + + icons = { + play = icon("play"), + pause = icon("pause"), + stop = icon("stop"), + clock = icon("clock"), + }, +} + +wibox.clockicon.image = wibox.icons.clock + +vicious.register(wibox.mpd, vicious.widgets.mpd, function (widget, args) + if args["{state}"] == "Stop" then + wibox.mpdicon.image = wibox.icons.stop + return "" + end + if args["{state}"] == "Pause" then + wibox.mpdicon.image = wibox.icons.pause + else + wibox.mpdicon.image = wibox.icons.play + end + return args["{Artist}"] .. " - " .. args["{Title}"] +end, 5) + +for s = 1, screen.count() do + wibox[s] = awful.wibox({ position = "top", screen = s}) + wibox[s].widgets = { + { + taglist.create(s), + wibox.promptbox, + layout = awful.widget.layout.horizontal.leftright + }, + s == 1 and wibox.systray or nil, + wibox.clock, + wibox.clockicon, + wibox.mpd, + wibox.mpdicon, + layout = awful.widget.layout.horizontal.rightleft + } +end + +-- Bindings +root.buttons(awful.util.table.join( + awful.button({ }, 4, awful.tag.viewnext), + awful.button({ }, 5, awful.tag.viewprev))) + +globalkeys = awful.util.table.join( + awful.key({ modkey }, "Left", awful.tag.viewprev), + awful.key({ modkey }, "Right", awful.tag.viewnext), + + -- Client focus + awful.key({ modkey }, "j", function () + awful.client.focus.byidx(1) + if client.focus then client.focus:raise() end + end), + awful.key({ modkey }, "k", function () + awful.client.focus.byidx(-1) + if client.focus then client.focus:raise() end + end), + + -- Client movement + awful.key({ modkey, "Shift" }, "j", function () awful.client.swap.byidx(1) end), + awful.key({ modkey, "Shift" }, "k", function () awful.client.swap.byidx(-1) end), + awful.key({ modkey, "Control" }, "j", function () awful.screen.focus_relative(1) end), + awful.key({ modkey, "Control" }, "k", function () awful.screen.focus_relative(-1) end), + awful.key({ modkey }, "u", awful.client.urgent.jumpto), + + -- Tag modification + awful.key({ modkey }, "l", function () awful.tag.incmwfact(0.05) end), + awful.key({ modkey }, "h", function () awful.tag.incmwfact(-0.05) end), + awful.key({ modkey, "Shift" }, "h", function () awful.tag.incnmaster(1) end), + awful.key({ modkey, "Shift" }, "l", function () awful.tag.incnmaster(-1) end), + awful.key({ modkey, "Control" }, "h", function () awful.tag.incncol(1) end), + awful.key({ modkey, "Control" }, "l", function () awful.tag.incncol(-1) end), + awful.key({ modkey }, "space", function () awful.layout.inc(layouts, 1) end), + awful.key({ modkey, "Shift" }, "space", function () awful.layout.inc(layouts, -1) end), + + -- Prompts + awful.key({ modkey }, "r", function () wibox.promptbox:run() end), + awful.key({ modkey }, "x", function () + awful.prompt.run({ prompt = "Lua: " }, + wibox.promptbox.widget, + awful.util.eval, nil, + awful.util.getdir("cache") .. "/history_eval") + end), + + awful.key({ }, "Print", function () awful.util.spawn(home .. "/bin/scrot-upload") end), + awful.key({ modkey }, "Print", function () awful.util.spawn(home .. "/bin/scrot-upload -b -s") end), + awful.key({ }, "XF86AudioPlay", function () awful.util.spawn("mpc toggle") end), + awful.key({ }, "XF86AudioStop", function () awful.util.spawn("mpc stop") end), + awful.key({ }, "XF86AudioNext", function () awful.util.spawn("mpc next") end), + awful.key({ }, "XF86AudioPrev", function () awful.util.spawn("mpc prev") end), + + awful.key({ modkey }, "Return", function () awful.util.spawn(terminal) end), + awful.key({ modkey, "Control" }, "r", awesome.restart), + awful.key({ modkey, "Shift" }, "q", awesome.quit)) + +clientkeys = awful.util.table.join( + awful.key({ modkey, "Shift" }, "c", function (c) c:kill() end), + + awful.key({ modkey }, "f", function (c) c.fullscreen = not c.fullscreen end), + awful.key({ modkey, "Control" }, "space", awful.client.floating.toggle), + awful.key({ modkey }, "t", function (c) c.ontop = not c.ontop end), + awful.key({ modkey, "Shift" }, "r", function (c) c:redraw() end), + + awful.key({ modkey, "Control" }, "Return", function (c) c:swap(awful.client.getmaster()) end), + awful.key({ modkey }, "o", awful.client.movetoscreen), + + -- This is where I got too lazy to rewrite the default + awful.key({ modkey, }, "n", + function (c) + -- The client currently has the input focus, so it cannot be + -- minimized, since minimized clients can't have the focus. + c.minimized = true + end), + awful.key({ modkey, }, "m", + function (c) + c.maximized_horizontal = not c.maximized_horizontal + c.maximized_vertical = not c.maximized_vertical + end) +) + +-- Compute the maximum number of digit we need, limited to 9 +keynumber = 0 +for s = 1, screen.count() do + keynumber = math.min(9, math.max(#tags[s], keynumber)); +end + +-- Bind all key numbers to tags. +-- Be careful: we use keycodes to make it works on any keyboard layout. +-- This should map on the top row of your keyboard, usually 1 to 9. +for i = 1, keynumber do + globalkeys = awful.util.table.join(globalkeys, + awful.key({ modkey }, "#" .. i + 9, + function () + local screen = mouse.screen + if tags[screen][i] then + awful.tag.viewonly(tags[screen][i]) + end + end), + awful.key({ modkey, "Control" }, "#" .. i + 9, + function () + local screen = mouse.screen + if tags[screen][i] then + awful.tag.viewtoggle(tags[screen][i]) + end + end), + awful.key({ modkey, "Shift" }, "#" .. i + 9, + function () + if client.focus and tags[client.focus.screen][i] then + awful.client.movetotag(tags[client.focus.screen][i]) + end + end), + awful.key({ modkey, "Control", "Shift" }, "#" .. i + 9, + function () + if client.focus and tags[client.focus.screen][i] then + awful.client.toggletag(tags[client.focus.screen][i]) + end + end)) +end + +clientbuttons = awful.util.table.join( + awful.button({ }, 1, function (c) client.focus = c; c:raise() end), + awful.button({ modkey }, 1, awful.mouse.client.move), + awful.button({ modkey }, 3, awful.mouse.client.resize)) + +-- Set keys +root.keys(globalkeys) +-- }}} + +-- {{{ Rules +awful.rules.rules = { + -- All clients will match this rule. + { rule = { }, + properties = { border_width = beautiful.border_width, + border_color = beautiful.border_normal, + focus = true, + keys = clientkeys, + buttons = clientbuttons } }, + { rule = { class = "MPlayer" }, + properties = { floating = true } }, + { rule = { class = "pinentry" }, + properties = { floating = true } }, + { rule = { class = "gimp" }, + properties = { floating = true } }, + -- Set Firefox to always map on tags number 2 of screen 1. + -- { rule = { class = "Firefox" }, + -- properties = { tag = tags[1][2] } }, +} +-- }}} + +-- {{{ Signals +-- Signal function to execute when a new client appears. +client.add_signal("manage", function (c, startup) + -- Add a titlebar + -- awful.titlebar.add(c, { modkey = modkey }) + + -- Enable sloppy focus + c:add_signal("mouse::enter", function(c) + if awful.layout.get(c.screen) ~= awful.layout.suit.magnifier + and awful.client.focus.filter(c) then + client.focus = c + end + end) + + if not startup then + -- Set the windows at the slave, + -- i.e. put it at the end of others instead of setting it master. + -- awful.client.setslave(c) + + -- Put windows in a smart way, only if they does not set an initial position. + if not c.size_hints.user_position and not c.size_hints.program_position then + awful.placement.no_overlap(c) + awful.placement.no_offscreen(c) + end + end +end) + +client.add_signal("focus", function(c) c.border_color = beautiful.border_focus end) +client.add_signal("unfocus", function(c) c.border_color = beautiful.border_normal end) +-- }}} + +awful.util.spawn(awesome_home .. "/autostart.sh") diff --git a/README.md b/README.md index 9e2085e1..70893123 100644 --- a/README.md +++ b/README.md @@ -2,6 +2,7 @@ My horrible configurations for: + * Awesome * IRB/RIPL - * ZSH * Xinit + * ZSH -- cgit 1.4.1