]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/contrib/kbdlayout.lua
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:
--]]
local helpers = require("lain.helpers")
--]]
local helpers = require("lain.helpers")
local awful = require("awful")
local wibox = require("wibox")
local awful = require("awful")
local wibox = require("wibox")
local string = { format = string.format,
match = string.match }
local execute = os.execute
local string = { format = string.format,
match = string.match }
local execute = os.execute
local setmetatable = setmetatable
-- Keyboard layout switcher
-- lain.widgets.contrib.kblayout
local setmetatable = setmetatable
-- Keyboard layout switcher
-- lain.widgets.contrib.kblayout
local function worker(args)
local function worker(args)
- local kbdlayout = {}
- local layouts = args.layouts
+ local args = args or {}
+ local layouts = args.layouts or {}
local settings = args.settings or function () end
local add_us_secondary = true
local timeout = args.timeout or 5
local settings = args.settings or function () end
local add_us_secondary = true
local timeout = args.timeout or 5
kbdlayout.widget = wibox.widget.textbox()
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)
+ local function kbd_run_settings(layout, variant)
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
end
function kbdlayout.update()
end
function kbdlayout.update()
- helpers.async(string.format("%s -c 'setxkbmap -query'", awful.util.shell),
- function(status)
- run_settings(string.match(status, "layout:%s*([^\n]*)"),
+ helpers.async("setxkbmap -query", function(status)
+ kbd_run_settings(string.match(status, "layout:%s*([^\n]*)"),
string.match(status, "variant:%s*([^\n]*)"))
end)
end
function kbdlayout.set(i)
string.match(status, "variant:%s*([^\n]*)"))
end)
end
function kbdlayout.set(i)
+ if #layouts == 0 then return end
idx = ((i - 1) % #layouts) + 1 -- Make sure to wrap around as needed.
local to_execute = "setxkbmap " .. layouts[idx].layout
idx = ((i - 1) % #layouts) + 1 -- Make sure to wrap around as needed.
local to_execute = "setxkbmap " .. layouts[idx].layout
end
if execute(to_execute) then
end
if execute(to_execute) then
- run_settings(layouts[idx].layout, layouts[idx].variant)
+ kbd_ run_settings(layouts[idx].layout, layouts[idx].variant)
- function kbdlayout.next()
- kbdlayout.set(idx + 1)
- end
+ function kbdlayout.next() kbdlayout.set(idx + 1) end
+ function kbdlayout.prev() kbdlayout.set(idx - 1) end
- function kbdlayout.prev()
- kbdlayout.set(idx - 1)
- end
+ -- Mouse bindings
+ kbdlayout.widget:buttons(awful.util.table.join(
+ awful.button({ }, 1, function () kbdlayout.next() end),
+ awful.button({ }, 3, function () kbdlayout.prev() end)))
helpers.newtimer("kbdlayout", timeout, kbdlayout.update)
helpers.newtimer("kbdlayout", timeout, kbdlayout.update)
- return setmetatable(kbdlayout, { __index = kbdlayout.widget })
end
return setmetatable({}, { __call = function (_, ...) return worker(...) end })
end
return setmetatable({}, { __call = function (_, ...) return worker(...) end })