summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--awesome/rc.lua443
-rw-r--r--awesome/theme/icon.pngbin0 -> 223 bytes
-rw-r--r--awesome/theme/submenu.pngbin0 -> 367 bytes
-rw-r--r--awesome/theme/theme.lua96
4 files changed, 539 insertions, 0 deletions
diff --git a/awesome/rc.lua b/awesome/rc.lua
new file mode 100644
index 0000000..6168ee4
--- /dev/null
+++ b/awesome/rc.lua
@@ -0,0 +1,443 @@
+-- David Robillard's Awesome Awesome Configuration
+
+-- Standard awesome library
+require("awful")
+require("awful.autofocus")
+require("awful.rules")
+-- Theme handling library
+require("beautiful")
+-- Notification library
+require("naughty")
+
+-- Widgets library
+require("wicked")
+require("vicious")
+
+-- Load Debian menu entries
+require("debian.menu")
+
+-- {{{ Variable definitions
+-- Themes define colours, icons, and wallpapers
+beautiful.init("/home/drobilla/.config/awesome/theme/theme.lua")
+
+-- This is used later as the default terminal and editor to run.
+terminal = "gnome-terminal"
+editor = os.getenv("EDITOR") or "editor"
+editor_cmd = terminal .. " -e " .. editor
+
+-- Modifier key
+modkey = "Mod4"
+
+-- Table of layouts to cover with awful.layout.inc, order matters.
+layouts =
+{
+ 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.spiral,
+-- awful.layout.suit.spiral.dwindle,
+ awful.layout.suit.max,
+-- awful.layout.suit.max.fullscreen,
+-- awful.layout.suit.magnifier,
+ awful.layout.suit.floating
+}
+-- }}}
+
+-- {{{ Tags
+-- Define tags table
+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, 10, 11, 12 }, s, layouts[1])
+end
+-- }}}
+
+-- {{{ Menu
+-- Create a laucher widget and a main menu
+myawesomemenu = {
+ { "Manual", terminal .. " -e man awesome" },
+ { "Configure", editor_cmd .. " " .. awful.util.getdir("config") .. "/rc.lua" },
+ { "Restart", awesome.restart },
+ { "Quit", awesome.quit }
+}
+
+mymainmenu = awful.menu({ items = { { "awesome", myawesomemenu, beautiful.awesome_icon },
+ { "Debian", debian.menu.Debian_menu.Debian },
+ { "open terminal", terminal }
+ }
+ })
+
+mylauncher = awful.widget.launcher({ image = image(beautiful.awesome_icon),
+ menu = mymainmenu })
+
+-- }}}
+
+-- {{{ Wibox
+
+-- Text clock
+--mytextclock = awful.widget.textclock({ align = "right" })
+mytextclock = awful.widget.textclock({ align = "right"},
+ "%a %d %b %H:%M",
+ 10)
+
+-- {{{ Reusable separator (space)
+separator = widget({ type = "textbox" })
+separator.text = " "
+-- }}}
+
+-- {{{ Reusable separator (bar)
+bar = widget({ type = "textbox" })
+bar.text = " : "
+-- }}}
+
+-- Temperature
+function get_temps()
+ local fh = io.popen("/home/drobilla/bin/temps")
+ local str = ""
+ for i in fh:lines() do
+ str = str .. i
+ end
+ io.close(fh)
+ return {str}
+end
+tempwidget = widget({ type = "textbox", name="tempwidget" })
+--tempwidget.text = " " .. get_temps()[0] .. " "
+vicious.register(tempwidget, get_temps, '$1', 4)
+
+--vicious.register(tempwidget, vicious.widgets.thermal, "$1?C", 20, "thermal_zone0", "proc")
+--vicious.register(tempwidget, vicious.widgets.thermal, "$1°", 20, { "coretemp.0", "core" })
+--cputempwidget = widget({ type = "textbox", name = "cputempwidget" })
+--vicious.register(cputempwidget, vicious.widgets.thermal, "$1°C", 20, { "coretemp.0", "core" })
+--hddtempwidget = widget({ type = 'textbox' })
+--vicious.register(hddtempwidget, vicious.widgets.hddtemp, "${/dev/sda} °C", refresh_delay)
+
+-- Network
+--ethwidget = widget({ type = "textbox" })
+--vicious.register(ethwidget, vicious.widgets.net,
+--'Eth: <span color="#F88">${eth0 down_kb}</span>' ..
+--'/<span color="#8F8">${eth0 up_kb}</span>', 3)
+ethwidget = widget({ type = "textbox" })
+vicious.register(ethwidget, vicious.widgets.net,
+'Eth <span color="#F88">${eth0 down_kb}</span>' ..
+'/<span color="#8F8">${eth0 up_kb}</span>', 4)
+wlanwidget = widget({ type = "textbox" })
+vicious.register(wlanwidget, vicious.widgets.net,
+'Wlan <span color="#F88">${wlan0 down_kb}</span>' ..
+'/<span color="#8F8">${wlan0 up_kb}</span>', 4)
+
+-- Systray
+mysystray = widget({ type = "systray" })
+
+-- Create a wibox for each screen and add it
+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, awful.tag.viewnext),
+ awful.button({ }, 5, awful.tag.viewprev)
+ )
+
+mytasklist = {}
+mytasklist.buttons = awful.util.table.join(
+ awful.button({ }, 1, function (c)
+ if not c:isvisible() then
+ awful.tag.viewonly(c:tags()[1])
+ end
+ client.focus = c
+ c:raise()
+ end),
+ awful.button({ }, 3, function ()
+ if instance then
+ instance:hide()
+ instance = nil
+ else
+ instance = awful.menu.clients({ 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))
+
+for s = 1, screen.count() do
+ -- CPU usage graph
+ cpuwidget = awful.widget.graph()
+ cpuwidget:set_width(32)
+ cpuwidget:set_background_color("#494B52")
+ cpuwidget:set_color("#0092E6")
+ vicious.cache(vicious.widgets.cpu)
+ vicious.register(cpuwidget, vicious.widgets.cpu, "$1", 1)
+
+ -- freqwidgets = {}
+ -- for c = 0, 3 do
+ -- freqwidgets[c] = awful.widget.progressbar()
+ -- freqwidgets[c]:set_width(4)
+ -- freqwidgets[c]:set_vertical(true)
+ -- freqwidgets[c]:set_value(0.0)
+ -- freqwidgets[c]:set_background_color('#525242')
+ -- freqwidgets[c]:set_color('#929252')
+ -- vicious.register(freqwidgets[c], vicious.widgets.cpufreq,
+ -- function (widget, args) freqwidgets[c]:set_value(args[2] / 2.7) end,
+ -- 1, "cpu" .. c)
+ -- end
+
+ -- Memory usage graph
+ memwidget = awful.widget.graph()
+ memwidget:set_width(32)
+ memwidget:set_background_color("#49524B")
+ memwidget:set_color("#AAF5D0")
+ vicious.cache(vicious.widgets.mem)
+ vicious.register(memwidget, vicious.widgets.mem, "$1", 1)
+
+ -- Create a promptbox for each screen
+ mypromptbox[s] = awful.widget.prompt({ layout = awful.widget.layout.horizontal.leftright })
+ -- 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.label.all, mytaglist.buttons)
+
+ -- Create a tasklist widget
+ mytasklist[s] = awful.widget.tasklist(function(c)
+ return awful.widget.tasklist.label.currenttags(c, s)
+ end, mytasklist.buttons)
+
+ -- Create the wibox
+ mywibox[s] = awful.wibox({ position = "top", screen = s })
+ -- Add widgets to the wibox - order matters
+ mywibox[s].widgets = {
+ {
+ mylauncher, separator,
+ cpuwidget, -- separator, freqwidgets[0], separator, freqwidgets[1], separator, freqwidgets[2], separator, freqwidgets[3],
+ separator, memwidget, separator,
+ bar,
+ tempwidget,
+ bar,
+ ethwidget,
+ bar,
+ wlanwidget, -- separator, ethwidget,
+ bar,
+ mytaglist[s],
+ bar,
+ mypromptbox[s],
+ layout = awful.widget.layout.horizontal.leftright
+ },
+ mylayoutbox[s],
+ separator,
+ mytextclock,
+ separator,
+ s == 1 and mysystray or nil,
+ bar,
+ mytasklist[s],
+ layout = awful.widget.layout.horizontal.rightleft
+ }
+end
+-- }}}
+
+-- {{{ 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)
+))
+-- }}}
+
+-- {{{ 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, }, "Page_Down",
+ function ()
+ awful.client.focus.byidx(1)
+ if client.focus then client.focus:raise() end
+ end),
+ awful.key({ modkey, }, "Page_Up",
+ function ()
+ awful.client.focus.byidx(-1)
+ if client.focus then client.focus:raise() end
+ end),
+
+ -- Layout manipulation
+ 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, }, "1", function () awful.screen.focus(2) end),
+ awful.key({ modkey, }, "2", function () awful.screen.focus(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),
+
+ -- Standard program
+ awful.key({ modkey, }, "Return", function () awful.util.spawn(terminal) end),
+ awful.key({ modkey, }, "\\", function () awful.util.spawn("nautilus -n --no-desktop /home/drobilla") 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, }, "Up", function () awful.tag.incnmaster( 1) end),
+ awful.key({ modkey, }, "Down", function () awful.tag.incnmaster(-1) end),
+ awful.key({ modkey, }, "Right", function () awful.tag.incncol( 1) end),
+ awful.key({ modkey, }, "Left", 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),
+
+ -- Run browser
+ awful.key({ modkey, "Control" }, "b", function () awful.util.spawn("sensible-browser") end),
+
+ -- Prompt
+ awful.key({ modkey, "Control" }, "r", function () mypromptbox[mouse.screen]:run() end),
+
+ -- Toggle bar
+ awful.key({ modkey }, "b",
+ function ()
+ if mywibox[mouse.screen].screen == nil then
+ mywibox[mouse.screen].screen = mouse.screen
+ else
+ mywibox[mouse.screen].screen = nil
+ end
+ end)
+)
+
+-- Client awful tagging: this is useful to tag some clients and then do stuff like move to tag on them
+clientkeys = awful.util.table.join(
+ awful.key({ modkey, "Control" }, "f", function (c) c.fullscreen = not c.fullscreen end),
+ awful.key({ modkey, "Control" }, "c", function (c) c:kill() end),
+ awful.key({ modkey, "Control" }, "l", awful.client.floating.toggle ),
+ awful.key({ modkey, "Control" }, "m", function (c) c:swap(awful.client.getmaster()) end),
+ awful.key({ modkey, }, "o", awful.client.movetoscreen ),
+ awful.key({ modkey, "Shift" }, "r", function (c) c:redraw() end),
+ awful.key({ modkey }, "t", awful.client.togglemarked),
+ awful.key({ modkey,}, "m",
+ function (c)
+ c.maximized_horizontal = not c.maximized_horizontal
+ c.maximized_vertical = not c.maximized_vertical
+ end)
+)
+
+-- Tag switching key bindings
+keys = {
+ [1] = "q", [2] = "w", [3] = "e", [4] = "r",
+ [5] = "a", [6] = "s", [7] = "d", [8] = "f",
+ [9] = "z", [10] = "x", [11] = "c", [12] = "v"
+}
+for i = 1, 12 do
+ keychar = keys[i]
+
+ globalkeys = awful.util.table.join(globalkeys,
+ -- Show only tag
+ awful.key({ modkey }, keychar,
+ function ()
+ local screen = mouse.screen
+ if tags[screen][i] then
+ awful.tag.viewonly(tags[screen][i])
+ end
+ end),
+
+ -- Move to tag
+ awful.key({ modkey, "Shift" }, keychar,
+ function ()
+ if client.focus and tags[client.focus.screen][i] then
+ awful.client.movetotag(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)
+
+-- {{{ Arrange signal handler
+for s = 1, screen.count() do screen[s]:add_signal("arrange", function ()
+ local clients = awful.client.visible(s)
+ local layout = awful.layout.getname(awful.layout.get(s))
+
+ for _, c in pairs(clients) do -- Floaters are always on top
+ if awful.client.floating.get(c) or layout == "floating"
+ then if not c.fullscreen then c.above = true end
+ else c.above = false end
+ end
+ end)
+end
+-- }}}
+
+-- }}}
diff --git a/awesome/theme/icon.png b/awesome/theme/icon.png
new file mode 100644
index 0000000..8f2dd73
--- /dev/null
+++ b/awesome/theme/icon.png
Binary files differ
diff --git a/awesome/theme/submenu.png b/awesome/theme/submenu.png
new file mode 100644
index 0000000..2b60e74
--- /dev/null
+++ b/awesome/theme/submenu.png
Binary files differ
diff --git a/awesome/theme/theme.lua b/awesome/theme/theme.lua
new file mode 100644
index 0000000..6dd591b
--- /dev/null
+++ b/awesome/theme/theme.lua
@@ -0,0 +1,96 @@
+---------------------------
+-- Default awesome theme --
+---------------------------
+
+theme = {}
+
+theme.font = "DejaVu Sans 10"
+
+theme.bg_normal = "#000000"
+theme.bg_focus = "#5A8F47"
+theme.bg_urgent = "#DFFF00" -- Chartreuse
+theme.bg_minimize = "#444444"
+
+theme.fg_normal = "#aaaaaa"
+theme.fg_focus = "#ffffff"
+theme.fg_urgent = "#ffffff"
+theme.fg_minimize = "#ffffff"
+
+theme.border_width = "2"
+theme.border_normal = "#000000"
+theme.border_focus = "#5A8F47"
+theme.border_marked = "#91231c"
+
+-- There are other variable sets
+-- overriding the default one when
+-- defined, the sets are:
+-- [taglist|tasklist]_[bg|fg]_[focus|urgent]
+-- titlebar_[bg|fg]_[normal|focus]
+-- tooltip_[font|opacity|fg_color|bg_color|border_width|border_color]
+-- mouse_finder_[color|timeout|animate_timeout|radius|factor]
+-- Example:
+--theme.taglist_bg_focus = "#ff0000"
+
+-- Display the taglist squares
+theme.taglist_squares_sel = "/usr/share/awesome/themes/default/taglist/squarefw.png"
+theme.taglist_squares_unsel = "/usr/share/awesome/themes/default/taglist/squarew.png"
+
+theme.tasklist_floating_icon = "/usr/share/awesome/themes/default/tasklist/floatingw.png"
+
+-- Variables set for theming the menu:
+-- menu_[bg|fg]_[normal|focus]
+-- menu_[border_color|border_width]
+theme.menu_submenu_icon = "/home/drobilla/.config/awesome/theme/submenu.png"
+theme.menu_height = "18"
+theme.menu_width = "128"
+
+-- You can add as many variables as
+-- you wish and access them by using
+-- beautiful.variable in your rc.lua
+--theme.bg_widget = "#cc0000"
+
+-- Define the image to load
+theme.titlebar_close_button_normal = "/usr/share/awesome/themes/default/titlebar/close_normal.png"
+theme.titlebar_close_button_focus = "/usr/share/awesome/themes/default/titlebar/close_focus.png"
+
+theme.titlebar_ontop_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/ontop_normal_inactive.png"
+theme.titlebar_ontop_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/ontop_focus_inactive.png"
+theme.titlebar_ontop_button_normal_active = "/usr/share/awesome/themes/default/titlebar/ontop_normal_active.png"
+theme.titlebar_ontop_button_focus_active = "/usr/share/awesome/themes/default/titlebar/ontop_focus_active.png"
+
+theme.titlebar_sticky_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/sticky_normal_inactive.png"
+theme.titlebar_sticky_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/sticky_focus_inactive.png"
+theme.titlebar_sticky_button_normal_active = "/usr/share/awesome/themes/default/titlebar/sticky_normal_active.png"
+theme.titlebar_sticky_button_focus_active = "/usr/share/awesome/themes/default/titlebar/sticky_focus_active.png"
+
+theme.titlebar_floating_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/floating_normal_inactive.png"
+theme.titlebar_floating_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/floating_focus_inactive.png"
+theme.titlebar_floating_button_normal_active = "/usr/share/awesome/themes/default/titlebar/floating_normal_active.png"
+theme.titlebar_floating_button_focus_active = "/usr/share/awesome/themes/default/titlebar/floating_focus_active.png"
+
+theme.titlebar_maximized_button_normal_inactive = "/usr/share/awesome/themes/default/titlebar/maximized_normal_inactive.png"
+theme.titlebar_maximized_button_focus_inactive = "/usr/share/awesome/themes/default/titlebar/maximized_focus_inactive.png"
+theme.titlebar_maximized_button_normal_active = "/usr/share/awesome/themes/default/titlebar/maximized_normal_active.png"
+theme.titlebar_maximized_button_focus_active = "/usr/share/awesome/themes/default/titlebar/maximized_focus_active.png"
+
+-- You can use your own command to set your wallpaper
+theme.wallpaper_cmd = { "xsetroot -solid black" }
+
+-- You can use your own layout icons like this:
+theme.layout_fairh = "/usr/share/awesome/themes/default/layouts/fairhw.png"
+theme.layout_fairv = "/usr/share/awesome/themes/default/layouts/fairvw.png"
+theme.layout_floating = "/usr/share/awesome/themes/default/layouts/floatingw.png"
+theme.layout_magnifier = "/usr/share/awesome/themes/default/layouts/magnifierw.png"
+theme.layout_max = "/usr/share/awesome/themes/default/layouts/maxw.png"
+theme.layout_fullscreen = "/usr/share/awesome/themes/default/layouts/fullscreenw.png"
+theme.layout_tilebottom = "/usr/share/awesome/themes/default/layouts/tilebottomw.png"
+theme.layout_tileleft = "/usr/share/awesome/themes/default/layouts/tileleftw.png"
+theme.layout_tile = "/usr/share/awesome/themes/default/layouts/tilew.png"
+theme.layout_tiletop = "/usr/share/awesome/themes/default/layouts/tiletopw.png"
+theme.layout_spiral = "/usr/share/awesome/themes/default/layouts/spiralw.png"
+theme.layout_dwindle = "/usr/share/awesome/themes/default/layouts/dwindlew.png"
+
+theme.awesome_icon = "/home/drobilla/.config/awesome/theme/icon.png"
+
+return theme
+-- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80