]> git.madduck.net Git - etc/awesome.git/commitdiff

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

All patches and comments are welcome. Please squash your changes to logical commits before using git-format-patch and git-send-email to patches@git.madduck.net. If you'd read over the Git project's submission guidelines and adhered to them, I'd be especially grateful.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

Add '.config/awesome/lain/' from commit 'fc6e880da40668c6e9bd9da3786ff2fcae519c75'
authormartin f. krafft <madduck@madduck.net>
Thu, 6 Apr 2017 09:01:06 +0000 (11:01 +0200)
committermartin f. krafft <madduck@madduck.net>
Thu, 6 Apr 2017 09:01:06 +0000 (11:01 +0200)
git-subtree-dir: .config/awesome/lain
git-subtree-mainline: 40798583795b58e496db607d9d23324b4a7ae09c
git-subtree-split: fc6e880da40668c6e9bd9da3786ff2fcae519c75

117 files changed:
.config/awesome/lain/.gitmodules [moved from .gitmodules with 100% similarity]
.config/awesome/lain/ISSUE_TEMPLATE.md [moved from ISSUE_TEMPLATE.md with 100% similarity]
.config/awesome/lain/LICENSE [moved from LICENSE with 100% similarity]
.config/awesome/lain/README.rst [moved from README.rst with 100% similarity]
.config/awesome/lain/helpers.lua [moved from helpers.lua with 100% similarity]
.config/awesome/lain/icons/cal/white/1.png [moved from icons/cal/white/1.png with 100% similarity]
.config/awesome/lain/icons/cal/white/10.png [moved from icons/cal/white/10.png with 100% similarity]
.config/awesome/lain/icons/cal/white/11.png [moved from icons/cal/white/11.png with 100% similarity]
.config/awesome/lain/icons/cal/white/12.png [moved from icons/cal/white/12.png with 100% similarity]
.config/awesome/lain/icons/cal/white/13.png [moved from icons/cal/white/13.png with 100% similarity]
.config/awesome/lain/icons/cal/white/14.png [moved from icons/cal/white/14.png with 100% similarity]
.config/awesome/lain/icons/cal/white/15.png [moved from icons/cal/white/15.png with 100% similarity]
.config/awesome/lain/icons/cal/white/16.png [moved from icons/cal/white/16.png with 100% similarity]
.config/awesome/lain/icons/cal/white/17.png [moved from icons/cal/white/17.png with 100% similarity]
.config/awesome/lain/icons/cal/white/18.png [moved from icons/cal/white/18.png with 100% similarity]
.config/awesome/lain/icons/cal/white/19.png [moved from icons/cal/white/19.png with 100% similarity]
.config/awesome/lain/icons/cal/white/2.png [moved from icons/cal/white/2.png with 100% similarity]
.config/awesome/lain/icons/cal/white/20.png [moved from icons/cal/white/20.png with 100% similarity]
.config/awesome/lain/icons/cal/white/21.png [moved from icons/cal/white/21.png with 100% similarity]
.config/awesome/lain/icons/cal/white/22.png [moved from icons/cal/white/22.png with 100% similarity]
.config/awesome/lain/icons/cal/white/23.png [moved from icons/cal/white/23.png with 100% similarity]
.config/awesome/lain/icons/cal/white/24.png [moved from icons/cal/white/24.png with 100% similarity]
.config/awesome/lain/icons/cal/white/25.png [moved from icons/cal/white/25.png with 100% similarity]
.config/awesome/lain/icons/cal/white/26.png [moved from icons/cal/white/26.png with 100% similarity]
.config/awesome/lain/icons/cal/white/27.png [moved from icons/cal/white/27.png with 100% similarity]
.config/awesome/lain/icons/cal/white/28.png [moved from icons/cal/white/28.png with 100% similarity]
.config/awesome/lain/icons/cal/white/29.png [moved from icons/cal/white/29.png with 100% similarity]
.config/awesome/lain/icons/cal/white/3.png [moved from icons/cal/white/3.png with 100% similarity]
.config/awesome/lain/icons/cal/white/30.png [moved from icons/cal/white/30.png with 100% similarity]
.config/awesome/lain/icons/cal/white/31.png [moved from icons/cal/white/31.png with 100% similarity]
.config/awesome/lain/icons/cal/white/4.png [moved from icons/cal/white/4.png with 100% similarity]
.config/awesome/lain/icons/cal/white/5.png [moved from icons/cal/white/5.png with 100% similarity]
.config/awesome/lain/icons/cal/white/6.png [moved from icons/cal/white/6.png with 100% similarity]
.config/awesome/lain/icons/cal/white/7.png [moved from icons/cal/white/7.png with 100% similarity]
.config/awesome/lain/icons/cal/white/8.png [moved from icons/cal/white/8.png with 100% similarity]
.config/awesome/lain/icons/cal/white/9.png [moved from icons/cal/white/9.png with 100% similarity]
.config/awesome/lain/icons/layout/default/cascade.png [moved from icons/layout/default/cascade.png with 100% similarity]
.config/awesome/lain/icons/layout/default/cascadetile.png [moved from icons/layout/default/cascadetile.png with 100% similarity]
.config/awesome/lain/icons/layout/default/cascadetilew.png [moved from icons/layout/default/cascadetilew.png with 100% similarity]
.config/awesome/lain/icons/layout/default/cascadew.png [moved from icons/layout/default/cascadew.png with 100% similarity]
.config/awesome/lain/icons/layout/default/centerfair.png [moved from icons/layout/default/centerfair.png with 100% similarity]
.config/awesome/lain/icons/layout/default/centerfairw.png [moved from icons/layout/default/centerfairw.png with 100% similarity]
.config/awesome/lain/icons/layout/default/centerwork.png [moved from icons/layout/default/centerwork.png with 100% similarity]
.config/awesome/lain/icons/layout/default/centerworkh.png [moved from icons/layout/default/centerworkh.png with 100% similarity]
.config/awesome/lain/icons/layout/default/centerworkhw.png [moved from icons/layout/default/centerworkhw.png with 100% similarity]
.config/awesome/lain/icons/layout/default/centerworkw.png [moved from icons/layout/default/centerworkw.png with 100% similarity]
.config/awesome/lain/icons/layout/default/termfair.png [moved from icons/layout/default/termfair.png with 100% similarity]
.config/awesome/lain/icons/layout/default/termfairw.png [moved from icons/layout/default/termfairw.png with 100% similarity]
.config/awesome/lain/icons/layout/zenburn/cascade.png [moved from icons/layout/zenburn/cascade.png with 100% similarity]
.config/awesome/lain/icons/layout/zenburn/cascadetile.png [moved from icons/layout/zenburn/cascadetile.png with 100% similarity]
.config/awesome/lain/icons/layout/zenburn/centerfair.png [moved from icons/layout/zenburn/centerfair.png with 100% similarity]
.config/awesome/lain/icons/layout/zenburn/centerwork.png [moved from icons/layout/zenburn/centerwork.png with 100% similarity]
.config/awesome/lain/icons/layout/zenburn/centerworkh.png [moved from icons/layout/zenburn/centerworkh.png with 100% similarity]
.config/awesome/lain/icons/layout/zenburn/termfair.png [moved from icons/layout/zenburn/termfair.png with 100% similarity]
.config/awesome/lain/icons/mail.png [moved from icons/mail.png with 100% similarity]
.config/awesome/lain/icons/no_net.png [moved from icons/no_net.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/01d.png [moved from icons/openweathermap/01d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/01n.png [moved from icons/openweathermap/01n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/02d.png [moved from icons/openweathermap/02d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/02n.png [moved from icons/openweathermap/02n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/03d.png [moved from icons/openweathermap/03d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/03n.png [moved from icons/openweathermap/03n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/04d.png [moved from icons/openweathermap/04d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/04n.png [moved from icons/openweathermap/04n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/09d.png [moved from icons/openweathermap/09d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/09n.png [moved from icons/openweathermap/09n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/10d.png [moved from icons/openweathermap/10d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/10n.png [moved from icons/openweathermap/10n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/11d.png [moved from icons/openweathermap/11d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/11n.png [moved from icons/openweathermap/11n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/13d.png [moved from icons/openweathermap/13d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/13n.png [moved from icons/openweathermap/13n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/50d.png [moved from icons/openweathermap/50d.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/50n.png [moved from icons/openweathermap/50n.png with 100% similarity]
.config/awesome/lain/icons/openweathermap/README.md [moved from icons/openweathermap/README.md with 100% similarity]
.config/awesome/lain/icons/openweathermap/na.png [moved from icons/openweathermap/na.png with 100% similarity]
.config/awesome/lain/icons/taskwarrior.png [moved from icons/taskwarrior.png with 100% similarity]
.config/awesome/lain/init.lua [moved from init.lua with 100% similarity]
.config/awesome/lain/lain-git.rockspec [moved from lain-git.rockspec with 100% similarity]
.config/awesome/lain/layout/cascade.lua [moved from layout/cascade.lua with 100% similarity]
.config/awesome/lain/layout/centerwork.lua [moved from layout/centerwork.lua with 100% similarity]
.config/awesome/lain/layout/init.lua [moved from layout/init.lua with 100% similarity]
.config/awesome/lain/layout/termfair.lua [moved from layout/termfair.lua with 100% similarity]
.config/awesome/lain/scripts/dfs [moved from scripts/dfs with 100% similarity]
.config/awesome/lain/util/dkjson.lua [moved from util/dkjson.lua with 100% similarity]
.config/awesome/lain/util/init.lua [moved from util/init.lua with 100% similarity]
.config/awesome/lain/util/markup.lua [moved from util/markup.lua with 100% similarity]
.config/awesome/lain/util/quake.lua [moved from util/quake.lua with 100% similarity]
.config/awesome/lain/util/separators.lua [moved from util/separators.lua with 100% similarity]
.config/awesome/lain/widget/alsa.lua [moved from widget/alsa.lua with 100% similarity]
.config/awesome/lain/widget/alsabar.lua [moved from widget/alsabar.lua with 100% similarity]
.config/awesome/lain/widget/bat.lua [moved from widget/bat.lua with 100% similarity]
.config/awesome/lain/widget/calendar.lua [moved from widget/calendar.lua with 100% similarity]
.config/awesome/lain/widget/contrib/gpmdp.lua [moved from widget/contrib/gpmdp.lua with 100% similarity]
.config/awesome/lain/widget/contrib/init.lua [moved from widget/contrib/init.lua with 100% similarity]
.config/awesome/lain/widget/contrib/kbdlayout.lua [moved from widget/contrib/kbdlayout.lua with 100% similarity]
.config/awesome/lain/widget/contrib/moc.lua [moved from widget/contrib/moc.lua with 100% similarity]
.config/awesome/lain/widget/contrib/redshift.lua [moved from widget/contrib/redshift.lua with 100% similarity]
.config/awesome/lain/widget/contrib/task.lua [moved from widget/contrib/task.lua with 100% similarity]
.config/awesome/lain/widget/contrib/tpbat/init.lua [moved from widget/contrib/tpbat/init.lua with 100% similarity]
.config/awesome/lain/widget/contrib/tpbat/smapi.lua [moved from widget/contrib/tpbat/smapi.lua with 100% similarity]
.config/awesome/lain/widget/cpu.lua [moved from widget/cpu.lua with 100% similarity]
.config/awesome/lain/widget/fs.lua [moved from widget/fs.lua with 100% similarity]
.config/awesome/lain/widget/imap.lua [moved from widget/imap.lua with 100% similarity]
.config/awesome/lain/widget/init.lua [moved from widget/init.lua with 100% similarity]
.config/awesome/lain/widget/mem.lua [moved from widget/mem.lua with 100% similarity]
.config/awesome/lain/widget/mpd.lua [moved from widget/mpd.lua with 100% similarity]
.config/awesome/lain/widget/net.lua [moved from widget/net.lua with 100% similarity]
.config/awesome/lain/widget/pulseaudio.lua [moved from widget/pulseaudio.lua with 100% similarity]
.config/awesome/lain/widget/pulsebar.lua [moved from widget/pulsebar.lua with 100% similarity]
.config/awesome/lain/widget/sysload.lua [moved from widget/sysload.lua with 100% similarity]
.config/awesome/lain/widget/temp.lua [moved from widget/temp.lua with 100% similarity]
.config/awesome/lain/widget/watch.lua [moved from widget/watch.lua with 100% similarity]
.config/awesome/lain/widget/weather.lua [moved from widget/weather.lua with 100% similarity]
.config/awesome/lain/wiki [moved from wiki with 100% similarity]
.config/awesome/rc.lua [new file with mode: 0644]
.xsession.d/50-awesomewm [new file with mode: 0644]

similarity index 100%
rename from .gitmodules
rename to .config/awesome/lain/.gitmodules
similarity index 100%
rename from LICENSE
rename to .config/awesome/lain/LICENSE
similarity index 100%
rename from README.rst
rename to .config/awesome/lain/README.rst
similarity index 100%
rename from helpers.lua
rename to .config/awesome/lain/helpers.lua
similarity index 100%
rename from init.lua
rename to .config/awesome/lain/init.lua
similarity index 100%
rename from scripts/dfs
rename to .config/awesome/lain/scripts/dfs
similarity index 100%
rename from wiki
rename to .config/awesome/lain/wiki
diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua
new file mode 100644 (file)
index 0000000..45263d4
--- /dev/null
@@ -0,0 +1,748 @@
+-- {{{ Imports
+-- Standard awesome library
+local gears = require("gears")
+local awful = require("awful")
+require("awful.autofocus")
+-- Widget and layout library
+local wibox = require("wibox")
+-- Theme handling library
+local beautiful = require("beautiful")
+-- Notification library
+local naughty = require("naughty")
+local menubar = require("menubar")
+local hotkeys_popup = require("awful.hotkeys_popup").widget
+local lain = require("lain")
+local dkjson = require("lain.util").dkjson
+local math = require("math")
+-- }}}
+
+-- {{{ 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.connect_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 = tostring(err) })
+        in_error = false
+    end)
+end
+-- }}}
+
+-- {{{ Variable definitions
+-- Themes define colours, icons, and wallpapers
+beautiful.init(awful.util.get_themes_dir() .. "default/theme.lua")
+
+-- This is used later as the default terminal and editor to run.
+terminal = "x-terminal-emulator"
+editor = "sensible-editor"
+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.
+modkey = "Mod4"
+cmdkey = "Mod3"
+
+-- Table of layouts to cover with awful.layout.inc, order matters.
+awful.layout.layouts = {
+    awful.layout.suit.fair,
+    awful.layout.suit.tile,
+    -- awful.layout.suit.tile.left,
+    -- awful.layout.suit.tile.bottom,
+    awful.layout.suit.tile.top,
+    -- 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.corner.nw,
+    -- awful.layout.suit.corner.ne,
+    -- awful.layout.suit.corner.sw,
+    -- awful.layout.suit.corner.se,
+    awful.layout.suit.floating,
+}
+
+layout_default = awful.layout.layouts[1]
+layout_tiled = awful.layout.layouts[2]
+layout_maximised = awful.layout.layouts[4]
+layout_floating = awful.layout.layouts[5]
+-- }}}
+
+-- {{{ Helper functions
+local function client_menu_toggle_fn()
+    local instance = nil
+
+    return function ()
+        if instance and instance.wibox.visible then
+            instance:hide()
+            instance = nil
+        else
+            instance = awful.menu.clients({ theme = { width = 250 } })
+        end
+    end
+end
+
+local function sorted_pairs(t, f)
+    local a = {}
+    for n in pairs(t) do table.insert(a, n) end
+    table.sort(a, f)
+    local i = 0      -- iterator variable
+    local iter = function ()   -- iterator function
+        i = i + 1
+        if a[i] == nil then return nil
+        else return a[i], t[a[i]]
+        end
+    end
+    return iter
+end
+
+local function print_table(tbl, indent)
+    if not indent then indent = 0 end
+    for k, v in pairs(tbl) do
+        formatting = string.rep("  ", indent) .. k .. ": "
+        if type(v) == "table" then
+            print(formatting)
+            print_table(v, indent+1)
+        else
+            print(formatting .. tostring(v))
+        end
+    end
+end
+
+local lain_bat = lain.widgets.bat({
+    batteries = {"BAT0", "BAT1"},
+    settings = function()
+        local delim = "↓"
+        if bat_now.status == "Charging" then delim = "↑"
+        elseif bat_now.status == "Unknown" then delim = "٭" end
+        widget:set_text(bat_now.perc .. "% " .. delim .. " " .. bat_now.time)
+    end,
+})
+
+local function poloniex_price(output, pair, prec)
+    local xc, pos, err = dkjson.decode(output, 1, nil)
+    if not prec then prec = 4 end
+    val = (xc and xc[pair]["last"]) or 0
+    val = math.floor(val*10^prec+0.5)/10^prec
+    return (not err and val) or "n/a"
+end
+
+local eth_widget = lain.widgets.abase({
+    cmd = "curl -m5 -s 'https://poloniex.com/public?command=returnTicker'",
+    timeout = 600,
+    settings = function()
+        widget:set_text(poloniex_price(output, 'BTC_ETH') .. " Ƀ/Ξ")
+    end
+})
+
+local function coindesk_price(output, base, prec)
+    local xc, pos, err = dkjson.decode(output, 1, nil)
+    if not prec then prec = 4 end
+    val = (xc and xc["bpi"][base]["rate_float"]) or 0
+    val = math.floor(val*10^prec+0.5)/10^prec
+    return (not err and val) or "n/a"
+end
+
+local btc_widget = lain.widgets.abase({
+    cmd = "curl -m5 -Ls 'https://api.coindesk.com/v1/bpi/currentprice/EUR.json'",
+    timeout = 600,
+    settings = function()
+        widget:set_text(coindesk_price(output, "EUR", 2) .. " €/Ƀ")
+    end
+})
+
+-- }}}
+
+-- {{{ Menu
+-- Create a launcher widget and a main menu
+myawesomemenu = {
+   { "hotkeys", function() return false, hotkeys_popup.show_help end},
+   { "manual", terminal .. " -e man awesome" },
+   { "edit config", editor_cmd .. " " .. awesome.conffile },
+   { "restart", awesome.restart },
+   { "quit", awesome.quit }
+}
+
+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
+local spacer = wibox.widget.textbox()
+spacer:set_text(' | ')
+-- Create a textclock widget
+mytextclock = wibox.widget.textclock("%a %d %b %H:%M:%S", 1)
+
+-- Create a wibox for each screen and add it
+mywibox = {}
+mypromptbox = {}
+mylayoutbox = {}
+mytaglist = {}
+mytaglist.buttons = awful.util.table.join(
+                    awful.button({ }, 1, function(t) t:view_only() end),
+                    awful.button({ modkey }, 1, function(t)
+                                              if client.focus then
+                                                  client.focus:move_to_tag(t)
+                                              end
+                                          end),
+                    awful.button({ }, 3, awful.tag.viewtoggle),
+                    awful.button({ modkey }, 3, function(t)
+                                              if client.focus then
+                                                  client.focus:toggle_tag(t)
+                                              end
+                                          end),
+                    awful.button({ }, 4, function(t) awful.tag.viewnext(t.screen) end),
+                    awful.button({ }, 5, function(t) awful.tag.viewprev(t.screen) end)
+                )
+
+mytasklist = {}
+mytasklist.buttons = awful.util.table.join(
+                     awful.button({ }, 1, function (c)
+                                              if c == client.focus then
+                                                  -- I don't like click-minimising
+                                                  -- c.minimized = true
+                                              else
+                                                  -- Without this, the following
+                                                  -- :isvisible() makes no sense
+                                                  c.minimized = false
+                                                  if not c:isvisible() and c.first_tag then
+                                                      c.first_tag:view_only()
+                                                  end
+                                                  -- This will also un-minimize
+                                                  -- the client, if needed
+                                                  client.focus = c
+                                                  c:raise()
+                                              end
+                                          end),
+                     awful.button({ }, 3, client_menu_toggle_fn()),
+                     awful.button({ }, 4, function ()
+                                              awful.client.focus.byidx(1)
+                                          end),
+                     awful.button({ }, 5, function ()
+                                              awful.client.focus.byidx(-1)
+                                          end))
+-- }}}
+
+-- {{{ Tags
+tags = {}
+tags.config = {}
+tags.config["main"] = {
+    t1 = { layout = layout_default, selected = true },
+    t2 = { layout = layout_default },
+    t3 = { layout = layout_tiled },
+    t4 = { layout = layout_tiled },
+    t5 = { layout = layout_tiled },
+    t6 = { layout = layout_floating },
+    t7 = { layout = layout_maximised },
+    t8 = { layout = layout_maximised },
+    t9 = { layout = layout_maximised },
+}
+tags.config["aux"] = {
+    t1 = { layout = layout_default, selected = true },
+    t2 = { layout = layout_default },
+    t3 = { layout = layout_tiled },
+    t4 = { layout = layout_floating },
+    t5 = { layout = layout_floating },
+    t6 = { layout = layout_floating },
+    t7 = { layout = layout_floating },
+    t8 = { layout = layout_floating },
+    t9 = { layout = layout_maximised },
+}
+
+screentags = {}
+screentags[1] = tags.config["main"]
+if screen.count() == 2 then -- aux screen is on the right
+  screentags[2] = tags.config["aux"]
+elseif screen.count() == 3 then -- main screen is still #1 in the middle
+  screentags[2] = tags.config["aux"]
+  screentags[3] = tags.config["aux"]
+end
+
+awful.screen.connect_for_each_screen(function(s)
+    -- Wallpaper
+    --DISABLED--if beautiful.wallpaper then
+    --DISABLED--    local wallpaper = beautiful.wallpaper
+    --DISABLED--    -- If wallpaper is a function, call it with the screen
+    --DISABLED--    if type(wallpaper) == "function" then
+    --DISABLED--        wallpaper = wallpaper(s)
+    --DISABLED--    end
+    --DISABLED--    gears.wallpaper.maximized(wallpaper, s, true)
+    --DISABLED--end
+
+    if not tags[s.index] then
+        tags[s.index] = {}
+    end
+    for n,p in sorted_pairs(screentags[s.index]) do
+        p["screen"] = s
+        n = string.sub(n, 2) -- remove leading 't' needed for syntax in table
+        table.insert(tags[s.index], awful.tag.add(n, p))
+    end
+
+    -- 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.
+    mylayoutbox[s] = awful.widget.layoutbox(s)
+    mylayoutbox[s]:buttons(awful.util.table.join(
+                           awful.button({ }, 1, function () awful.layout.inc( 1) end),
+                           awful.button({ }, 3, function () awful.layout.inc(-1) end),
+                           awful.button({ }, 4, function () awful.layout.inc( 1) end),
+                           awful.button({ }, 5, function () awful.layout.inc(-1) end)))
+    -- Create a taglist widget
+    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)
+
+    -- Create the wibox
+    mywibox[s] = awful.wibar({ position = "top", screen = s })
+
+    -- Add widgets to the wibox
+    mywibox[s]:setup {
+        layout = wibox.layout.align.horizontal,
+        { -- Left widgets
+            layout = wibox.layout.fixed.horizontal,
+            -- mylauncher,
+            mytaglist[s],
+            mypromptbox[s],
+        },
+        mytasklist[s], -- Middle widget
+        { -- Right widgets
+            layout = wibox.layout.fixed.horizontal,
+            mykeyboardlayout,
+            wibox.widget.systray(),
+            btc_widget,
+            spacer,
+            lain_bat.widget,
+            spacer,
+            mytextclock,
+            mylayoutbox[s],
+        },
+    }
+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,           }, "s",      hotkeys_popup.show_help,
+              {description="show help", group="awesome"}),
+    awful.key({ modkey,           }, "Left",   awful.tag.viewprev,
+              {description = "view previous", group = "tag"}),
+    awful.key({ modkey,           }, "Right",  awful.tag.viewnext,
+              {description = "view next", group = "tag"}),
+    awful.key({ modkey,           }, "Escape", awful.tag.history.restore,
+              {description = "go back", group = "tag"}),
+
+    awful.key({ modkey,           }, "k",
+        function ()
+            awful.client.focus.byidx( 1)
+        end,
+        {description = "focus next by index", group = "client"}
+    ),
+    awful.key({ modkey,           }, "j",
+        function ()
+            awful.client.focus.byidx(-1)
+        end,
+        {description = "focus previous by index", group = "client"}
+    ),
+    awful.key({ modkey,           }, "w", function () mymainmenu:show() end,
+              {description = "show main menu", group = "awesome"}),
+
+    -- Layout manipulation
+    awful.key({ modkey, "Shift"   }, "k", function () awful.client.swap.byidx(  1)    end,
+              {description = "swap with next client by index", group = "client"}),
+    awful.key({ modkey, "Shift"   }, "j", function () awful.client.swap.byidx( -1)    end,
+              {description = "swap with previous client by index", group = "client"}),
+    awful.key({ modkey, "Control" }, "k", function () awful.screen.focus_relative( 1) end,
+              {description = "focus the next screen", group = "screen"}),
+    awful.key({ modkey, "Control" }, "j", function () awful.screen.focus_relative(-1) end,
+              {description = "focus the previous screen", group = "screen"}),
+    awful.key({ modkey,           }, "u", awful.client.urgent.jumpto,
+              {description = "jump to urgent client", group = "client"}),
+    awful.key({ modkey,           }, "Tab",
+        function ()
+            awful.client.focus.history.previous()
+            if client.focus then
+                client.focus:raise()
+            end
+        end,
+        {description = "go back", group = "client"}),
+
+    -- Standard program
+    awful.key({ modkey,           }, "Return", function () awful.spawn(terminal) end,
+              {description = "open a terminal", group = "launcher"}),
+    awful.key({ modkey, "Control" }, "r", awesome.restart,
+              {description = "reload awesome", group = "awesome"}),
+    awful.key({ modkey, "Shift"   }, "q", awesome.quit,
+              {description = "quit awesome", group = "awesome"}),
+
+    awful.key({ modkey,           }, "l",     function () awful.tag.incmwfact( 0.05)          end,
+              {description = "increase master width factor", group = "layout"}),
+    awful.key({ modkey,           }, "h",     function () awful.tag.incmwfact(-0.05)          end,
+              {description = "decrease master width factor", group = "layout"}),
+    awful.key({ modkey, "Shift"   }, "h",     function () awful.tag.incnmaster( 1, nil, true) end,
+              {description = "increase the number of master clients", group = "layout"}),
+    awful.key({ modkey, "Shift"   }, "l",     function () awful.tag.incnmaster(-1, nil, true) end,
+              {description = "decrease the number of master clients", group = "layout"}),
+    awful.key({ modkey, "Control" }, "h",     function () awful.tag.incncol( 1, nil, true)    end,
+              {description = "increase the number of columns", group = "layout"}),
+    awful.key({ modkey, "Control" }, "l",     function () awful.tag.incncol(-1, nil, true)    end,
+              {description = "decrease the number of columns", group = "layout"}),
+    awful.key({ modkey,           }, "space", function () awful.layout.inc( 1)                end,
+              {description = "select next", group = "layout"}),
+    awful.key({ modkey, "Shift"   }, "space", function () awful.layout.inc(-1)                end,
+              {description = "select previous", group = "layout"}),
+
+    awful.key({ modkey, "Control" }, "n",
+              function ()
+                  local c = awful.client.restore()
+                  -- Focus restored client
+                  if c then
+                      client.focus = c
+                      c:raise()
+                  end
+              end,
+              {description = "restore minimized", group = "client"}),
+
+    -- Prompt
+    awful.key({ modkey },            "r",     function () mypromptbox[awful.screen.focused()]:run() end,
+              {description = "run prompt", group = "launcher"}),
+
+    awful.key({ modkey }, "x",
+              function ()
+                  awful.prompt.run({ prompt = "Run Lua code: " },
+                  mypromptbox[awful.screen.focused()].widget,
+                  awful.util.eval, nil,
+                  awful.util.get_cache_dir() .. "/history_eval")
+              end,
+              {description = "lua execute prompt", group = "awesome"}),
+    -- Menubar
+    awful.key({ modkey }, "p", function() menubar.show() end,
+              {description = "show the menubar", group = "launcher"})
+)
+
+clientkeys = awful.util.table.join(
+    awful.key({ modkey,           }, "f",
+        function (c)
+            c.fullscreen = not c.fullscreen
+            c:raise()
+        end,
+        {description = "toggle fullscreen", group = "client"}),
+    awful.key({ modkey, "Shift"   }, "c",      function (c) c:kill()                         end,
+              {description = "close", group = "client"}),
+    awful.key({ modkey, "Control" }, "space",  awful.client.floating.toggle                     ,
+              {description = "toggle floating", group = "client"}),
+    awful.key({ modkey, "Control" }, "Return", function (c) c:swap(awful.client.getmaster()) end,
+              {description = "move to master", group = "client"}),
+    awful.key({ modkey,           }, "o",      function (c) c:move_to_screen()               end,
+              {description = "move to screen", group = "client"}),
+    awful.key({ modkey,           }, "t",      function (c) c.ontop = not c.ontop            end,
+              {description = "toggle keep on top", group = "client"}),
+    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 ,
+        {description = "minimize", group = "client"}),
+    awful.key({ modkey,           }, "m",
+        function (c)
+            c.maximized = not c.maximized
+            c:raise()
+        end ,
+        {description = "maximize", group = "client"})
+)
+
+-- 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 = awful.screen.focused()
+                        local tag = screen.tags[i]
+                        if tag then
+                           tag:view_only()
+                        end
+                  end,
+                  {description = "view tag #"..i, group = "tag"}),
+        -- Toggle tag.
+        awful.key({ modkey, "Control" }, "#" .. i + 9,
+                  function ()
+                      local screen = awful.screen.focused()
+                      local tag = screen.tags[i]
+                      if tag then
+                         awful.tag.viewtoggle(tag)
+                      end
+                  end,
+                  {description = "toggle tag #" .. i, group = "tag"}),
+        -- Move client to tag.
+        awful.key({ modkey, "Shift" }, "#" .. i + 9,
+                  function ()
+                      if client.focus then
+                          local tag = client.focus.screen.tags[i]
+                          if tag then
+                              client.focus:move_to_tag(tag)
+                          end
+                     end
+                  end,
+                  {description = "move focused client to tag #"..i, group = "tag"}),
+        -- Toggle tag on focused client.
+        awful.key({ modkey, "Control", "Shift" }, "#" .. i + 9,
+                  function ()
+                      if client.focus then
+                          local tag = client.focus.screen.tags[i]
+                          if tag then
+                              client.focus:toggle_tag(tag)
+                          end
+                      end
+                  end,
+                  {description = "toggle focused client on tag #" .. i, group = "tag"})
+    )
+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))
+
+-- misc apps
+globalkeys = awful.util.table.join(globalkeys,
+awful.key({ cmdkey }, "n", function () awful.spawn("firefox") end),
+awful.key({ cmdkey }, "m", function () awful.spawn("chromium --enable-remote-extensions") end),
+awful.key({ cmdkey }, "y", function () awful.spawn(terminal .. " -e python") end),
+awful.key({ cmdkey }, "c", function () awful.spawn("thunderbird") end),
+awful.key({ cmdkey }, "r", function () mypromptbox[mouse.screen]:run() end),
+awful.key({ cmdkey }, "g", function () awful.spawn("gscan2pdf") end),
+awful.key({ cmdkey }, "v", function () awful.spawn("virt-manager") end),
+awful.key({ cmdkey }, "l", function () awful.spawn("libreoffice") end),
+awful.key({ cmdkey }, "f", function () awful.spawn("thunar") end),
+awful.key({ cmdkey }, "i", function () awful.spawn(terminal .. " -name irc -e env MOSH_TITLE_NOPREFIX=true mosh -4 -- irc-host tmux new -DAs irc irssi") end),
+awful.key({ cmdkey }, "x", function () awful.spawn.with_shell("/sbin/start-stop-daemon --start --background --exec /usr/bin/xscreensaver -- -no-capture-stderr; sleep 2; xscreensaver-command -lock") end),
+awful.key({ cmdkey, "Shift" }, "x", function () awful.spawn("xscreensaver-command -exit") end),
+
+-- function keys
+awful.key(nil, "XF86ScreenSaver", function () awful.spawn("xset dpms force off") end),
+awful.key(nil, "XF86AudioMute", function () awful.spawn("pactl set-sink-mute 0 toggle") end),
+awful.key({ cmdkey }, "End", function () awful.spawn("pactl set-sink-mute 0 toggle") end),
+awful.key(nil, "XF86AudioLowerVolume", function () awful.spawn("pactl set-sink-volume 0 -2%") end),
+awful.key({ cmdkey }, "Next", function () awful.spawn("pactl set-sink-volume 0 -2%") end),
+awful.key(nil, "XF86AudioRaiseVolume", function () awful.spawn("pactl set-sink-volume 0 +2%") end),
+awful.key({ cmdkey }, "Prior", function () awful.spawn("pactl set-sink-volume 0 +2%") end),
+awful.key(nil, "XF86AudioMicMute", function () awful.spawn("pactl set-source-mute 1 toggle") end),
+awful.key({ cmdkey }, "Home", function () awful.spawn("pactl set-source-mute 1 toggle") end),
+awful.key(nil, "XF86MonBrightnessDown", function () awful.spawn("xbacklight -dec 5%") end),
+awful.key(nil, "XF86MonBrightnessUp", function () awful.spawn("xbacklight -inc 5%") end),
+awful.key(nil, "XF86Display", function () awful.spawn("") end),
+awful.key(nil, "XF86WLAN", function () awful.spawn("") end),
+awful.key(nil, "XF86Tools", function () awful.spawn("") end),
+awful.key(nil, "XF86Search", function () awful.spawn("") end),
+awful.key(nil, "XF86LaunchA", function () awful.spawn("") end),
+awful.key(nil, "XF86Explorer", function () awful.spawn("") end)
+)
+
+-- Set keys
+root.keys(globalkeys)
+-- }}}
+
+-- {{{ Rules
+-- Rules to apply to new clients (through the "manage" signal).
+
+local function move_to_tag(s, t)
+    return function(c)
+        c:move_to_tag(tags[s][t])
+    end
+end
+
+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,
+                     raise = true,
+                     keys = clientkeys,
+                     buttons = clientbuttons,
+                     screen = awful.screen.preferred,
+                     placement = awful.placement.no_overlap+awful.placement.no_offscreen,
+                     floating = false
+                 },
+    },
+
+    -- Add titlebars to normal clients and dialogs
+    --DISABLED-- { rule_any = {type = { "normal", "dialog" }
+    --DISABLED--  }, properties = { titlebars_enabled = true }
+    --DISABLED-- },
+
+    { rule = { type = "dialog" },
+      properties = { floating = true,
+                     placement = awful.placement.centered
+                 }
+    },
+
+    { rule = { class = "URxvt" },
+               properties = {
+                   floating = false,
+                   size_hints_honor = false
+               } },
+    { rule = { class = "URxvt", instance = "irc" },
+               properties = {
+                   switchtotag = true
+               },
+               callback = move_to_tag(screen.count(), screen.count() == 1 and 2 or 1)
+           },
+    { rule = { class = "Firefox", instance = "Navigator" },
+               properties = {
+                   floating = false,
+               },
+               callback = move_to_tag(screen.count() == 1 and 1 or 2, 9)
+           },
+    { rule = { class = "Firefox-esr", instance = "Navigator" },
+               properties = {
+                   floating = false,
+               },
+               callback = move_to_tag(screen.count() == 1 and 1 or 2, 9)
+           },
+    { rule = { class = "Thunderbird", instance = "Mail" },
+               properties = {
+                   floating = false,
+               },
+               callback = move_to_tag(screen.count() == 1 and 1 or 2, 8)
+           },
+    { rule = { class = "Chromium", instance = "chromium" },
+               properties = {
+                   floating = false,
+               },
+               callback = move_to_tag(screen.count() == 1 and 1 or 2, 9)
+           },
+    { rule = { class = "Gscan2pdf" },
+               properties = {
+                   switchtotag = true
+               },
+               callback = move_to_tag(1, 5)
+           },
+    { rule = { name = "gscan2pdf .*" },
+               properties = {
+                   floating = false,
+               },
+           },
+    { rule = { class = "Thunar", type = "normal" },
+               properties = {
+                   floating = false,
+               },
+           },
+    { rule = { class = "MuPDF", instance = "mupdf" },
+               properties = {
+                   floating = true,
+               },
+           },
+}
+-- }}}
+
+-- {{{ Signals
+-- Signal function to execute when a new client appears.
+client.connect_signal("manage", function (c)
+    -- Set the windows at the slave,
+    -- i.e. put it at the end of others instead of setting it master.
+    -- if not awesome.startup then awful.client.setslave(c) end
+
+    if awesome.startup and
+      not c.size_hints.user_position
+      and not c.size_hints.program_position then
+        -- Prevent clients from being unreachable after screen count changes.
+        awful.placement.no_offscreen(c)
+    end
+end)
+
+-- Add a titlebar if titlebars_enabled is set to true in the rules.
+client.connect_signal("request::titlebars", function(c)
+    -- 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)
+    )
+
+    awful.titlebar(c) : setup {
+        { -- Left
+            awful.titlebar.widget.iconwidget(c),
+            buttons = buttons,
+            layout  = wibox.layout.fixed.horizontal
+        },
+        { -- Middle
+            { -- Title
+                align  = "center",
+                widget = awful.titlebar.widget.titlewidget(c)
+            },
+            buttons = buttons,
+            layout  = wibox.layout.flex.horizontal
+        },
+        { -- Right
+            awful.titlebar.widget.floatingbutton (c),
+            awful.titlebar.widget.maximizedbutton(c),
+            awful.titlebar.widget.stickybutton   (c),
+            awful.titlebar.widget.ontopbutton    (c),
+            awful.titlebar.widget.closebutton    (c),
+            layout = wibox.layout.fixed.horizontal()
+        },
+        layout = wibox.layout.align.horizontal
+    }
+end)
+
+-- Enable sloppy focus
+client.connect_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)
+
+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.ewmh.add_activate_filter(function(c, context, hints)
+    if context == "ewmh" and c.class == "Firefox-esr" or c.class == "Firefox" then return false end
+end)
+
+-- vim:ft=lua:sw=4:sts=4:ts=4:et
diff --git a/.xsession.d/50-awesomewm b/.xsession.d/50-awesomewm
new file mode 100644 (file)
index 0000000..bbb8f55
--- /dev/null
@@ -0,0 +1,18 @@
+sleep 10 &
+sleeppid=$!
+
+set -x
+
+if [ -f ~/code/awesome/awesome ] && [ -x ~/code/awesome/awesome ]; then
+  ~/code/awesome/awesome
+elif [[ -x =awesome ]]; then
+  if awesome --check; then
+    awesome --no-argb
+  else
+    awesome --config $XDG_CONFIG_HOME/awesome/stock-rc.lua.
+  fi
+else
+  x-window-manager
+fi
+
+wait $sleeppid