mostly fixes, some improvements
[distro-setup] / filesystem / usr / local / bin / abrowser
index 7892cc7cafcc2838882dd39a62bae1f0084a842a..d3ce6431f1053ecc4d4ffcb7527bba948c78ac6c 100755 (executable)
@@ -43,11 +43,13 @@ i3-msg -t get_tree | jq -e '.nodes[].nodes[].nodes[].nodes | [.[]] + ( [.[].node
 
 # prefer abrowser
 if type -P abrowser &>/dev/null; then
-  abrowser "$@" &
+  b=abrowser
 else
-  firefox "$@" &
+  b=firefox
 fi
 
+$b "$@" &
+
 # on a fast computer, .5 is too fast, 1 is ok. on x200, 1 is too fast, 2 is ok.
 sleep 2
 # debug
@@ -60,7 +62,7 @@ if (( $# == 0 )) && ! i3-msg -t get_tree | jq --stream -r 'select(.[1]|scalars!=
   # into a single array instead of a list of arrays with [.[]], or else
   # it will add the arrays a bunch of times and give several results.
   # comm gives us just the new id.
-  id=$(i3-msg -t get_tree | jq -e '.nodes[].nodes[].nodes[].nodes | [.[]] + ( [.[].nodes[]]) + ( [.[].nodes[].nodes[]]) + ( [.[].nodes[].nodes[].nodes[]]) | .[] | select(.window_properties.class=="abrowser") | .id' | comm -23 - $tmpf | head -n1)
+  id=$(i3-msg -t get_tree | jq -e '.nodes[].nodes[].nodes[].nodes | [.[]] + ( [.[].nodes[]]) + ( [.[].nodes[].nodes[]]) + ( [.[].nodes[].nodes[].nodes[]]) | .[] | select(.window_properties.class=="'$b'") | .id' | comm -23 - $tmpf | head -n1)
   rm -f $tmpf
   if [[ $id ]]; then
     i3-msg "[con_id=$id] mark abrowser"