fixes
[distro-setup] / filesystem / usr / local / bin / abrowser
index 80f2371beaa40a6824ab1f719f12d5d9741c753f..96c969a4c149ca95aadd09383fa56df94e523534 100755 (executable)
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
+# note this is duplicated in i3-abrowser
+
+if ! test "$BASH_VERSION"; then echo "error: shell is not bash" >&2; exit 1; fi
+shopt -s inherit_errexit 2>/dev/null ||: # ignore fail in bash < 4.4
+set -eE -o pipefail
+trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" exit status: $?, PIPESTATUS: ${PIPESTATUS[*]}" >&2' ERR
+
 
-# https://stackoverflow.com/a/2108540
-tmp=:$PATH:
-del=/usr/local/bin
-tmp=${tmp//:$del:/:}
-tmp=${tmp%:}
-tmp=${tmp#:}
-PATH=$tmp
 
 # -allow-downgrade good enough?
 #rm -f {/p/c/firefox-main-profile,/p/c/firefox-main-profile,/p/c/firefox-vpn2-profile,/mnt/z/firefox-vpn-profile}/compatibility.ini
@@ -38,33 +38,20 @@ PATH=$tmp
 # new tab
 
 
-tmpf=$(mktemp)
-i3-msg -t get_tree | jq -e '.nodes[].nodes[].nodes[].nodes | [.[]] + ( [.[].nodes[]]) | .[] | select(.window_properties.class=="abrowser") | .id' | sort >$tmpf
 
+# remove local/bin from path
+# https://stackoverflow.com/a/2108540
+tmp=:$PATH:
+del=/usr/local/bin
+tmp=${tmp//:$del:/:}
+tmp=${tmp%:}
+tmp=${tmp#:}
+PATH=$tmp
 # prefer abrowser
 if type -P abrowser &>/dev/null; then
-  abrowser "$@" &
+  b=abrowser
 else
-  firefox "$@" &
-fi
-
-# .5 was too fast
-sleep 1
-# debug
-#printf "%s\n" "$*" >> /tmp/a
-if (( $# == 0 )) && ! i3-msg -t get_tree | jq --stream -r 'select(.[1]|scalars!=null) | "\(.[0]|join(".")): \(.[1]|tojson)"'  | grep 'marks.0: "abrowser"$' &>/dev/null; then
-  # explaining this jq nonsense. when the abrowser window starts, it
-  # might be in a vertical split container, and then it is nested down
-  # another level.  the best way I could find to look in both levels was
-  # to get both, then combine them with + (and you have to turn them
-  # 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[]]) | .[] | select(.window_properties.class=="abrowser") | .id' | comm -23 - $tmpf | head -n1)
-  rm -f $tmpf
-  if [[ $id ]]; then
-    i3-msg "[con_id=$id] mark abrowser"
-  fi
+  b=firefox
 fi
 
-wait
+$b "$@"