X-Git-Url: https://git.madduck.net/etc/awesome.git/blobdiff_plain/a89bbec6f39985515c33aa71dab1689f863b7851..1ebfa854f95e3abcd8b41a1798646a9db6e8408b:/util/quake.lua?ds=sidebyside diff --git a/util/quake.lua b/util/quake.lua index 0ec1081..bf78fce 100644 --- a/util/quake.lua +++ b/util/quake.lua @@ -27,6 +27,8 @@ local quake = {} function quake:display() if self.followtag then self.screen = awful.screen.focused() end + local toscan = self.screen + if self.onlyone then toscan = nil end -- First, we locate the client local client = nil @@ -34,7 +36,7 @@ function quake:display() for c in awful.client.iterate(function (c) -- c.name may be changed! return c.instance == self.name - end, nil, self.screen) + end, nil, toscan) do i = i + 1 if i == 1 then @@ -64,7 +66,7 @@ function quake:display() client.floating = true client.border_width = self.border client.size_hints_honor = false - client:geometry(self:compute_size()) + client:geometry(self.geometry[self.screen] or self:compute_size()) -- Set not sticky and on top client.sticky = false @@ -72,6 +74,9 @@ function quake:display() client.above = true client.skip_taskbar = true + -- Additional user settings + if self.settings then self.settings(client) end + -- Toggle display if self.visible then client.hidden = false @@ -125,8 +130,10 @@ function quake:new(config) conf.border = conf.border or 1 -- client border width conf.visible = conf.visible or false -- initially not visible conf.followtag = conf.followtag or false -- spawn on currently focused screen + conf.onlyone = conf.onlyone or false -- one instance for all screens conf.overlap = conf.overlap or false -- overlap wibox conf.screen = conf.screen or awful.screen.focused() + conf.settings = conf.settings -- If width or height <= 1 this is a proportion of the workspace conf.height = conf.height or 0.25 -- height