Update swaytree script
This commit is contained in:
parent
fb892470cb
commit
38915b0a0a
2 changed files with 39 additions and 23 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
|
Loading…
Reference in a new issue