cleanup
This commit is contained in:
parent
2fb43032b7
commit
11b95a1e05
19
bt
19
bt
@ -2,7 +2,7 @@
|
|||||||
#load config
|
#load config
|
||||||
. "${XDG_CONFIG_HOME:-$HOME/.config}/bt/config"
|
. "${XDG_CONFIG_HOME:-$HOME/.config}/bt/config"
|
||||||
|
|
||||||
[ "$AUTOTRUST" = false ] && actions="$(printf '%s\ntrust\n' "$actions")"
|
"$AUTOTRUST" || actions="$(printf '%s\ntrust\n' "$actions")"
|
||||||
|
|
||||||
power(){
|
power(){
|
||||||
powerstatus="$( bluetoothctl show | grep Powered | awk '{print $2}' )"
|
powerstatus="$( bluetoothctl show | grep Powered | awk '{print $2}' )"
|
||||||
@ -35,6 +35,7 @@ update_pair_list(){
|
|||||||
btctl_paired_devices="$(bluetoothctl paired-devices)"
|
btctl_paired_devices="$(bluetoothctl paired-devices)"
|
||||||
if [ -n "$btctl_paired_devices" ]
|
if [ -n "$btctl_paired_devices" ]
|
||||||
then
|
then
|
||||||
|
#needs temp var as it writes into the same file as it reads from
|
||||||
btctl_not_in_list="$( echo "$btctl_paired_devices" | grep -vf "$PAIRLIST")"
|
btctl_not_in_list="$( echo "$btctl_paired_devices" | grep -vf "$PAIRLIST")"
|
||||||
[ -n "$btctl_not_in_list" ] && echo "$btctl_not_in_list" >> "$PAIRLIST"
|
[ -n "$btctl_not_in_list" ] && echo "$btctl_not_in_list" >> "$PAIRLIST"
|
||||||
fi
|
fi
|
||||||
@ -46,7 +47,7 @@ startup(){
|
|||||||
if $AUTOSCAN
|
if $AUTOSCAN
|
||||||
then
|
then
|
||||||
power on
|
power on
|
||||||
scan on > /dev/null
|
scan on
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -60,7 +61,7 @@ if [ "$1" = "edit" ]; then
|
|||||||
esac
|
esac
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
#Sadly needs to be run without '&' for now, since it otherwise breaks start_scan variable
|
|
||||||
startup &
|
startup &
|
||||||
update_pair_list &
|
update_pair_list &
|
||||||
|
|
||||||
@ -75,15 +76,13 @@ connected_devices="$(echo "$connected_ids" | while read -r id; do
|
|||||||
fi
|
fi
|
||||||
done)"
|
done)"
|
||||||
|
|
||||||
[ -n "$include_disconnect_option" ] &&
|
"$include_disconnect_option" &&
|
||||||
[ -n "$connected_devices" ] &&
|
[ -n "$connected_devices" ] &&
|
||||||
actions="$(printf "disconnect\n%s" "$actions")"
|
actions="$(printf "disconnect\n%s" "$actions")"
|
||||||
|
|
||||||
#Compile list of all Bluetooth IDS of paired devices (from bluetoothctl and from hardcoded list)
|
|
||||||
bt_IDS="$( ( bluetoothctl paired-devices && cat "$PAIRLIST" ) | awk '{print $2}' | sort -u )"
|
|
||||||
|
|
||||||
#Compile list of all device Names of paired devices (from bluetoothctl and from hardcoded list)
|
#Compile list of all device Names of paired devices (from bluetoothctl and from hardcoded list)
|
||||||
paired_devices_with_id="$( ( bluetoothctl paired-devices && cat "$PAIRLIST" ) | sort -u | cut -d' ' --complement -f1)"
|
paired_devices_with_id="$( ( bluetoothctl paired-devices && cat "$PAIRLIST" ) | sort -u | cut -d' ' --complement -f1)"
|
||||||
|
bt_IDS="$(echo "$paired_devices_with_id" | cut -d' ' -f1)"
|
||||||
#de-alias
|
#de-alias
|
||||||
paired_devices="$(echo "$paired_devices_with_id" | while read -r device_line; do
|
paired_devices="$(echo "$paired_devices_with_id" | while read -r device_line; do
|
||||||
id="$(echo "$device_line" | cut -d' ' -f1)"
|
id="$(echo "$device_line" | cut -d' ' -f1)"
|
||||||
@ -135,8 +134,8 @@ pair(){
|
|||||||
scan on > /dev/null
|
scan on > /dev/null
|
||||||
#check whether $SCAN_PERIOD seconds has already passed since starting scanning, if not, wait for the rest of that time.
|
#check whether $SCAN_PERIOD seconds has already passed since starting scanning, if not, wait for the rest of that time.
|
||||||
start_scan="$(cat /tmp/bt_start_scan$$)"
|
start_scan="$(cat /tmp/bt_start_scan$$)"
|
||||||
if [ $(( $(date +'%s') - $start_scan )) -lt $SCAN_PERIOD ]; then
|
if [ $(( $(date +'%s') - start_scan )) -lt "$SCAN_PERIOD" ]; then
|
||||||
sleep_period="$(( $SCAN_PERIOD - $( date +'%s') + $start_scan ))"
|
sleep_period="$(( SCAN_PERIOD - $( date +'%s') + start_scan ))"
|
||||||
[ "$sleep_period" -gt 1 ] && plural="s"
|
[ "$sleep_period" -gt 1 ] && plural="s"
|
||||||
notify-send "bt" "Searching for devices, please wait $sleep_period second$plural"
|
notify-send "bt" "Searching for devices, please wait $sleep_period second$plural"
|
||||||
sleep "$sleep_period"
|
sleep "$sleep_period"
|
||||||
@ -266,7 +265,7 @@ case $choice in
|
|||||||
start_scan="$(cat /tmp/bt_start_scan$$)"
|
start_scan="$(cat /tmp/bt_start_scan$$)"
|
||||||
echo "Scan on"
|
echo "Scan on"
|
||||||
notify-send "bt" "Scanning for new devices until wanted device has been found"
|
notify-send "bt" "Scanning for new devices until wanted device has been found"
|
||||||
while ! echo "$dev_id" | grep -q "$all_devices"; do
|
until echo "$dev_id" | grep -q "$all_devices"; do
|
||||||
sleep 1
|
sleep 1
|
||||||
all_devices="$(bluetoothctl devices | cut -d' ' -f2)"
|
all_devices="$(bluetoothctl devices | cut -d' ' -f2)"
|
||||||
time_scanned="$(( $(date +'%s') - start_scan ))"
|
time_scanned="$(( $(date +'%s') - start_scan ))"
|
||||||
|
3
config
3
config
@ -12,5 +12,4 @@ ALIASLIST=${XDG_CONFIG_HOME:-$HOME/.config}/bt/alias
|
|||||||
|
|
||||||
actions="$(printf 'pair\nunpair\n')"
|
actions="$(printf 'pair\nunpair\n')"
|
||||||
#disconnect menu does not need to be displayed since just directly selecting the connected device will disconnect it
|
#disconnect menu does not need to be displayed since just directly selecting the connected device will disconnect it
|
||||||
#set to anything non-empty to enable
|
include_disconnect_option=false
|
||||||
include_disconnect_option=""
|
|
||||||
|
Loading…
Reference in New Issue
Block a user