X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/871ff68fe59f6b5a2e0ed1e5176ed7153d5015ca..8406a181daaacb36b92835dde4773061836d1354:/.config/awesome/rc.lua?ds=sidebyside diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua index d2c717e..c7cd405 100644 --- a/.config/awesome/rc.lua +++ b/.config/awesome/rc.lua @@ -1,18 +1,25 @@ --- awesome 3 configuration file - -AWESOME_DATADIR = "/home/madduck/code/awesome" -package.path = AWESOME_DATADIR .. "/lib/?.lua;" .. package.path - --- Include awesome library, with lots of useful function! +-- Standard awesome library require("awful") -require("tabulous") +require("beautiful") +require("naughty") --- Uncomment this to activate autotabbing --- tabulous.autotab_start() +-- Load Debian menu entries +require("debian.menu") -- {{{ Variable definitions --- This is used later as the default terminal to run. +-- Themes define colours, icons, and wallpapers +-- The default is a dark theme +theme_path = "/usr/share/awesome/themes/default/theme" +-- Uncommment this for a lighter theme +-- theme_path = "/usr/share/awesome/themes/sky/theme" + +-- Actually load theme +beautiful.init(theme_path) + +-- This is used later as the default terminal and editor to run. terminal = "x-terminal-emulator" +editor = os.getenv("EDITOR") or "editor" +editor_cmd = terminal .. " -e " .. editor -- Default modkey. -- Usually, Mod4 is the key with a logo between Control and Alt. @@ -24,150 +31,282 @@ modkey = "Mod4" -- Table of layouts to cover with awful.layout.inc, order matters. layouts = { - "tile", - "tileleft", - "tilebottom", - "tiletop", - "magnifier", - "max", - "spiral", - "dwindle", - "floating" + awful.layout.suit.tile, + awful.layout.suit.tile.left, + awful.layout.suit.tile.bottom, + awful.layout.suit.tile.top, + awful.layout.suit.fair, + awful.layout.suit.fair.horizontal, + awful.layout.suit.max, + awful.layout.suit.max.fullscreen, + awful.layout.suit.magnifier, + awful.layout.suit.floating } --- Table of clients that should be set floating -floatings = +-- Table of clients that should be set floating. The index may be either +-- the application class or instance. The instance is useful when running +-- a console app in a terminal like (Music on Console) +-- xterm -name mocp -e mocp +-- OVERRULED BY TILEDAPPS BELOW +floatapps = { - ["mplayer"] = true, + -- by class + ["MPlayer"] = true, ["pinentry"] = true, ["GIMP"] = true, ["twinkle"] = true, ["Add-ons"] = true, - ["Play stream"] = true + ["Play stream"] = true, } --- Color & Appearance definitions, we use these later to display things -font = "RotisSansSerif 10" -border_width = 1 - -bg_normal = "#222222" -fg_normal = "#aaaaaa" -border_normal = "#000000" +-- Applications that should never float, assuming everything else floats +-- (by instance) +tiledapps = +{ + ["urxvt"] = true, +} -bg_focus = "#535d6c" -fg_focus = "#ffffff" -border_focus = bg_focus -border_marked = "#91231C" +-- Applications that should be maximised +-- (by instance) +maxapps = +{ + ["Navigator"] = true, + -- jpilot is -v + ["-v"] = true, + ["Xpdf"] = true, + ["gscan2pdf"] = true +} -awesome.font_set(font) -awesome.colors_set({ fg = fg_normal, bg = bg_normal }) +-- Applications to be moved to a pre-defined tag by class or instance. +-- Use the screen and tags indices. +apptags = +{ + ["Navigator"] = { screen = 1, tag = 9 }, + -- jpilot is -v + ["-v"] = { screen = 1, tag = 8 }, +} +-- Define if we want to use titlebar on all applications. +use_titlebar = false -- }}} -- {{{ Tags --- Define tags table +-- Define tags table. tags = {} for s = 1, screen.count() do - -- Each screen has its own tag table + -- Each screen has its own tag table. tags[s] = {} - -- Create 9 tags per screen + -- Create 9 tags per screen. for tagnumber = 1, 9 do - tags[s][tagnumber] = tag({ name = tagnumber, layout = layouts[1] }) + tags[s][tagnumber] = tag(tagnumber) -- Add tags to screen one by one -- split at 0.5/50% exactly - tags[s][tagnumber].mwfact = 0.5 - tags[s][tagnumber]:add(s) + -- tags[s][tagnumber].mwfact = 0.5 + tags[s][tagnumber].screen = s + awful.layout.set(layouts[5], tags[s][tagnumber]) end -- I'm sure you want to see at least one tag. tags[s][1].selected = true end -- }}} --- {{{ Statusbar --- Create a taglist widget -mytaglist = widget({ type = "taglist", name = "mytaglist" }) -mytaglist:mouse_add(mouse({}, 1, function (object, tag) awful.tag.viewonly(tag) end)) -mytaglist:mouse_add(mouse({ modkey }, 1, function (object, tag) awful.client.movetotag(tag) end)) -mytaglist:mouse_add(mouse({}, 3, function (object, tag) tag.selected = not tag.selected end)) -mytaglist:mouse_add(mouse({ modkey }, 3, function (object, tag) awful.client.toggletag(tag) end)) -mytaglist:mouse_add(mouse({ }, 4, awful.tag.viewnext)) -mytaglist:mouse_add(mouse({ }, 5, awful.tag.viewprev)) -function mytaglist.label(t) - local text = "" - if t.selected then - text = " "..t.name.." " - else - text = " "..t.name.." " - end - return text -end - --- Create a tasklist widget -mytasklist = widget({ type = "tasklist", name = "mytasklist" }) -mytasklist:mouse_add(mouse({ }, 1, function (object, c) c:focus_set(); c:raise() end)) -mytasklist:mouse_add(mouse({ }, 4, function () awful.client.focus(1) end)) -mytasklist:mouse_add(mouse({ }, 5, function () awful.client.focus(-1) end)) -function mytasklist.label(c) - local text = "" - if c.floating then - text = "" - end - if client.focus_get() == c then - text = text .. " "..c.name.." " - else - text = text .. " "..awful.escape(c.name).." " - end - return text -end - +-- {{{ Wibox -- Create a textbox widget -mytextbox = widget({ type = "textbox", name = "mytextbox", align = "right" }) +mytextbox = widget({ type = "textbox", align = "right" }) -- Set the default text in textbox -mytextbox.text = " awesome " .. AWESOME_VERSION .. " " -mypromptbox = widget({ type = "textbox", name = "mypromptbox", align = "left" }) +mytextbox.text = " " .. AWESOME_RELEASE .. " " + +-- Create a laucher widget and a main menu +myawesomemenu = { + { "manual", terminal .. " -e man awesome" }, + { "edit config", editor_cmd .. " " .. awful.util.getdir("config") .. "/rc.lua" }, + { "restart", awesome.restart }, + { "quit", awesome.quit } +} + +mymainmenu = awful.menu.new({ items = { { "awesome", myawesomemenu, beautiful.awesome_icon }, + { "open terminal", terminal }, + { "Debian", debian.menu.Debian_menu.Debian } + } + }) --- Create an iconbox widget -myiconbox = widget({ type = "textbox", name = "myiconbox", align = "left" }) -myiconbox.text = "" +mylauncher = awful.widget.launcher({ image = image(beautiful.awesome_icon), + menu = mymainmenu }) -- Create a systray -mysystray = widget({ type = "systray", name = "mysystray", align = "right" }) +mysystray = widget({ type = "systray", align = "right" }) --- Create an iconbox widget which will contains an icon indicating which layout we're using. --- We need one layoutbox per screen. +-- Create textbox widgets +mytimebox = widget({ type = "textbox", name = "mytimebox", align = "right" }) +mybatterybox = widget({ type = "textbox", name = "mybatterybox", align = "right" }) + +-- Create a wibox for each screen and add it +mywibox = {} +mypromptbox = {} mylayoutbox = {} -for s = 1, screen.count() do - mylayoutbox[s] = widget({ type = "textbox", name = "mylayoutbox", align = "right" }) - mylayoutbox[s]:mouse_add(mouse({ }, 1, function () awful.layout.inc(layouts, 1) end)) - mylayoutbox[s]:mouse_add(mouse({ }, 3, function () awful.layout.inc(layouts, -1) end)) - mylayoutbox[s]:mouse_add(mouse({ }, 4, function () awful.layout.inc(layouts, 1) end)) - mylayoutbox[s]:mouse_add(mouse({ }, 5, function () awful.layout.inc(layouts, -1) end)) - mylayoutbox[s].text = "" -end +mytaglist = {} +mytaglist.buttons = { button({ }, 1, awful.tag.viewonly), + button({ modkey }, 1, awful.client.movetotag), + button({ }, 3, function (tag) tag.selected = not tag.selected end), + button({ modkey }, 3, awful.client.toggletag), + button({ }, 4, awful.tag.viewnext), + button({ }, 5, awful.tag.viewprev) } +mytasklist = {} +mytasklist.buttons = { button({ }, 1, function (c) + if not c:isvisible() then + awful.tag.viewonly(c:tags()[1]) + end + client.focus = c + c:raise() + end), + button({ }, 3, function () if instance then instance:hide() end instance = awful.menu.clients({ width=250 }) end), + button({ }, 4, function () awful.client.focus.byidx(1) end), + button({ }, 5, function () awful.client.focus.byidx(-1) end) } --- Create a statusbar for each screen and add it -mystatusbar = {} for s = 1, screen.count() do - mystatusbar[s] = statusbar({ position = "top", name = "mystatusbar" .. s, - fg = fg_normal, bg = bg_normal }) - -- Add widgets to the statusbar - order matters - mystatusbar[s]:widget_add(mytaglist) - mystatusbar[s]:widget_add(mytasklist) - mystatusbar[s]:widget_add(mypromptbox) - mystatusbar[s]:widget_add(mytextbox) - mystatusbar[s]:widget_add(mylayoutbox[s]) - mystatusbar[s]:add(s) + -- Create a promptbox for each screen + mypromptbox[s] = widget({ type = "textbox", align = "left" }) + -- Create an imagebox widget which will contains an icon indicating which layout we're using. + -- We need one layoutbox per screen. + mylayoutbox[s] = widget({ type = "imagebox", align = "right" }) + mylayoutbox[s]:buttons({ button({ }, 1, function () awful.layout.inc(layouts, 1) end), + button({ }, 3, function () awful.layout.inc(layouts, -1) end), + button({ }, 4, function () awful.layout.inc(layouts, 1) end), + button({ }, 5, function () awful.layout.inc(layouts, -1) end) }) + -- Create a taglist widget + mytaglist[s] = awful.widget.taglist.new(s, awful.widget.taglist.label.all, mytaglist.buttons) + + -- Create a tasklist widget + mytasklist[s] = awful.widget.tasklist.new(function(c) + return awful.widget.tasklist.label.currenttags(c, s) + end, mytasklist.buttons) + + -- Create the wibox + mywibox[s] = wibox({ position = "top", fg = beautiful.fg_normal, bg = beautiful.bg_normal }) + -- Add widgets to the wibox - order matters + mywibox[s].widgets = { mytaglist[s], + mytasklist[s], + mypromptbox[s], + mybatterybox, + mytimebox, + mylayoutbox[s], + s == screen.count() and mysystray or nil } + mywibox[s].screen = s end -mystatusbar[screen.count()]:widget_add(mysystray) -- }}} +--Battery widget +batterywidget = widget({ type = 'progressbar', name = 'batterywidget' }) +batterywidget.width = 100 +batterywidget.height = 0.8 +batterywidget.gap = 1 +batterywidget.border_padding = 1 +batterywidget.border_width = 1 +batterywidget.ticks_count = 10 +batterywidget.ticks_gap = 1 +batterywidget.vertical = false +batterywidget:bar_properties_set('bat', { + bg = 'black', + fg = 'blue4', + fg_off = 'red', + reverse = false, + min_value = 0, + max_value = 100 +}) +-- }}} + + -- {{{ Mouse bindings -awesome.mouse_add(mouse({ }, 3, function () awful.spawn(terminal) end)) -awesome.mouse_add(mouse({ }, 4, awful.tag.viewnext)) -awesome.mouse_add(mouse({ }, 5, awful.tag.viewprev)) +root.buttons({ + button({ }, 3, function () mymainmenu:toggle() end), + button({ }, 4, awful.tag.viewnext), + button({ }, 5, awful.tag.viewprev) +}) -- }}} -- {{{ Key bindings +globalkeys = +{ + key({ modkey, }, "Left", awful.tag.viewprev ), + key({ modkey, }, "Right", awful.tag.viewnext ), + key({ modkey, }, "Escape", awful.tag.history.restore), + + key({ modkey, }, "j", + function () + awful.client.focus.byidx( 1) + if client.focus then client.focus:raise() end + end), + key({ modkey, }, "k", + function () + awful.client.focus.byidx(-1) + if client.focus then client.focus:raise() end + end), + + -- Layout manipulation + key({ modkey, "Shift" }, "j", function () awful.client.swap.byidx( 1) end), + key({ modkey, "Shift" }, "k", function () awful.client.swap.byidx( -1) end), + key({ modkey, "Control" }, "j", function () awful.screen.focus( 1) end), + key({ modkey, "Control" }, "k", function () awful.screen.focus(-1) end), + key({ modkey, }, "u", awful.client.urgent.jumpto), + key({ modkey, }, "Tab", + function () + awful.client.focus.history.previous() + if client.focus then + client.focus:raise() + end + end), + + -- Standard program + key({ modkey, }, "Return", function () awful.util.spawn(terminal) end), + key({ modkey, "Control" }, "r", awesome.restart), + key({ modkey, "Shift" }, "q", awesome.quit), + + key({ modkey, }, "l", function () awful.tag.incmwfact( 0.05) end), + key({ modkey, }, "h", function () awful.tag.incmwfact(-0.05) end), + key({ modkey, "Shift" }, "h", function () awful.tag.incnmaster( 1) end), + key({ modkey, "Shift" }, "l", function () awful.tag.incnmaster(-1) end), + key({ modkey, "Control" }, "h", function () awful.tag.incncol( 1) end), + key({ modkey, "Control" }, "l", function () awful.tag.incncol(-1) end), + key({ modkey, }, "space", function () awful.layout.inc(layouts, 1) end), + key({ modkey, "Shift" }, "space", function () awful.layout.inc(layouts, -1) end), + + -- Prompt + key({ modkey }, "F1", + function () + awful.prompt.run({ prompt = "Run: " }, + mypromptbox[mouse.screen], + awful.util.spawn, awful.completion.bash, + awful.util.getdir("cache") .. "/history") + end), + + key({ modkey }, "F4", + function () + awful.prompt.run({ prompt = "Run Lua code: " }, + mypromptbox[mouse.screen], + awful.util.eval, awful.prompt.bash, + awful.util.getdir("cache") .. "/history_eval") + end), +} + +-- Client awful tagging: this is useful to tag some clients and then do stuff like move to tag on them +clientkeys = +{ + key({ modkey, }, "f", function (c) c.fullscreen = not c.fullscreen end), + key({ modkey, "Shift" }, "c", function (c) c:kill() end), + key({ modkey, "Control" }, "space", awful.client.floating.toggle ), + key({ modkey, "Control" }, "Return", function (c) c:swap(awful.client.getmaster()) end), + key({ modkey, }, "o", awful.client.movetoscreen ), + key({ modkey, "Shift" }, "r", function (c) c:redraw() end), + key({ modkey }, "t", awful.client.togglemarked), + key({ modkey,}, "m", + function (c) + if not awful.client.floating then + awful.client.floating.toggle() + end + c.maximized_horizontal = not c.maximized_horizontal + c.maximized_vertical = not c.maximized_vertical + end), +} -- Bind keyboard digits -- Compute the maximum number of digit we need, limited to 9 @@ -177,249 +316,385 @@ for s = 1, screen.count() do end for i = 1, keynumber do - keybinding({ modkey }, i, - function () - local screen = mouse.screen - if tags[screen][i] then - awful.tag.viewonly(tags[screen][i]) - end - end):add() - keybinding({ modkey, "Control" }, i, - function () - local screen = mouse.screen - if tags[screen][i] then - tags[screen][i].selected = not tags[screen][i].selected - end - end):add() - keybinding({ modkey, "Shift" }, i, - function () - local screen = mouse.screen - if tags[screen][i] then - awful.client.movetotag(tags[screen][i]) - end - end):add() - keybinding({ modkey, "Control", "Shift" }, i, - function () - local screen = mouse.screen - if tags[screen][i] then - awful.client.toggletag(tags[screen][i]) - end - end):add() + table.insert(globalkeys, + key({ modkey }, i, + function () + local screen = mouse.screen + if tags[screen][i] then + awful.tag.viewonly(tags[screen][i]) + end + end)) + table.insert(globalkeys, + key({ modkey, "Control" }, i, + function () + local screen = mouse.screen + if tags[screen][i] then + tags[screen][i].selected = not tags[screen][i].selected + end + end)) + table.insert(globalkeys, + key({ modkey, "Shift" }, i, + function () + if client.focus and tags[client.focus.screen][i] then + awful.client.movetotag(tags[client.focus.screen][i]) + end + end)) + table.insert(globalkeys, + key({ modkey, "Control", "Shift" }, i, + function () + if client.focus and tags[client.focus.screen][i] then + awful.client.toggletag(tags[client.focus.screen][i]) + end + end)) end -keybinding({ modkey }, "Left", awful.tag.viewprev):add() -keybinding({ modkey }, "Right", awful.tag.viewnext):add() - --- Standard program -keybinding({ modkey }, "Return", function () awful.spawn(terminal) end):add() - -keybinding({ modkey, "Control" }, "r", awesome.restart):add() -keybinding({ modkey, "Shift" }, "q", awesome.quit):add() - --- Client manipulation -keybinding({ modkey, "Shift" }, "c", function () client.focus_get():kill() end):add() -keybinding({ modkey }, "j", function () awful.client.focus(1); client.focus_get():raise() end):add() -keybinding({ modkey }, "k", function () awful.client.focus(-1); client.focus_get():raise() end):add() -keybinding({ modkey, "Shift" }, "j", function () awful.client.swap(1) end):add() -keybinding({ modkey, "Shift" }, "k", function () awful.client.swap(-1) end):add() -keybinding({ modkey, "Control" }, "j", function () awful.screen.focus(1) end):add() -keybinding({ modkey, "Control" }, "k", function () awful.screen.focus(-1) end):add() -keybinding({ modkey, "Control" }, "space", awful.client.togglefloating):add() -keybinding({ modkey, "Control" }, "Return", function () client.focus_get():swap(awful.client.master()) end):add() -keybinding({ modkey }, "o", awful.client.movetoscreen):add() - --- Layout manipulation -keybinding({ modkey }, "l", function () awful.tag.incmwfact(0.05) end):add() -keybinding({ modkey }, "h", function () awful.tag.incmwfact(-0.05) end):add() -keybinding({ modkey, "Shift" }, "h", function () awful.tag.incnmaster(1) end):add() -keybinding({ modkey, "Shift" }, "l", function () awful.tag.incnmaster(-1) end):add() -keybinding({ modkey, "Control" }, "h", function () awful.tag.incncol(1) end):add() -keybinding({ modkey, "Control" }, "l", function () awful.tag.incncol(-1) end):add() -keybinding({ modkey }, "space", function () awful.layout.inc(layouts, 1) end):add() -keybinding({ modkey, "Shift" }, "space", function () awful.layout.inc(layouts, -1) end):add() - --- Prompt -keybinding({ modkey }, "F1", function () - awful.prompt({ prompt = "Run: ", cursor_fg = fg_focus, cursor_bg = bg_focus }, mypromptbox, awful.spawn, awful.completion.bash) - end):add() -keybinding({ modkey }, "F4", function () - awful.prompt({ prompt = "Run Lua code: ", cursor_fg = fg_focus, cursor_bg = bg_focus }, mypromptbox, awful.eval, awful.prompt.bash) - end):add() - ---- Tabulous, tab manipulation -keybinding({ modkey, "Control" }, "y", function () - local tabbedview = tabulous.tabindex_get() - local nextclient = awful.client.next(1) - - if tabbedview == nil then - tabbedview = tabulous.tabindex_get(nextclient) - - if tabbedview == nil then - tabbedview = tabulous.tab_create() - tabulous.tab(tabbedview, nextclient) - else - tabulous.tab(tabbedview, client.focus_get()) - end - else - tabulous.tab(tabbedview, nextclient) - end -end):add() - -keybinding({ modkey, "Shift" }, "y", tabulous.untab):add() - -keybinding({ modkey }, "y", function () - local tabbedview = tabulous.tabindex_get() - if tabbedview ~= nil then - local n = tabulous.next(tabbedview) - tabulous.display(tabbedview, n) - end -end):add() - --- Client awful tagging: this is useful to tag some clients and then do stuff like move to tag on them -keybinding({ modkey }, "t", awful.client.togglemarked):add() -keybinding({ modkey, 'Shift' }, "t", function () - local tabbedview = tabulous.tabindex_get() - local clients = awful.client.getmarked() - - if tabbedview == nil then - tabbedview = tabulous.tab_create(clients[1]) - table.remove(clients, 1) - end +for i = 1, keynumber do + table.insert(globalkeys, key({ modkey, "Shift" }, "F" .. i, + function () + local screen = mouse.screen + if tags[screen][i] then + for k, c in pairs(awful.client.getmarked()) do + awful.client.movetotag(tags[screen][i], c) + end + end + end)) +end - for k,c in pairs(clients) do - tabulous.tab(tabbedview, c) - end +cmdmodkey = "Mod3" -end):add() +-- xmms2 & sound +table.insert(globalkeys, key({ cmdmodkey }, "Prior", function () awful.util.spawn("amixer set Master 2+") end)) +table.insert(globalkeys, key({ cmdmodkey }, "Next", function () awful.util.spawn("amixer set Master 2-") end)) +table.insert(globalkeys, key({ cmdmodkey }, "Up", function () awful.util.spawn("amixer set PCM 2+") end)) +table.insert(globalkeys, key({ cmdmodkey }, "Down", function () awful.util.spawn("amixer set PCM 2-") end)) +table.insert(globalkeys, key({ cmdmodkey }, "Home", function () awful.util.spawn("amixer set Mic toggle") end)) +table.insert(globalkeys, key({ cmdmodkey }, "End", function () awful.util.spawn("amixer set Master toggle") end)) +table.insert(globalkeys, key({ cmdmodkey }, "Left", function () awful.util.spawn("xmms2 prev") end)) +table.insert(globalkeys, key({ cmdmodkey }, "Right", function () awful.util.spawn("xmms2 next") end)) +table.insert(globalkeys, key({ cmdmodkey }, "space", function () awful.util.spawn("xmms2 toggleplay") end)) +table.insert(globalkeys, key({ cmdmodkey }, "backslash", function () awful.util.spawn("xmms2 current | head -1 | xmessage -nearmouse -timeout 5 -file -") end)) +table.insert(globalkeys, key({ cmdmodkey, "Shift" }, "backslash", function () awful.util.spawn("xmms2 list | xmessage -nearmouse -timeout 5 -file -") end)) -for i = 1, keynumber do - keybinding({ modkey, "Shift" }, "F" .. i, - function () - local screen = mouse.screen - if tags[screen][i] then - for k, c in pairs(awful.client.getmarked()) do - awful.client.movetotag(tags[screen][i], c) - end - end - end):add() -end +-- misc apps +table.insert(globalkeys, key({ cmdmodkey }, "n", function () awful.util.spawn("sensible-browser") end)) +table.insert(globalkeys, key({ cmdmodkey }, "m", function () awful.util.spawn(terminal .. " -e mutt -f =store") end)) +table.insert(globalkeys, key({ cmdmodkey }, "t", function () awful.util.spawn(terminal) end)) +table.insert(globalkeys, key({ cmdmodkey }, "c", function () awful.util.spawn(terminal .. " -e python") end)) +table.insert(globalkeys, key({ cmdmodkey }, "r", function () awful.util.spawn("gmrun") end)) +table.insert(globalkeys, key({ cmdmodkey }, "j", function () awful.util.spawn("jpilot") end)) +table.insert(globalkeys, key({ cmdmodkey }, "x", function () awful.util.spawn("/sbin/start-stop-daemon --start --background --exec /usr/bin/xscreensaver; xscreensaver-command -lock") end)) +table.insert(globalkeys, key({ cmdmodkey, "Shift" }, "x", function () awful.util.spawn("xscreensaver-command -exit") end)) + +-- Set keys +root.keys(globalkeys) -- }}} -- {{{ Hooks -- Hook function to execute when focusing a client. -function hook_focus(c) +awful.hooks.focus.register(function (c) if not awful.client.ismarked(c) then - c.border_color = border_focus + c.border_color = beautiful.border_focus end -end +end) -- Hook function to execute when unfocusing a client. -function hook_unfocus(c) +awful.hooks.unfocus.register(function (c) if not awful.client.ismarked(c) then - c.border_color = border_normal + c.border_color = beautiful.border_normal end -end +end) -- Hook function to execute when marking a client -function hook_marked(c) - c.border_color = border_marked -end +awful.hooks.marked.register(function (c) + c.border_color = beautiful.border_marked +end) --- Hook function to execute when unmarking a client -function hook_unmarked(c) - c.border_color = border_focus -end +-- Hook function to execute when unmarking a client. +awful.hooks.unmarked.register(function (c) + c.border_color = beautiful.border_focus +end) --- Hook function to execute when the mouse is over a client. -function hook_mouseover(c) +-- Hook function to execute when the mouse enters a client. +awful.hooks.mouse_enter.register(function (c) -- Sloppy focus, but disabled for magnifier layout - if awful.layout.get(c.screen) ~= "magnifier" then - c:focus_set() + if awful.layout.get(c.screen) ~= awful.layout.suit.magnifier + and awful.client.focus.filter(c) then + client.focus = c end -end +end) -- Hook function to execute when a new client appears. -function hook_manage(c) +awful.hooks.manage.register(function (c, startup) + -- If we are not managing this application at startup, + -- move it to the screen where the mouse is. + -- We only do it for filtered windows (i.e. no dock, etc). + if not startup and awful.client.focus.filter(c) then + c.screen = mouse.screen + end + + if use_titlebar then + -- Add a titlebar + awful.titlebar.add(c, { modkey = modkey }) + end -- Add mouse bindings - c:mouse_add(mouse({ }, 1, function (c) c:focus_set(); c:raise() end)) - c:mouse_add(mouse({ modkey }, 1, function (c) c:mouse_move() end)) - c:mouse_add(mouse({ modkey }, 3, function (c) c:mouse_resize() end)) + c:buttons({ + button({ }, 1, function (c) client.focus = c; c:raise() end), + button({ modkey }, 1, awful.mouse.client.move), + button({ modkey }, 3, awful.mouse.client.resize) + }) -- New client may not receive focus -- if they're not focusable, so set border anyway. - c.border_width = border_width - c.border_color = border_normal - c:focus_set() - if floatings[c.name:lower()] then - c.floating = true + c.border_width = beautiful.border_width + c.border_color = beautiful.border_normal + + -- Check if the application should be floating. + -- OVERRIDDEN, SEE tiledapps BELOW + local cls = c.class + local inst = c.instance + if floatapps[cls] then + awful.client.floating.set(c, floatapps[cls]) + elseif floatapps[inst] then + awful.client.floating.set(c, floatapps[inst]) end - -- Honor size hints - c.honorsizehints = true -end --- Hook function to execute when arranging the screen + -- Override with tiledapps + awful.client.floating.set(c, not (tiledapps[inst] or tiledapps[cls])) + + -- Check application->screen/tag mappings. + local target + if apptags[cls] then + target = apptags[cls] + elseif apptags[inst] then + target = apptags[inst] + end + if target then + c.screen = target.screen + awful.client.movetotag(tags[target.screen][target.tag], c) + end + + -- Do this after tag mapping, so you don't see it on the wrong tag for a split second. + client.focus = c + + -- Set key bindings + c:keys(clientkeys) + + -- Set the windows at the slave, + -- i.e. put it at the end of others instead of setting it master. + -- awful.client.setslave(c) + + -- Honor size hints: if you want to drop the gaps between windows, set this to false. + c.size_hints_honor = true + + -- Maximise some + if maxapps[inst] or maxapps[cls] then + c.maximized_horizontal = not c.maximized_horizontal + c.maximized_vertical = not c.maximized_vertical + end +end) + +-- Hook function to execute when arranging the screen. -- (tag switch, new client, etc) -function hook_arrange(screen) - local layout = awful.layout.get(screen) - mylayoutbox[screen].text = "" +awful.hooks.arrange.register(function (screen) + local layout = awful.layout.getname(awful.layout.get(screen)) + if layout and beautiful["layout_" ..layout] then + mylayoutbox[screen].image = image(beautiful["layout_" .. layout]) + else + mylayoutbox[screen].image = nil + end + + -- Give focus to the latest client in history if no window has focus + -- or if the current window is a desktop or a dock one. + if not client.focus then + local c = awful.client.focus.history.get(screen, 0) + if c then client.focus = c end + end -- Uncomment if you want mouse warping --[[ - local sel = client.focus_get() - if sel then - local c_c = sel.coords - local m_c = mouse.coords + if client.focus then + local c_c = client.focus:fullgeometry() + local m_c = mouse.coords() if m_c.x < c_c.x or m_c.x >= c_c.x + c_c.width or m_c.y < c_c.y or m_c.y >= c_c.y + c_c.height then if table.maxn(m_c.buttons) == 0 then - mouse.coords = { x = c_c.x + 5, y = c_c.y + 5} + mouse.coords({ x = c_c.x + 5, y = c_c.y + 5}) end end end ]] -end +end) -- Hook called every second -function hook_timer () +awful.hooks.timer.register(1, function () -- For unix time_t lovers -- mytextbox.text = " " .. os.time() .. " time_t " -- Otherwise use: - mytextbox.text = " " .. os.date() .. " " + mytimebox.text = " " .. os.date() .. " " +end) + +-- Hook called every sixty seconds +function hook_battery() + mybatterybox.text = " " .. get_acpibatt() .. " " end +-- {{{ Statusbar battery +-- +function get_acpibatt() + + local f = io.popen('acpi -b', 'r') + if not f then + return "acpi -b failed" + end + + local s = f:read('*l') + f:close() + if not s then + return '-'; + end + + -- Battery 0: Discharging, 89%, 00:02:14 remaining + -- Battery 0: Charging, 58%, 00:02:14 until charged + -- Battery 0: Full, 100% + -- so find the first bit first and then go look for the time + local st, en, status, percent = string.find(s, '%a+%s%d:%s(%a+),%s(%d+%%)'); + local st, en, time = string.find(s, ',%s(%d+:%d+):%d+%s%a+', en); + + if not status or not percent then -- time can be empty if we're full + return "couldn't parse line " .. s + end + + if not time then + return percent + end + + if status == 'Charging' then + status = '+'; + elseif status == 'Discharging' then + status = '-'; + else + status = 'x'; + end + + return status .. ' ' .. time; + -- return percent .. ' (' .. status .. ')'; -- .. ' ' .. time .. ' left'; +end +-- }}} + +--{{{ batt hook +local function get_bat() + local a = io.open("/sys/class/power_supply/BAT1/charge_full") + for line in a:lines() do + full = line + end + a:close() + local b = io.open("/sys/class/power_supply/BAT1/charge_now") + for line in b:lines() do + now = line + end + b:close() + batt=math.floor(now*100/full) + batterywidget:bar_data_add("bat",batt ) +end +--}}} + -- Set up some hooks -awful.hooks.focus(hook_focus) -awful.hooks.unfocus(hook_unfocus) -awful.hooks.marked(hook_marked) -awful.hooks.unmarked(hook_unmarked) -awful.hooks.manage(hook_manage) -awful.hooks.mouseover(hook_mouseover) -awful.hooks.arrange(hook_arrange) -awful.hooks.timer(1, hook_timer) +awful.hooks.timer.register(120, hook_battery) +-- awful.hooks.timer.register(5, get_bat) -- }}} -cmdmodkey = "Mod3" +-- Highlight statusbars on the screen that has focus, +-- set this to false if you only have one screen or +-- you don't like it :P +if screen.count() > 1 then + statusbar_highlight_focus = true +else + statusbar_highlight_focus = false +end --- xmms2 & sound -keybinding({ cmdmodkey }, "Prior", function () awful.spawn("amixer set Master 2+") end):add() -keybinding({ cmdmodkey }, "Next", function () awful.spawn("amixer set Master 2-") end):add() -keybinding({ cmdmodkey }, "Up", function () awful.spawn("amixer set PCM 2+") end):add() -keybinding({ cmdmodkey }, "Down", function () awful.spawn("amixer set PCM 2-") end):add() -keybinding({ cmdmodkey }, "Home", function () awful.spawn("amixer set Mic toggle") end):add() -keybinding({ cmdmodkey }, "End", function () awful.spawn("amixer set Master toggle") end):add() -keybinding({ cmdmodkey }, "Left", function () awful.spawn("xmms2 prev") end):add() -keybinding({ cmdmodkey }, "Right", function () awful.spawn("xmms2 next") end):add() -keybinding({ cmdmodkey }, "space", function () awful.spawn("xmms2 toggle") end):add() -keybinding({ cmdmodkey }, "backslash", function () awful.spawn("xmms2 current | head -1 | xmessage -nearmouse -timeout 5 -file -") end):add() -keybinding({ cmdmodkey, "Shift" }, "backslash", function () awful.spawn("xmms2 list | xmessage -nearmouse -timeout 5 -file -") end):add() +hook_battery() --- misc apps -keybinding({ cmdmodkey }, "n", function () awful.spawn("sensible-browser") end):add() -keybinding({ cmdmodkey }, "m", function () awful.spawn(terminal .. " -e mutt -f =store") end):add() -keybinding({ cmdmodkey }, "t", function () awful.spawn(terminal) end):add() -keybinding({ cmdmodkey }, "c", function () awful.spawn(terminal .. " -e python") end):add() -keybinding({ cmdmodkey }, "r", function () awful.spawn("gmrun") end):add() -keybinding({ cmdmodkey }, "j", function () awful.spawn("jpilot") end):add() -keybinding({ cmdmodkey }, "x", function () awful.spawn("/sbin/start-stop-daemon --start --background --exec /usr/bin/xscreensaver; xscreensaver-command -lock") end):add() -keybinding({ cmdmodkey, "Shift" }, "x", function () awful.spawn("xscreensaver-command -exit") end):add() +function displayMonth(month,year,weekStart) + local t,wkSt=os.time{year=year, month=month+1, day=0},weekStart or 1 + local d=os.date("*t",t) + local mthDays,stDay=d.day,(d.wday-d.day-wkSt+1)%7 + + local lines = {} + + for x=0,6 do + lines[x+1] = os.date("%a ",os.time{year=2006,month=1,day=x+wkSt}) + end + lines[8] = " " + + local writeLine = 1 + while writeLine < (stDay + 1) do + lines[writeLine] = lines[writeLine] .. " " + writeLine = writeLine + 1 + end + + for x=1,mthDays do + if writeLine == 8 then + writeLine = 1 + end + if writeLine == 1 or x == 1 then + lines[8] = lines[8] .. os.date(" %V",os.time{year=year,month=month,day=x}) + end + if (#(tostring(x)) == 1) then + x = " " .. x + end + lines[writeLine] = lines[writeLine] .. " " .. x + writeLine = writeLine + 1 + end + local header = os.date("%B %Y\n",os.time{year=year,month=month,day=1}) + header = string.rep(" ", math.floor((#(lines[1]) - #header) / 2 )) .. header + + return header .. table.concat(lines, '\n') +end + +local calendar = {} +function switchNaughtyMonth(switchMonths) + if (#calendar < 3) then return end + local swMonths = switchMonths or 1 + calendar[1] = calendar[1] + swMonths + calendar[3].box.widgets[2].text = displayMonth(calendar[1], calendar[2], 2) +end + +mytimebox.mouse_enter = function () + local month, year = os.date('%m'), os.date('%Y') + calendar = { month, year, + naughty.notify({ + text = displayMonth(month, year, 2), + timeout = 0, hover_timeout = 0.5, + width = 200, screen = mouse.screen + }) + } +end +mytimebox.mouse_leave = function () naughty.destroy(calendar[3]) end + +mytimebox:buttons({ + button({ }, 1, function() + switchNaughtyMonth(-1) + end), + button({ }, 3, function() + switchNaughtyMonth(1) + end), + button({ }, 4, function() + switchNaughtyMonth(-1) + end), + button({ }, 5, function() + switchNaughtyMonth(1) + end), + button({ 'Shift' }, 1, function() + switchNaughtyMonth(-12) + end), + button({ 'Shift' }, 3, function() + switchNaughtyMonth(12) + end), + button({ 'Shift' }, 4, function() + switchNaughtyMonth(-12) + end), + button({ 'Shift' }, 5, function() + switchNaughtyMonth(12) + end) +})