Update swaytree script

This commit is contained in:
Akemi Izuko 2023-12-23 20:13:57 -07:00
parent fb892470cb
commit 38915b0a0a
Signed by: akemi
GPG key ID: 8DE0764E1809E9FC
2 changed files with 39 additions and 23 deletions

View file

@ -22,15 +22,43 @@
// ├───> [Chromium-browser] // ├───> [Chromium-browser]
// └───> [Alacritty] // └───> [Alacritty]
use std::io::{self, BufRead}; use std::io::{self, BufRead, BufReader};
use std::process::{Command, Stdio, ChildStdout};
fn main() { fn main() {
let stdin = io::stdin(); let sway_tree = match get_tree() {
let sway_representation = stdin.lock().lines().next() Ok(tree) => BufReader::new(tree).lines().map(|l| l.unwrap()),
.expect("Could not read from stdin") Err(e) => panic!("Failed to get sway tree: {}", e),
.expect("Stdio error"); };
println!("{}", ParserTree::from(&sway_representation).format()); for (i, line) in sway_tree.enumerate() {
println!("Workspace {} :: {}", i+1, line);
println!("{}", ParserTree::from(&line).format());
}
}
fn get_tree() -> io::Result<ChildStdout> {
let swaymsg = Command::new("swaymsg")
.arg("-t")
.arg("get_tree")
.stdout(Stdio::piped())
.spawn()?;
let jq = Command::new("jq")
.arg(".nodes[1].nodes[].representation")
.stdin(swaymsg.stdout.unwrap())
.stdout(Stdio::piped())
.spawn()
.expect("`jq` binary is not available");
let tr = Command::new("tr")
.arg("-d")
.arg("\"")
.stdin(jq.stdout.unwrap())
.stdout(Stdio::piped())
.spawn()?;
Ok(tr.stdout.unwrap())
} }
@ -162,7 +190,7 @@ fn parse_sway_tree(rep: &str) -> ParserTree {
return child return child
} }
eprintln!("PushLeaf: {:?}", &container_stack); //eprintln!("PushLeaf: {:?}", &container_stack);
state = State::ExitContainer; state = State::ExitContainer;
} else if c == ' ' { } else if c == ' ' {
@ -171,7 +199,7 @@ fn parse_sway_tree(rep: &str) -> ParserTree {
let container = container_stack.last_mut().unwrap(); let container = container_stack.last_mut().unwrap();
container.1.push(leaf); container.1.push(leaf);
eprintln!("PushLeaf: {:?}", &container_stack); //eprintln!("PushLeaf: {:?}", &container_stack);
state = State::EnterContainer; state = State::EnterContainer;
} else { } else {
@ -184,7 +212,7 @@ fn parse_sway_tree(rep: &str) -> ParserTree {
if (c == 'H' || c == 'V' || c == 'T' || c == 'S') && c1 == '[' { if (c == 'H' || c == 'V' || c == 'T' || c == 'S') && c1 == '[' {
container_stack.push(init_container(c)); container_stack.push(init_container(c));
eprintln!("AppendChild: {:?}", &container_stack); //eprintln!("AppendChild: {:?}", &container_stack);
i += 2; i += 2;
} else { } else {
@ -193,7 +221,7 @@ fn parse_sway_tree(rep: &str) -> ParserTree {
} }
State::ExitContainer => { State::ExitContainer => {
if c == ']' { if c == ']' {
eprintln!("AppendParent:{:?}", &container_stack); //eprintln!("AppendParent:{:?}", &container_stack);
let container = container_stack.pop().unwrap(); let container = container_stack.pop().unwrap();
let child = ParserTree::container(container.0, container.1); let child = ParserTree::container(container.0, container.1);
@ -206,7 +234,7 @@ fn parse_sway_tree(rep: &str) -> ParserTree {
i += 1; i += 1;
} else { } else {
eprintln!("NextChild: {:?}", &container_stack); //eprintln!("NextChild: {:?}", &container_stack);
state = State::EnterContainer; state = State::EnterContainer;
i += 1; i += 1;
} }

View file

@ -1,12 +0,0 @@
#!/usr/bin/env bash
i=0
swaymsg -t get_tree | jq '.nodes[1].nodes[].representation' | tr -d '"' | \
while read ln; do
space_num="$(swaymsg -t get_tree | jq '.nodes[1].nodes['"$i"'].name' | tr -d '"')"
printf "Workspace %s :: %s\n" "$space_num" "$ln"
i=$(( i + 1 ))
printf "%s" "$ln" | sway_tree 2>/dev/null
done