Re-write compact workspaces script to be less stupid

This commit is contained in:
Adam Goldsmith 2018-02-25 13:26:03 -05:00
parent cca40130b8
commit 53f2e6ade5

View File

@ -3,18 +3,22 @@
import subprocess import subprocess
import json import json
workspaces = json.loads(subprocess.run(["i3-msg", "-t", "get_workspaces"], stdout=subprocess.PIPE).stdout) exclude_workspaces = (-1, 10)
numbered_workspaces = [ws for ws in workspaces if ws['num'] != -1]
#focused = next(ws for ws in workspaces if ws['focused'] == True) def numbered_workspaces():
maximum_ws = max(numbered_workspaces, key=lambda ws: ws['num']) workspaces = json.loads(subprocess.run(["i3-msg", "-t", "get_workspaces"],
# loop through all possible workspace numbers stdout=subprocess.PIPE).stdout)
for ws_num in range(1, maximum_ws['num']): return {int(ws['num']): ws for ws in workspaces if ws['num'] not in exclude_workspaces}
# if workspace with current number doesn't exist
# TODO: handle multiple missing workspaces (consecutive or not) workspaces = sorted(numbered_workspaces().keys())
if next((ws for ws in numbered_workspaces if ws['num'] == ws_num), None) is None: num = 1
# loop through all greater numbers and move down 1 print(workspaces)
for ws in [ws for ws in numbered_workspaces if ws['num'] > ws_num]: while len(workspaces) > 0:
ws = numbered_workspaces()[workspaces.pop(0)]
if ws['num'] != num:
new_name = ws['name'].split(":") new_name = ws['name'].split(":")
new_name[0] = str(int(new_name[0]) - 1) # subtract 1 from workspace number new_name[0] = str(num)
print("move", ws['num'], '->', num)
subprocess.run(["i3-msg", "rename", "workspace", subprocess.run(["i3-msg", "rename", "workspace",
ws['name'], "to", ":".join(new_name)]) ws['name'], "to", ":".join(new_name)])
num += 1