now it is possible to use the hotkey used to switch to specific tag to go back to previous one à la weechat + finally fixed floating window management
This commit is contained in:
		
							parent
							
								
									75c97eac8b
								
							
						
					
					
						commit
						6fc4556eed
					
				
					 1 changed files with 10 additions and 17 deletions
				
			
		
							
								
								
									
										25
									
								
								rc.lua
									
										
									
									
									
								
							
							
						
						
									
										25
									
								
								rc.lua
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -140,7 +140,7 @@ tags = {}
 | 
			
		|||
saved_layouts = {}
 | 
			
		||||
for s = 1, screen.count() do
 | 
			
		||||
	tags[s] = { name = {}, layout = {} }
 | 
			
		||||
	saved_layouts[s] = { tiled = {}, float = {} }
 | 
			
		||||
	saved_layouts[s] = { tiled = {} }
 | 
			
		||||
end
 | 
			
		||||
-- screen 1
 | 
			
		||||
--tags[1].name = {
 | 
			
		||||
| 
						 | 
				
			
			@ -494,8 +494,12 @@ for i = 1, 9 do
 | 
			
		|||
				local screen = mouse.screen
 | 
			
		||||
				local tag = awful.tag.gettags(screen)[i]
 | 
			
		||||
				if tag then
 | 
			
		||||
					if awful.tag.selected(screen) == tag and awful.tag.selectedlist(screen)[2] == nil then
 | 
			
		||||
						awful.tag.history.restore()
 | 
			
		||||
					else
 | 
			
		||||
						awful.tag.viewonly(tag)
 | 
			
		||||
					end
 | 
			
		||||
				end
 | 
			
		||||
			end),
 | 
			
		||||
		awful.key({ modkey, 'Control' }, '#' .. i + 9,
 | 
			
		||||
			function ()
 | 
			
		||||
| 
						 | 
				
			
			@ -706,7 +710,7 @@ tag.connect_signal(
 | 
			
		|||
	function(t)
 | 
			
		||||
		for k, c in ipairs(t:clients()) do
 | 
			
		||||
			if awful.layout.get(mouse.screen) == awful.layout.suit.floating then
 | 
			
		||||
				c:geometry(saved_layouts[c.screen].float[c.window])
 | 
			
		||||
				c:geometry(awful.client.property.get(c, 'floating_geometry'))
 | 
			
		||||
			end
 | 
			
		||||
		end
 | 
			
		||||
	end
 | 
			
		||||
| 
						 | 
				
			
			@ -716,27 +720,16 @@ client.connect_signal(
 | 
			
		|||
	'manage',
 | 
			
		||||
	function(c)
 | 
			
		||||
		if awful.layout.get(mouse.screen) == awful.layout.suit.floating then
 | 
			
		||||
			saved_layouts[c.screen].float[c.window] = c:geometry()
 | 
			
		||||
			awful.client.property.set(c, 'floating_geometry', c:geometry())
 | 
			
		||||
		end
 | 
			
		||||
	end
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
client.connect_signal('unmanage', function(c) saved_layouts[c.screen].float[c.window] = nil end)
 | 
			
		||||
 | 
			
		||||
client.connect_signal(
 | 
			
		||||
	'property::geometry',
 | 
			
		||||
	function(c)
 | 
			
		||||
		if awful.layout.get(mouse.screen) == awful.layout.suit.floating and awful.client.floating.get(c) == false then
 | 
			
		||||
			saved_layouts[c.screen].float[c.window] = c:geometry()
 | 
			
		||||
		end
 | 
			
		||||
	end
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
client.connect_signal(
 | 
			
		||||
	'property::floating',
 | 
			
		||||
	function(c)
 | 
			
		||||
		if awful.client.floating.get(c) == false and saved_layouts[c.screen].float[c.window] ~= nil then
 | 
			
		||||
			c:geometry(saved_layouts[c.screen].float[c.window])
 | 
			
		||||
		if awful.layout.get(mouse.screen) == awful.layout.suit.floating then
 | 
			
		||||
			awful.client.property.set(c, 'floating_geometry', c:geometry())
 | 
			
		||||
		end
 | 
			
		||||
	end
 | 
			
		||||
)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue