diff options
Diffstat (limited to '.config/awesome/rc.lua')
-rw-r--r-- | .config/awesome/rc.lua | 538 |
1 files changed, 298 insertions, 240 deletions
diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua index 745721d..20af5da 100644 --- a/.config/awesome/rc.lua +++ b/.config/awesome/rc.lua @@ -1,6 +1,8 @@ -- Standard awesome library local gears = require("gears") local awful = require("awful") +awful.rules = require("awful.rules") +require("awful.autofocus") -- Widget and layout library local wibox = require("wibox") -- Theme handling library @@ -10,30 +12,8 @@ local naughty = require("naughty") local menubar = require("menubar") local lfs = require("lfs") -awful.rules = require("awful.rules") -require("awful.autofocus") - local maildir_base = os.getenv("HOME") .. "/documents/mail/" -function ror(program, cls) - local rorfunc = function () - local matcher = function (c) - return awful.rules.match(c, { class = cls }) - end - - awful.client.run_or_raise(program, matcher) - end - - return rorfunc -end - -function ror_combo(mod, key, program, class) - return awful.util.table.join( - awful.key(mod, key, ror(program, class)), - awful.key(awful.util.table.join(mod, { "Shift" }), key, - function () awful.util.spawn(program) end)) -end - function new_mail(maildir) local count = 0 @@ -53,10 +33,9 @@ function new_mail(maildir) return count 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) +-- {{{ 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!", @@ -77,22 +56,22 @@ do in_error = false end) end - ------ Variable definitions --- Themes define colours, icons, and wallpapers +-- }}} + +-- {{{ Variable definitions +-- Themes define colours, icons, font and wallpapers. beautiful.init("/usr/share/awesome/themes/default/theme.lua") -- This is used later as the default terminal and editor to run. terminal = "urxvt" -editor = os.getenv("EDITOR") or "nano" -editor_cmd = terminal .. " -e " .. editor - ------ Default modkey. --- Usually, Mod4 is the key with a logo between Control and Alt. If --- you do not like this or do not have such a key, I suggest you to --- remap Mod4 to another key using xmodmap or other tools. However, --- you can use another modifier like Mod1, but it may interact with --- others. +editor = "emacsclient -c" +editor_cmd = editor + +-- Default modkey. +-- Usually, Mod4 is the key with a logo between Control and Alt. +-- If you do not like this or do not have such a key, +-- I suggest you to remap Mod4 to another key using xmodmap or other tools. +-- However, you can use another modifier like Mod1, but it may interact with others. modkey = "Mod4" -- Table of layouts to cover with awful.layout.inc, order matters. @@ -109,25 +88,28 @@ local layouts = awful.layout.suit.max, awful.layout.suit.max.fullscreen, awful.layout.suit.magnifier, - awful.layout.suit.floating + awful.layout.suit.floating, } - ------ Wallpaper +-- }}} + +-- {{{ Wallpaper if beautiful.wallpaper then for s = 1, screen.count() do gears.wallpaper.maximized(beautiful.wallpaper, s, true) end end - ------ Tags +-- }}} + +-- {{{ Tags -- Define a tag table which hold all screen tags. tags = {} for s = 1, screen.count() do -- Each screen has its own tag table. tags[s] = awful.tag({ 1, 2, 3, 4, 5, 6, 7, 8, 9 }, s, layouts[1]) end - ------ Menu +-- }}} + +-- {{{ Menu -- Create a laucher widget and a main menu myawesomemenu = { { "manual", terminal .. " -e man awesome" }, @@ -136,18 +118,19 @@ myawesomemenu = { { "quit", awesome.quit } } -mymainmenu = awful.menu( - { items = { { "awesome", myawesomemenu, beautiful.awesome_icon }, - { "open terminal", terminal } } }) +mymainmenu = awful.menu({ items = { { "awesome", myawesomemenu, beautiful.awesome_icon }, + { "open terminal", terminal } + } + }) mylauncher = awful.widget.launcher({ image = beautiful.awesome_icon, menu = mymainmenu }) -- Menubar configuration -menubar.utils.terminal = terminal -- Set the terminal for applications - -- that require it - ------ Wibox +menubar.utils.terminal = terminal -- Set the terminal for applications that require it +-- }}} + +-- {{{ Wibox -- Create a textclock widget mytextclock = awful.widget.textclock() @@ -156,58 +139,86 @@ mywibox = {} mypromptbox = {} mylayoutbox = {} mytaglist = {} +mytaglist.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, function(t) awful.tag.viewnext(awful.tag.getscreen(t)) end), + awful.button({ }, 5, function(t) awful.tag.viewprev(awful.tag.getscreen(t)) end) + ) mytasklist = {} +mytasklist.buttons = awful.util.table.join( + awful.button({ }, 1, function (c) + if c == client.focus then + c.minimized = true + else + -- Without this, the following + -- :isvisible() makes no sense + c.minimized = false + if not c:isvisible() then + awful.tag.viewonly(c:tags()[1]) + end + -- This will also un-minimize + -- the client, if needed + client.focus = c + c:raise() + end + end), + awful.button({ }, 3, function () + if instance then + instance:hide() + instance = nil + else + instance = awful.menu.clients({ + theme = { width = 250 } + }) + end + end), + awful.button({ }, 4, function () + awful.client.focus.byidx(1) + if client.focus then client.focus:raise() end + end), + awful.button({ }, 5, function () + awful.client.focus.byidx(-1) + if client.focus then client.focus:raise() end + end)) mymaillist = wibox.widget.textbox() mymaillist:set_text( - string.format(" ryu: %d gmail: %d aethon: %d 9f: %d", + string.format(" ryu: %d gmail: %d 9f: %d", new_mail('ryuslash.org/inbox'), new_mail('gmail/inbox'), - new_mail('aethon/inbox'), new_mail('ninthfloor/inbox'))) mymaillisttimer = timer({ timeout = 60 }) mymaillisttimer:connect_signal( "timeout", function () mymaillist:set_text( - string.format(" ryu: %d gmail: %d aethon: %d 9f: %d", + string.format(" ryu: %d gmail: %d 9f: %d", new_mail('ryuslash.org/inbox'), new_mail('gmail/inbox'), - new_mail('aethon/inbox'), new_mail('ninthfloor/inbox'))) end) mymaillisttimer:start() -mytodolist = wibox.widget.textbox() -mytodolist:set_text( - string.format(" ptodo: %d wtodo: %d", - awful.util.pread("todo-count t"), - awful.util.pread("todo-count w"))) -mytodolisttimer = timer({ timeout = 60 * 60 }) -mytodolisttimer:connect_signal( - "timeout", - function () - mytodolist:set_text( - string.format(" pers: %d work: %d", - awful.util.pread("todo-count t"), - awful.util.pread("todo-count w"))) - end) -mytodolisttimer:start() for s = 1, screen.count() do -- Create a promptbox for each screen mypromptbox[s] = awful.widget.prompt() - -- Create an imagebox widget which will contains an icon - -- indicating which layout we're using. We need one layoutbox per - -- screen. + -- Create an imagebox widget which will contains an icon indicating which layout we're using. + -- We need one layoutbox per screen. mylayoutbox[s] = awful.widget.layoutbox(s) + mylayoutbox[s]:buttons(awful.util.table.join( + awful.button({ }, 1, function () awful.layout.inc(layouts, 1) end), + awful.button({ }, 3, function () awful.layout.inc(layouts, -1) end), + awful.button({ }, 4, function () awful.layout.inc(layouts, 1) end), + awful.button({ }, 5, function () awful.layout.inc(layouts, -1) end))) -- Create a taglist widget - mytaglist[s] = awful.widget.taglist( - s, awful.widget.taglist.filter.all, mytaglist.buttons) + mytaglist[s] = awful.widget.taglist(s, awful.widget.taglist.filter.all, mytaglist.buttons) -- Create a tasklist widget - mytasklist[s] = awful.widget.tasklist( - s, awful.widget.tasklist.filter.currenttags, mytasklist.buttons) + mytasklist[s] = awful.widget.tasklist(s, awful.widget.tasklist.filter.currenttags, mytasklist.buttons) -- Create the wibox mywibox[s] = awful.wibox({ position = "top", screen = s }) @@ -221,7 +232,6 @@ for s = 1, screen.count() do -- Widgets that are aligned to the right local right_layout = wibox.layout.fixed.horizontal() if s == 1 then - right_layout:add(mytodolist) right_layout:add(mymaillist) right_layout:add(wibox.widget.systray()) end @@ -236,189 +246,237 @@ for s = 1, screen.count() do mywibox[s]:set_widget(layout) end - ------ Key bindings +-- }}} + +-- {{{ Mouse bindings +root.buttons(awful.util.table.join( + awful.button({ }, 3, function () mymainmenu:toggle() end), + awful.button({ }, 4, awful.tag.viewnext), + awful.button({ }, 5, awful.tag.viewprev) +)) +-- }}} + +function fraise (idx) + awful.client.focus.byidx(idx) + if client.focus then client.focus:raise() end +end + +function hpraise () + awful.client.focus.history.previous() + if client.focus then client.focus:raise() end +end + +-- {{{ Key bindings globalkeys = awful.util.table.join( - awful.key({ modkey, }, "Left", awful.tag.viewprev), - awful.key({ modkey, }, "Right", awful.tag.viewnext), - awful.key({ modkey, }, "Escape", awful.tag.history.restore), - - awful.key({ modkey, }, "n", - function () - awful.client.focus.byidx(1) - if client.focus then client.focus:raise() end - end), - awful.key({ modkey, }, "p", - function () - awful.client.focus.byidx(-1) - if client.focus then client.focus:raise() end - end), + awful.key({ modkey, }, "Left", awful.tag.viewprev), + awful.key({ modkey, }, "Right", awful.tag.viewnext), + awful.key({ modkey, }, "Escape", awful.tag.history.restore), + awful.key({ modkey, }, "n", function () fraise(1) end), + awful.key({ modkey, }, "p", function () fraise(-1) end), + -- awful.key({ modkey, }, "w", function () mymainmenu:show() end), -- Layout manipulation - awful.key({ modkey, "Shift" }, "n", - function () awful.client.swap.byidx(1) end), - awful.key({ modkey, "Shift" }, "p", - function () awful.client.swap.byidx(-1) end), - awful.key({ modkey, "Control" }, "n", - function () awful.screen.focus_relative(1) end), - awful.key({ modkey, "Control" }, "p", - function () awful.screen.focus_relative(-1) end), - awful.key({ modkey, }, "u", awful.client.urgent.jumpto), - awful.key({ modkey, }, "Tab", - function () - awful.client.focus.history.previous() - if client.focus then - client.focus:raise() - end - end), + awful.key({ modkey, "Shift" }, "n", function () awful.client.swap.byidx( 1) end), + awful.key({ modkey, "Shift" }, "p", function () awful.client.swap.byidx( -1) end), + awful.key({ modkey, }, ".", function () awful.screen.focus_relative( 1) end), + awful.key({ modkey, }, ",", function () awful.screen.focus_relative(-1) end), + awful.key({ modkey, }, "u", awful.client.urgent.jumpto), + awful.key({ modkey, }, "Tab", hpraise), -- Standard program - awful.key({ modkey, }, "Return", - function () awful.util.spawn(terminal) 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), - - 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), + awful.key({ modkey, "Shift" }, "q", awesome.quit), + + 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), awful.key({ modkey, "Control" }, "j", awful.client.restore), -- Prompt - awful.key({ modkey }, "r", - function () mypromptbox[mouse.screen]:run() end), + awful.key({ modkey }, "r", function () mypromptbox[mouse.screen]:run() end), awful.key({ modkey }, "x", function () - awful.prompt.run( - { prompt = "Run Lua code: " }, - mypromptbox[mouse.screen].widget, - awful.util.eval, nil, - awful.util.getdir("cache") .. "/history_eval") + awful.prompt.run({ prompt = "Run Lua code: " }, + mypromptbox[mouse.screen].widget, + awful.util.eval, nil, + awful.util.getdir("cache") .. "/history_eval") end), - - ror_combo({ modkey }, "e", 'emacsclient -ca emacs', 'Emacs'), - ror_combo({ modkey }, "c", 'urxvt', 'URxvt'), - ror_combo({ modkey }, "w", 'conkeror', 'Conkeror'), - awful.key({ "Control", "Mod1" }, "l", - function () awful.util.spawn('i3lock -c 000000') end)) + -- Menubar + awful.key({ modkey }, "k", function() menubar.show() end) +) clientkeys = awful.util.table.join( - awful.key({ modkey, }, "f", - function (c) c.fullscreen = not c.fullscreen end), - awful.key({ modkey, "Shift" }, "c", - function (c) c:kill() end), - awful.key({ modkey, "Control" }, "space", - awful.client.floating.toggle), - awful.key({ modkey, "Control" }, "Return", - function (c) c:swap(awful.client.getmaster()) end), - awful.key({ modkey, }, "o", - function () awful.screen.focus_relative(1) end), - awful.key({ modkey, "Shift" }, "o", awful.client.movetoscreen), - awful.key({ modkey, }, "t", function (c) c.ontop = not c.ontop 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)) + awful.key({ modkey, }, "f", function (c) c.fullscreen = not c.fullscreen end), + awful.key({ modkey, "Shift" }, "c", function (c) c:kill() end), + awful.key({ modkey, "Control" }, "space", awful.client.floating.toggle ), + awful.key({ modkey, "Control" }, "Return", function (c) c:swap(awful.client.getmaster()) end), + awful.key({ modkey, }, "o", awful.client.movetoscreen ), + awful.key({ modkey, }, "t", function (c) c.ontop = not c.ontop end), + awful.key({ modkey, }, "j", + 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) +) + +-- 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, 9 do + globalkeys = awful.util.table.join(globalkeys, + -- View tag only. + awful.key({ modkey }, "#" .. i + 9, + function () + local screen = mouse.screen + local tag = awful.tag.gettags(screen)[i] + if tag then + awful.tag.viewonly(tag) + end + end), + -- Toggle tag. + awful.key({ modkey, "Control" }, "#" .. i + 9, + function () + local screen = mouse.screen + local tag = awful.tag.gettags(screen)[i] + if tag then + awful.tag.viewtoggle(tag) + end + end), + -- Move client to tag. + awful.key({ modkey, "Shift" }, "#" .. i + 9, + function () + if client.focus then + local tag = awful.tag.gettags(client.focus.screen)[i] + if tag then + awful.client.movetotag(tag) + end + end + end), + -- Toggle tag. + awful.key({ modkey, "Control", "Shift" }, "#" .. i + 9, + function () + if client.focus then + local tag = awful.tag.gettags(client.focus.screen)[i] + if tag then + awful.client.toggletag(tag) + end + end + end)) 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 +-- }}} + +-- {{{ Rules +-- Rules to apply to new clients (through the "manage" signal). awful.rules.rules = { - -- All clients will match this rule. - { rule = { }, - properties = { border_width = beautiful.border_width, - border_color = beautiful.border_normal, - focus = awful.client.focus.filter, - keys = clientkeys } }, - { rule = { class = "pinentry" }, - properties = { floating = true } }, - { rule = { class = "gimp" }, - properties = { floating = true } }, - { rule = { class = "Conkeror" }, - properties = { floating = false, - tag = tags[2][1] } }, - -- Set Firefox to always map on tags number 2 of screen 1. - -- { rule = { class = "Firefox" }, - -- properties = { tag = tags[1][2] } }, + -- All clients will match this rule. + { rule = { }, + properties = { border_width = beautiful.border_width, + border_color = beautiful.border_normal, + focus = awful.client.focus.filter, + raise = true, + keys = clientkeys, + buttons = clientbuttons } }, + { rule = { class = "MPlayer" }, + properties = { floating = true } }, + { rule = { class = "pinentry" }, + properties = { floating = true } }, + { rule = { class = "gimp" }, + properties = { floating = true } }, + { rule = { instance = "RogueLegacy.exe" }, + properties = { fullscreen = true } }, + { rule = { instance = "swtor.exe" }, + properties = { fullscreen = true } }, + -- Set Firefox to always map on tags number 2 of screen 1. + -- { rule = { class = "Firefox" }, + -- properties = { tag = tags[1][2] } }, } - ------ Signals +-- }}} + +-- {{{ Signals -- Signal function to execute when a new client appears. -client.connect_signal( - "manage", - function (c, startup) - 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.connect_signal("manage", function (c, startup) + 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 + + local titlebars_enabled = false + if titlebars_enabled and (c.type == "normal" or c.type == "dialog") then + -- buttons for the titlebar + local buttons = awful.util.table.join( + awful.button({ }, 1, function() + client.focus = c + c:raise() + awful.mouse.client.move(c) + end), + awful.button({ }, 3, function() + client.focus = c + c:raise() + awful.mouse.client.resize(c) + end) + ) + + -- Widgets that are aligned to the left + local left_layout = wibox.layout.fixed.horizontal() + left_layout:add(awful.titlebar.widget.iconwidget(c)) + left_layout:buttons(buttons) + + -- Widgets that are aligned to the right + local right_layout = wibox.layout.fixed.horizontal() + right_layout:add(awful.titlebar.widget.floatingbutton(c)) + right_layout:add(awful.titlebar.widget.maximizedbutton(c)) + right_layout:add(awful.titlebar.widget.stickybutton(c)) + right_layout:add(awful.titlebar.widget.ontopbutton(c)) + right_layout:add(awful.titlebar.widget.closebutton(c)) + + -- The title goes in the middle + local middle_layout = wibox.layout.flex.horizontal() + local title = awful.titlebar.widget.titlewidget(c) + title:set_align("center") + middle_layout:add(title) + middle_layout:buttons(buttons) + + -- Now bring it all together + local layout = wibox.layout.align.horizontal() + layout:set_left(left_layout) + layout:set_right(right_layout) + layout:set_middle(middle_layout) + + awful.titlebar(c):set_widget(layout) + end +end) + +client.connect_signal("focus", function(c) c.border_color = beautiful.border_focus end) +client.connect_signal("unfocus", function(c) c.border_color = beautiful.border_normal end) +-- }}} -client.connect_signal( - "focus", function(c) c.border_color = beautiful.border_focus end) -client.connect_signal( - "unfocus", function(c) c.border_color = beautiful.border_normal end) +awful.tag.setmwfact(0.586, nil); |