summaryrefslogtreecommitdiffstats
path: root/.config
diff options
context:
space:
mode:
authorFlorian Pritz <f-p@gmx.at>2009-03-08 22:32:00 +0100
committerFlorian Pritz <f-p@gmx.at>2009-03-08 22:32:00 +0100
commit81c3131950ab38a42b5f156c5fbd0e7e6946da56 (patch)
tree3baf792853720affbf3be555bf86f3b6b33bab78 /.config
parent7cf92498048dbf69f7b68829aeda71f3c1df721c (diff)
downloaddotfiles-81c3131950ab38a42b5f156c5fbd0e7e6946da56.tar.gz
dotfiles-81c3131950ab38a42b5f156c5fbd0e7e6946da56.tar.xz
played a bit with awesome but configs doesn't really work
Diffstat (limited to '.config')
-rw-r--r--.config/awesome/rc.lua350
1 files changed, 159 insertions, 191 deletions
diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua
index 508a17f..8fafca2 100644
--- a/.config/awesome/rc.lua
+++ b/.config/awesome/rc.lua
@@ -1,17 +1,22 @@
--- awesome 3 configuration file
-
--- Include awesome library, with lots of useful function!
+-- Include awesome libraries, with lots of useful function!
require("awful")
-require("tabulous")
require("beautiful")
require("wicked")
-- {{{ Variable definitions
--- This is a file path to a theme file which will defines colors.
-theme_path = "/home/flo/.themes/awesome/default"
+-- Themes define colours, icons, and wallpapers
+-- The default is a dark theme
+theme_path = "/usr/share/awesome/themes/default/theme"
+-- Uncommment this for a lighter theme
+-- theme_path = "/usr/share/awesome/themes/sky/theme"
+
+-- Actually load theme
+beautiful.init(theme_path)
--- This is used later as the default terminal to run.
+-- This is used later as the default terminal and editor to run.
terminal = "urxvtc"
+editor = os.getenv("EDITOR") or "nano"
+editor_cmd = terminal .. " -e " .. editor
-- Default modkey.
-- Usually, Mod4 is the key with a logo between Control and Alt.
@@ -20,9 +25,6 @@ terminal = "urxvtc"
-- However, you can use another modifier like Mod1, but it may interact with others.
modkey = "Mod4"
-statusbar_color = "#456BC9"
-
-
-- Table of layouts to cover with awful.layout.inc, order matters.
layouts =
{
@@ -34,6 +36,7 @@ layouts =
"fairv",
"magnifier",
"max",
+ "fullscreen",
"spiral",
"dwindle",
"floating"
@@ -48,12 +51,9 @@ floatapps =
-- by class
["MPlayer"] = true,
["pinentry"] = true,
- ["pinentry-gtk-2"] = true,
["gimp"] = true,
- ["gajim.py"] = true,
-- by instance
- ["mocp"] = true,
- ["gxmessage"] = true
+ ["mocp"] = true
}
-- Applications to be moved to a pre-defined tag by class or instance.
@@ -61,7 +61,6 @@ floatapps =
apptags =
{
-- ["Firefox"] = { screen = 1, tag = 2 },
- ["Thunderbird"] = { screen = 1, tag = 3 },
-- ["mocp"] = { screen = 2, tag = 4 },
}
@@ -69,19 +68,6 @@ apptags =
use_titlebar = false
-- }}}
--- {{{ Initialization
--- Initialize theme (colors).
-beautiful.init(theme_path)
-
--- Register theme in awful.
--- This allows to not pass plenty of arguments to each function
--- to inform it about colors we want it to draw.
-#awful.beautiful.register(beautiful)
-
--- Uncomment this to activate autotabbing
--- tabulous.autotab_start()
--- }}}
-
-- {{{ Tags
-- Define tags table.
tags = {}
@@ -150,60 +136,88 @@ mytextbox = widget({ type = "textbox", name = "mytextbox", align="right" })
mytextbox.text = "<b><small> awesome " .. AWESOME_VERSION .. " </small></b>"
mypromptbox = widget({ type = "textbox", name = "mypromptbox", align = "left" })
--- Create a launcher widget
---mylauncher.awful.widget.launcher({ name = "mylauncher",
--- image = "/usr/share/awesome/icons/awesome16.png",
--- command = terminal .. "-e man awesome" })
+-- }}}
+
+-- {{{ Wibox
+-- Create a textbox widget
+mytextbox = widget({ type = "textbox", align = "right" })
+-- Set the default text in textbox
+mytextbox.text = "<b><small> " .. AWESOME_RELEASE .. " </small></b>"
+
+-- Create a laucher widget and a main menu
+myawesomemenu = {
+ { "manual", terminal .. " -e man awesome" },
+ { "edit config", editor_cmd .. " " .. awful.util.getdir("config") .. "/rc.lua" },
+ { "restart", awesome.restart },
+ { "quit", awesome.quit }
+}
+
+mymainmenu = awful.menu.new({ items = { { "awesome", myawesomemenu, beautiful.awesome_icon },
+ { "open terminal", terminal }
+ }
+ })
+
+mylauncher = awful.widget.launcher({ image = beautiful.awesome_icon,
+ menu = mymainmenu })
-- Create a systray
-mysystray = widget({ type = "systray", name = "mysystray", align = "right" })
+mysystray = widget({ type = "systray", align = "right" })
--- Create an iconbox widget which will contains an icon indicating which layout we're using.
--- We need one layoutbox per screen.
+-- Create a wibox for each screen and add it
+mywibox = {}
+mypromptbox = {}
mylayoutbox = {}
-for s = 1, screen.count() do
- mylayoutbox[s] = widget({ type = "textbox", name = "mylayoutbox", align = "right" })
- mylayoutbox[s]:mouse_add(mouse({ }, 1, function () awful.layout.inc(layouts, 1) end))
- mylayoutbox[s]:mouse_add(mouse({ }, 3, function () awful.layout.inc(layouts, -1) end))
- mylayoutbox[s]:mouse_add(mouse({ }, 4, function () awful.layout.inc(layouts, 1) end))
- mylayoutbox[s]:mouse_add(mouse({ }, 5, function () awful.layout.inc(layouts, -1) end))
- mylayoutbox[s].text = "<bg image=\"/usr/share/awesome/icons/layouts/tilew.png\" resize=\"true\"/>"
-end
+mytaglist = {}
+mytaglist.buttons = { button({ }, 1, awful.tag.viewonly),
+ button({ modkey }, 1, awful.client.movetotag),
+ button({ }, 3, function (tag) tag.selected = not tag.selected end),
+ button({ modkey }, 3, awful.client.toggletag),
+ button({ }, 4, awful.tag.viewnext),
+ button({ }, 5, awful.tag.viewprev) }
+mytasklist = {}
+mytasklist.buttons = { button({ }, 1, function (c) client.focus = c; c:raise() end),
+ button({ }, 3, function () awful.menu.clients({ width=250 }) end),
+ button({ }, 4, function () awful.client.focus.byidx(1) end),
+ button({ }, 5, function () awful.client.focus.byidx(-1) end) }
--- Create a statusbar for each screen and add it
-mystatusbar = {}
-mystatusbar_bot = {}
for s = 1, screen.count() do
- mystatusbar[s] = statusbar({ position = "top", name = "mystatusbar" .. s,
- fg = beautiful.fg_normal, bg = beautiful.bg_normal })
- mystatusbar_bot[s] = statusbar({ position = "bottom", name = "mystatusbar_bot" .. s,
- fg = beautiful.fg_normal, bg = beautiful.bg_normal, height="12" })
- -- Add widgets to the statusbar - order matters
- mystatusbar[s]:widgets({
- mytaglist,
- mypromptbox,
--- mysysstatus,
--- fswidget,
--- netwidget,
- mytextbox,
- mylayoutbox[s],
- s == 1 and mysystray or nil
- })
-
- mystatusbar_bot[s]:widgets({
- mysysstatus,
- fswidget,
- netwidget
- })
- mystatusbar[s].screen = s
- mystatusbar_bot[s].screen = s
+ -- Create a promptbox for each screen
+ mypromptbox[s] = widget({ type = "textbox", align = "left" })
+ -- Create an imagebox widget which will contains an icon indicating which layout we're using.
+ -- We need one layoutbox per screen.
+ mylayoutbox[s] = widget({ type = "imagebox", align = "right" })
+ mylayoutbox[s]:buttons({ button({ }, 1, function () awful.layout.inc(layouts, 1) end),
+ button({ }, 3, function () awful.layout.inc(layouts, -1) end),
+ button({ }, 4, function () awful.layout.inc(layouts, 1) end),
+ button({ }, 5, function () awful.layout.inc(layouts, -1) end) })
+ -- Create a taglist widget
+ mytaglist[s] = awful.widget.taglist.new(s, awful.widget.taglist.label.all, mytaglist.buttons)
+
+ -- Create a tasklist widget
+ mytasklist[s] = awful.widget.tasklist.new(function(c)
+ return awful.widget.tasklist.label.currenttags(c, s)
+ end, mytasklist.buttons)
+
+ -- Create the wibox
+ mywibox[s] = wibox({ position = "top", fg = beautiful.fg_normal, bg = beautiful.bg_normal })
+ -- Add widgets to the wibox - order matters
+ mywibox[s].widgets = { mylauncher,
+ mytaglist[s],
+ mytasklist[s],
+ mypromptbox[s],
+ mytextbox,
+ mylayoutbox[s],
+ s == 1 and mysystray or nil }
+ mywibox[s].screen = s
end
-- }}}
-- {{{ Mouse bindings
-awesome.mouse_add(mouse({ }, 3, function () awful.spawn(terminal) end))
-awesome.mouse_add(mouse({ }, 4, awful.tag.viewnext))
-awesome.mouse_add(mouse({ }, 5, awful.tag.viewprev))
+awesome.buttons({
+ button({ }, 3, function () mymainmenu:toggle() end),
+ button({ }, 4, awful.tag.viewnext),
+ button({ }, 5, awful.tag.viewprev)
+})
-- }}}
-- {{{ Key bindings
@@ -232,19 +246,17 @@ for i = 1, keynumber do
end):add()
keybinding({ modkey, "Shift" }, i,
function ()
- local sel = client.focus
- if sel then
- if tags[sel.screen][i] then
- awful.client.movetotag(tags[sel.screen][i])
+ if client.focus then
+ if tags[client.focus.screen][i] then
+ awful.client.movetotag(tags[client.focus.screen][i])
end
end
end):add()
keybinding({ modkey, "Control", "Shift" }, i,
function ()
- local sel = client.focus
- if sel then
- if tags[sel.screen][i] then
- awful.client.toggletag(tags[sel.screen][i])
+ if client.focus then
+ if tags[client.focus.screen][i] then
+ awful.client.toggletag(tags[client.focus.screen][i])
end
end
end):add()
@@ -255,26 +267,30 @@ keybinding({ modkey }, "Right", awful.tag.viewnext):add()
keybinding({ modkey }, "Escape", awful.tag.history.restore):add()
-- Standard program
-keybinding({ modkey }, "Return", function () awful.spawn(terminal) end):add()
+keybinding({ modkey }, "Return", function () awful.util.spawn(terminal) end):add()
-keybinding({ modkey, "Control" }, "r", awesome.restart):add()
+keybinding({ modkey, "Control" }, "r", function ()
+ mypromptbox[mouse.screen].text =
+ awful.util.escape(awful.util.restart())
+ end):add()
keybinding({ modkey, "Shift" }, "q", awesome.quit):add()
-- Client manipulation
keybinding({ modkey }, "m", awful.client.maximize):add()
-keybinding({ modkey, "Shift" }, "c", function () client.focus:kill() end):add()
-keybinding({ modkey }, "j", function () awful.client.focusbyidx(1); client.focus:raise() end):add()
-keybinding({ modkey }, "k", function () awful.client.focusbyidx(-1); client.focus:raise() end):add()
-keybinding({ modkey, "Shift" }, "j", function () awful.client.swap(1) end):add()
-keybinding({ modkey, "Shift" }, "k", function () awful.client.swap(-1) end):add()
+keybinding({ modkey }, "f", function () if client.focus then client.focus.fullscreen = not client.focus.fullscreen end end):add()
+keybinding({ modkey, "Shift" }, "c", function () if client.focus then client.focus:kill() end end):add()
+keybinding({ modkey }, "j", function () awful.client.focus.byidx(1); if client.focus then client.focus:raise() end end):add()
+keybinding({ modkey }, "k", function () awful.client.focus.byidx(-1); if client.focus then client.focus:raise() end end):add()
+keybinding({ modkey, "Shift" }, "j", function () awful.client.swap.byidx(1) end):add()
+keybinding({ modkey, "Shift" }, "k", function () awful.client.swap.byidx(-1) end):add()
keybinding({ modkey, "Control" }, "j", function () awful.screen.focus(1) end):add()
keybinding({ modkey, "Control" }, "k", function () awful.screen.focus(-1) end):add()
keybinding({ modkey, "Control" }, "space", awful.client.togglefloating):add()
-keybinding({ modkey, "Control" }, "Return", function () client.focus:swap(awful.client.master()) end):add()
+keybinding({ modkey, "Control" }, "Return", function () if client.focus then client.focus:swap(awful.client.getmaster()) end end):add()
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()
+keybinding({ modkey, "Shift" }, "r", function () if client.focus then client.focus:redraw() end end):add()
-- Layout manipulation
keybinding({ modkey }, "l", function () awful.tag.incmwfact(0.05) end):add()
@@ -288,74 +304,34 @@ keybinding({ modkey, "Shift" }, "space", function () awful.layout.inc(layouts, -
-- Prompt
keybinding({ modkey }, "F1", function ()
- awful.prompt.run({ prompt = "Run: " }, mypromptbox, awful.spawn, awful.completion.bash,
-os.getenv("HOME") .. "/.cache/awesome/history") end):add()
+ awful.prompt.run({ prompt = "Run: " }, mypromptbox[mouse.screen], awful.util.spawn, awful.completion.bash,
+ awful.util.getdir("cache") .. "/history")
+ end):add()
keybinding({ modkey }, "F4", function ()
- awful.prompt.run({ prompt = "Run Lua code: " }, mypromptbox, awful.eval, awful.prompt.bash,
-os.getenv("HOME") .. "/.cache/awesome/history_eval") end):add()
+ awful.prompt.run({ prompt = "Run Lua code: " }, mypromptbox[mouse.screen], awful.util.eval, awful.prompt.bash,
+ awful.util.getdir("cache") .. "/history_eval")
+ end):add()
+
keybinding({ modkey, "Ctrl" }, "i", function ()
- if mypromptbox.text then
- mypromptbox.text = nil
- else
- mypromptbox.text = nil
+ local s = mouse.screen
+ if mypromptbox[s].text then
+ mypromptbox[s].text = nil
+ elseif client.focus then
+ mypromptbox[s].text = nil
if client.focus.class then
- mypromptbox.text = "Class: " .. client.focus.class .. " "
+ mypromptbox[s].text = "Class: " .. client.focus.class .. " "
end
if client.focus.instance then
- mypromptbox.text = mypromptbox.text .. "Instance: ".. client.focus.instance .. " "
+ mypromptbox[s].text = mypromptbox[s].text .. "Instance: ".. client.focus.instance .. " "
end
if client.focus.role then
- mypromptbox.text = mypromptbox.text .. "Role: ".. client.focus.role
+ mypromptbox[s].text = mypromptbox[s].text .. "Role: ".. client.focus.role
end
end
end):add()
---- Tabulous, tab manipulation
-keybinding({ modkey, "Control" }, "y", function ()
- local tabbedview = tabulous.tabindex_get()
- local nextclient = awful.client.next(1)
-
- if not tabbedview then
- tabbedview = tabulous.tabindex_get(nextclient)
-
- if not tabbedview then
- tabbedview = tabulous.tab_create()
- tabulous.tab(tabbedview, nextclient)
- else
- tabulous.tab(tabbedview, client.focus)
- end
- else
- tabulous.tab(tabbedview, nextclient)
- end
-end):add()
-
-keybinding({ modkey, "Shift" }, "y", tabulous.untab):add()
-
-keybinding({ modkey }, "y", function ()
- local tabbedview = tabulous.tabindex_get()
-
- if tabbedview then
- local n = tabulous.next(tabbedview)
- tabulous.display(tabbedview, n)
- end
-end):add()
-
-- Client awful tagging: this is useful to tag some clients and then do stuff like move to tag on them
keybinding({ modkey }, "t", awful.client.togglemarked):add()
-keybinding({ modkey, 'Shift' }, "t", function ()
- local tabbedview = tabulous.tabindex_get()
- local clients = awful.client.getmarked()
-
- if not tabbedview then
- tabbedview = tabulous.tab_create(clients[1])
- table.remove(clients, 1)
- end
-
- for k,c in pairs(clients) do
- tabulous.tab(tabbedview, c)
- end
-
-end):add()
for i = 1, keynumber do
keybinding({ modkey, "Shift" }, "F" .. i,
@@ -372,54 +348,54 @@ end
-- {{{ Hooks
-- Hook function to execute when focusing a client.
-function hook_focus(c)
+awful.hooks.focus.register(function (c)
if not awful.client.ismarked(c) then
c.border_color = beautiful.border_focus
end
-end
+end)
-- Hook function to execute when unfocusing a client.
-function hook_unfocus(c)
+awful.hooks.unfocus.register(function (c)
if not awful.client.ismarked(c) then
c.border_color = beautiful.border_normal
end
-end
+end)
-- Hook function to execute when marking a client
-function hook_marked(c)
+awful.hooks.marked.register(function (c)
c.border_color = beautiful.border_marked
-end
+end)
--- Hook function to execute when unmarking a client
-function hook_unmarked(c)
+-- Hook function to execute when unmarking a client.
+awful.hooks.unmarked.register(function (c)
c.border_color = beautiful.border_focus
-end
+end)
--- Hook function to execute when the mouse is over a client.
-function hook_mouseover(c)
+-- Hook function to execute when the mouse enters a client.
+awful.hooks.mouse_enter.register(function (c)
-- Sloppy focus, but disabled for magnifier layout
- if awful.layout.get(c.screen) ~= "magnifier" then
+ if awful.layout.get(c.screen) ~= "magnifier"
+ and awful.client.focus.filter(c) then
client.focus = c
end
-end
+end)
-- Hook function to execute when a new client appears.
-function hook_manage(c)
- -- Set floating placement to be smart!
- c.floating_placement = "smart"
+awful.hooks.manage.register(function (c)
if use_titlebar then
-- Add a titlebar
awful.titlebar.add(c, { modkey = modkey })
end
-- Add mouse bindings
- c:mouse_add(mouse({ }, 1, function (c) client.focus = c; c:raise() end))
- c:mouse_add(mouse({ modkey }, 1, function (c) c:mouse_move() end))
- c:mouse_add(mouse({ modkey }, 3, function (c) c:mouse_resize() end))
+ c:buttons({
+ button({ }, 1, function (c) client.focus = c; c:raise() end),
+ button({ modkey }, 1, function (c) c:mouse_move() end),
+ button({ modkey }, 3, function (c) c:mouse_resize() end)
+ })
-- New client may not receive focus
-- if they're not focusable, so set border anyway.
c.border_width = beautiful.border_width
c.border_color = beautiful.border_normal
- client.focus = c
-- Check if the application should be floating.
local cls = c.class
@@ -442,26 +418,29 @@ function hook_manage(c)
awful.client.movetotag(tags[target.screen][target.tag], c)
end
+ -- Do this after tag mapping, so you don't see it on the wrong tag for a split second.
+ client.focus = c
+
-- Set the windows at the slave,
-- i.e. put it at the end of others instead of setting it master.
-- awful.client.setslave(c)
- -- Honor size hints
- c.honorsizehints = true
-end
+ -- Honor size hints: if you want to drop the gaps between windows, set this to false.
+ -- c.honorsizehints = false
+end)
--- Hook function to execute when arranging the screen
+-- Hook function to execute when arranging the screen.
-- (tag switch, new client, etc)
-function hook_arrange(screen)
+awful.hooks.arrange.register(function (screen)
local layout = awful.layout.get(screen)
if layout then
- mylayoutbox[screen].text =
- "<bg image=\"/usr/share/awesome/icons/layouts/" .. awful.layout.get(screen) .. "w.png\" resize=\"true\"/>"
- else
- mylayoutbox[screen].text = "No layout."
+ mylayoutbox[screen].image = image(beautiful["layout_" .. layout])
+ else
+ mylayoutbox[screen].image = nil
end
- -- If no window has focus, give focus to the latest in history
+ -- Give focus to the latest client in history if no window has focus
+ -- or if the current window is a desktop or a dock one.
if not client.focus then
local c = awful.client.focus.history.get(screen, 0)
if c then client.focus = c end
@@ -469,9 +448,8 @@ function hook_arrange(screen)
-- Uncomment if you want mouse warping
--[[
- local sel = client.focus
- if sel then
- local c_c = sel:coords()
+ if client.focus then
+ local c_c = client.focus:fullgeometry()
local m_c = mouse.coords()
if m_c.x < c_c.x or m_c.x >= c_c.x + c_c.width or
@@ -482,23 +460,13 @@ function hook_arrange(screen)
end
end
]]
-end
+end)
-- Hook called every second
-function hook_timer ()
+awful.hooks.timer.register(1, function ()
-- For unix time_t lovers
--mytextbox.text = " " .. os.time() .. " time_t "
-- Otherwise use:
- mytextbox.text = " " .. os.date("%H:%M:%S %F") .. " "
-end
-
--- Set up some hooks
-awful.hooks.focus.register(hook_focus)
-awful.hooks.unfocus.register(hook_unfocus)
-awful.hooks.marked.register(hook_marked)
-awful.hooks.unmarked.register(hook_unmarked)
-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)
+ mytextbox.text = " " .. os.date("%H:%M:%S %F") .. " "
+end)
-- }}}