]>
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:
summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (parent:
a89bbec )
-local newtimer = require("lain.helpers").newtimer
-local read_pipe = require("lain.helpers").read_pipe
+local helpers = require("lain.helpers")
-local wibox = require("wibox")
local awful = require("awful")
local awful = require("awful")
+local wibox = require("wibox")
-local string = { match = string.match }
+local string = { format = string.format,
+ match = string.match }
+local execute = os.execute
local setmetatable = setmetatable
local setmetatable = setmetatable
-- lain.widgets.contrib.kblayout
local function worker(args)
-- lain.widgets.contrib.kblayout
local function worker(args)
- local kbdlayout = {}
- kbdlayout.widget = wibox.widget.textbox('')
-
local layouts = args.layouts
local settings = args.settings or function () end
local add_us_secondary = true
local layouts = args.layouts
local settings = args.settings or function () end
local add_us_secondary = true
if args.add_us_secondary == false then add_us_secondary = false end
if args.add_us_secondary == false then add_us_secondary = false end
+ kbdlayout.widget = wibox.widget.textbox()
+
-- Mouse bindings
kbdlayout.widget:buttons(awful.util.table.join(
awful.button({ }, 1, function () kbdlayout.next() end),
awful.button({ }, 3, function () kbdlayout.prev() end)))
local function run_settings(layout, variant)
-- Mouse bindings
kbdlayout.widget:buttons(awful.util.table.join(
awful.button({ }, 1, function () kbdlayout.next() end),
awful.button({ }, 3, function () kbdlayout.prev() end)))
local function run_settings(layout, variant)
- widget = kbdlayout.widget
- kbdlayout_now = {
- layout=string.match(layout, "[^,]+"), -- Make sure to match the primary layout only.
- variant=variant
+ kbdlayout_now = {
+ layout = string.match(layout, "[^,]+"), -- Make sure to match the primary layout only.
+ variant = variant
+ widget = kbdlayout.widget
settings()
end
function kbdlayout.update()
settings()
end
function kbdlayout.update()
- local status = read_pipe('setxkbmap -query')
-
- run_settings(string.match(status, "layout:%s*([^\n]*)"),
- string.match(status, "variant:%s*([^\n]*)"))
+ helpers.async(string.format("%s -c 'setxkbmap -query'", awful.util.shell),
+ function(status)
+ run_settings(string.match(status, "layout:%s*([^\n]*)"),
+ string.match(status, "variant:%s*([^\n]*)"))
+ end)
end
function kbdlayout.set(i)
idx = ((i - 1) % #layouts) + 1 -- Make sure to wrap around as needed.
end
function kbdlayout.set(i)
idx = ((i - 1) % #layouts) + 1 -- Make sure to wrap around as needed.
- local to_execute = 'setxkbmap ' .. layouts[idx].layout
+ local to_execute = "setxkbmap " .. layouts[idx].layout
if add_us_secondary and not string.match(layouts[idx].layout, ",?us,?") then
to_execute = to_execute .. ",us"
end
if layouts[idx].variant then
if add_us_secondary and not string.match(layouts[idx].layout, ",?us,?") then
to_execute = to_execute .. ",us"
end
if layouts[idx].variant then
- to_execute = to_execute .. ' ' .. layouts[idx].variant
+ to_execute = to_execute .. " " .. layouts[idx].variant
- if os. execute(to_execute) then
+ if execute(to_execute) then
run_settings(layouts[idx].layout, layouts[idx].variant)
end
end
run_settings(layouts[idx].layout, layouts[idx].variant)
end
end
kbdlayout.set(idx - 1)
end
kbdlayout.set(idx - 1)
end
- newtimer("kbdlayout", timeout, kbdlayout.update)
+ helpers.newtimer("kbdlayout", timeout, kbdlayout.update)
+
return setmetatable(kbdlayout, { __index = kbdlayout.widget })
end
return setmetatable(kbdlayout, { __index = kbdlayout.widget })
end
-Subproject commit d975ff04346986b5ab24e7bc16321e438d3425b8
+Subproject commit bfdf6d24310d0822bac3447c39bb93cb83a75f77