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:

Merge pull request #75 from osleg/master
[etc/awesome.git] / layout / uselesspiral.lua
index 3164c7597ea9d2d0a003a5361d125d8b9b450c02..ba63bca30fe79b80dc4c1c2e67c3adab101fd95c 100644 (file)
@@ -2,7 +2,8 @@
 --[[
                                                   
      Licensed under GNU General Public License v2 
-      * (c) 2013,      Luke Bonham                
+      * (c) 2014       projektile                 
+      * (c) 2013       Luke Bonham                
       * (c) 2009       Uli Schlachter             
       * (c) 2008       Julien Danjolu             
                                                   
@@ -11,6 +12,7 @@
 local beautiful = require("beautiful")
 local ipairs    = ipairs
 local tonumber  = tonumber
+local math      = require("math")
 
 local uselesspiral = {}
 
@@ -18,19 +20,32 @@ local function spiral(p, spiral)
     -- A useless gap (like the dwm patch) can be defined with
     -- beautiful.useless_gap_width.
     local useless_gap = tonumber(beautiful.useless_gap_width) or 0
+    if useless_gap < 0 then useless_gap = 0 end
 
+    -- A global border can be defined with
+    -- beautiful.global_border_width
+    local global_border = tonumber(beautiful.global_border_width) or 0
+    if global_border < 0 then global_border = 0 end
+
+    -- Themes border width requires an offset
+    local bw = tonumber(beautiful.border_width) or 0
+
+    -- get our orientation right
     local wa = p.workarea
     local cls = p.clients
-    local n = #cls
+    local n = #cls -- number of windows total; k = which window number
+
+    wa.height = wa.height - ((global_border * 2) + (bw * 2))
+    wa.width = wa.width - ((global_border * 2) + (bw * 2))
 
     local static_wa = wa
 
     for k, c in ipairs(cls) do
         if k < n then
             if k % 2 == 0 then
-                wa.height = wa.height / 2
+                wa.height = (wa.height / 2)
             else
-                wa.width = wa.width / 2
+                wa.width = (wa.width / 2)
             end
         end
 
@@ -49,10 +64,10 @@ local function spiral(p, spiral)
         end
 
             local wa2 = {}
-            wa2.x = wa.x
-            wa2.y = wa.y
-            wa2.height = wa.height
-            wa2.width = wa.width
+            wa2.x = wa.x + (useless_gap / 2) + global_border
+            wa2.y = wa.y + (useless_gap / 2) + global_border
+            wa2.height = wa.height - (useless_gap / 2)
+            wa2.width = wa.width - (useless_gap / 2)
 
         -- Useless gap.
         if useless_gap > 0
@@ -64,8 +79,6 @@ local function spiral(p, spiral)
             top = false
             left = false
 
-            gap_factor = (useless_gap / 100) * 2
-
             if wa2.y == static_wa.y then
                top = true
             end
@@ -75,17 +88,17 @@ local function spiral(p, spiral)
             end
 
             if top then
-                wa2.height = wa2.height - (2 + gap_factor) * useless_gap
-                wa2.y = wa2.y + useless_gap
+                wa2.height = wa2.height - useless_gap
+                wa2.y = wa2.y - (useless_gap / 2)
             else
-                wa2.height = wa2.height - (1 + gap_factor) * useless_gap
+                wa2.height = wa2.height - (useless_gap / 2)
             end
 
             if left then
-                wa2.width = wa2.width - (2 + gap_factor) * useless_gap
-                wa2.x = wa2.x + useless_gap
+                wa2.width = wa2.width - useless_gap
+                wa2.x = wa2.x - (useless_gap / 2)
             else
-                wa2.width = wa2.width - (1 + gap_factor) * useless_gap
+                wa2.width = wa2.width - (useless_gap / 2)
             end
         end
         -- End of useless gap.