X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/74506b469366ea653f60ddd9e8d415728cf13ebf..59c9bbdc2889d5eb04920216656a4955ff428ccd:/.config/awesome/rc.lua?ds=sidebyside diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua index 398c03e..554ecbb 100644 --- a/.config/awesome/rc.lua +++ b/.config/awesome/rc.lua @@ -29,7 +29,7 @@ layouts = "tileleft", "tilebottom", "tiletop", --- "magnifier", + "magnifier", "max", -- "spiral", -- "dwindle", @@ -40,6 +40,7 @@ layouts = -- 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 = { -- by class @@ -51,12 +52,30 @@ floatapps = ["Play stream"] = true } +-- Applications that should never float, assuming everything else floats +-- (by instance) +tiledapps = +{ + ["urxvt"] = true +} + +-- Applications that should be maximised +-- (by instance) +maxapps = +{ + ["Navigator"] = true, + -- jpilot is -v + ["-v"] = true, + ["Xpdf"] = true +} + -- Applications to be moved to a pre-defined tag by class or instance. --- Use the screen and workspace indices. +-- Use the screen and tags indices. apptags = { - ["Firefox"] = { screen = 1, tag = 9 }, - ["jpilot"] = { screen = 1, tag = 8 }, + ["Navigator"] = { screen = 1, tag = 9 }, + -- jpilot is -v + ["-v"] = { screen = 1, tag = 8 }, } -- Define if we want to use titlebar on all applications. @@ -87,7 +106,7 @@ for s = 1, screen.count() do tags[s][tagnumber] = tag({ name = tagnumber, layout = layouts[1] }) -- Add tags to screen one by one -- split at 0.5/50% exactly - tags[s][tagnumber].mwfact = 0.5 + -- tags[s][tagnumber].mwfact = 0.5 tags[s][tagnumber].screen = s end -- I'm sure you want to see at least one tag. @@ -114,9 +133,8 @@ mytasklist:mouse_add(mouse({ }, 5, function () awful.client.focusbyidx(-1) end)) mytasklist.label = awful.widget.tasklist.label.currenttags -- Create a textbox widget -mytextbox = widget({ type = "textbox", name = "mytextbox", align = "right" }) --- Set the default text in textbox -mytextbox.text = " awesome " .. AWESOME_VERSION .. " " +mytimebox = widget({ type = "textbox", name = "mytimebox", align = "right" }) +mybatterybox = widget({ type = "textbox", name = "mybatterybox", align = "right" }) mypromptbox = widget({ type = "textbox", name = "mypromptbox", align = "left" }) -- Create an iconbox widget @@ -138,21 +156,42 @@ for s = 1, screen.count() do mylayoutbox[s].text = "" end +--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 +}) +-- }}} + -- 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 = beautiful.fg_normal, bg = beautiful.bg_normal }) + fg = beautiful.fg_normal, bg = beautiful.bg_normal }) -- Add widgets to the statusbar - order matters - mystatusbar[s].widgets = - { + mystatusbar[s]:widgets({ mytaglist, mytasklist, mypromptbox, - mytextbox, +-- batterywidget, + mybatterybox, + mytimebox, mylayoutbox[s], s == screen.count() and mysystray or nil - } + }) mystatusbar[s].screen = s end -- }}} @@ -231,6 +270,7 @@ keybinding({ modkey, "Control" }, "Return", function () client.focus:swap(awful. keybinding({ modkey }, "o", awful.client.movetoscreen):add() keybinding({ modkey }, "Tab", awful.client.focus.history.previous):add() keybinding({ modkey }, "u", awful.client.urgent.jumpto):add() +keybinding({ modkey, "Shift" }, "r", function () client.focus:redraw() end):add() -- Layout manipulation keybinding({ modkey }, "l", function () awful.tag.incmwfact(0.05) end):add() @@ -253,7 +293,16 @@ keybinding({ modkey, "Ctrl" }, "i", function () if mypromptbox.text then mypromptbox.text = nil else - mypromptbox.text = "Class: " .. client.focus.class .. " Instance: ".. client.focus.instance + mypromptbox.text = nil + if client.focus.class then + mypromptbox.text = "Class: " .. client.focus.class .. " " + end + if client.focus.instance then + mypromptbox.text = mypromptbox.text .. "Instance: ".. client.focus.instance .. " " + end + if client.focus.role then + mypromptbox.text = mypromptbox.text .. "Role: ".. client.focus.role + end end end):add() @@ -369,6 +418,7 @@ function hook_manage(c) client.focus = c -- Check if the application should be floating. + -- OVERRIDDEN, SEE tiledapps BELOW local cls = c.class local inst = c.instance if floatapps[cls] then @@ -377,6 +427,9 @@ function hook_manage(c) c.floating = floatapps[inst] end + -- Override with tiledapps + c.floating = not (tiledapps[inst] or tiledapps[cls]) + -- Check application->screen/tag mappings. local target if apptags[cls] then @@ -391,6 +444,11 @@ function hook_manage(c) -- Honor size hints c.honorsizehints = true + + -- Maximise some + if maxapps[inst] or maxapps[cls] then + awful.client.maximize(c) + end end -- Hook function to execute when arranging the screen @@ -414,13 +472,13 @@ function hook_arrange(screen) --[[ local sel = client.focus if sel then - local c_c = sel.coords - local m_c = mouse.coords + local c_c = sel:coords() + 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 @@ -428,13 +486,77 @@ function hook_arrange(screen) end -- Hook called every second -function hook_timer () +function hook_timer() -- 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 laststring; + 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 = 'c'; + elseif status == 'Discarching' then + status = 'd'; + else + status = ''; + end + + 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.register(hook_focus) awful.hooks.unfocus.register(hook_unfocus) @@ -444,6 +566,8 @@ awful.hooks.manage.register(hook_manage) awful.hooks.mouseover.register(hook_mouseover) awful.hooks.arrange.register(hook_arrange) awful.hooks.timer.register(1, hook_timer) +awful.hooks.timer.register(120, hook_battery) +-- awful.hooks.timer.register(5, get_bat) -- }}} cmdmodkey = "Mod3" @@ -479,3 +603,5 @@ if screen.count() > 1 then else statusbar_highlight_focus = false end + +hook_battery()