diff options
author | Egor Tensin <egor@tensin.name> | 2025-09-10 11:35:49 +0200 |
---|---|---|
committer | Egor Tensin <egor@tensin.name> | 2025-09-10 11:36:40 +0200 |
commit | 6ebedc72e1e0d6d1c824915a73d51e1f8925af77 (patch) | |
tree | 48e35bab9fe2b2d3a83e8aedb14ef27d98d13cfa /bin/script | |
parent | add README & LICENSE, just for fun (diff) | |
download | grub-reboot-into-windows-6ebedc72e1e0d6d1c824915a73d51e1f8925af77.tar.gz grub-reboot-into-windows-6ebedc72e1e0d6d1c824915a73d51e1f8925af77.zip |
Diffstat (limited to 'bin/script')
-rwxr-xr-x | bin/script | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/bin/script b/bin/script new file mode 100755 index 0000000..a6584b9 --- /dev/null +++ b/bin/script @@ -0,0 +1,43 @@ +#!/usr/bin/env bash + +set -o errexit -o nounset -o pipefail +shopt -s inherit_errexit lastpipe + +readonly cfg_path=/boot/grub/grub.cfg + +get_windows_menu_entry() { + local windows_entries + windows_entries="$( awk -F\' '/menuentry / {print $2}' "$cfg_path" | grep -Fi Windows )" + + local numof_entries + numof_entries="$( echo "$windows_entries" | wc -l )" + + if [ "$numof_entries" -ne 1 ]; then + echo "Don't know which one of the following entries to select:" >&2 + echo "$windows_entries" >&2 + return 1 + fi + + echo "$windows_entries" +} + +main() { + local entry + entry="$( get_windows_menu_entry )" + + # grub-reboot returns 0 even if something like a permission error happens. + # It does print something in that case though, and nothing after a + # successful termination. + local output + output="$( grub-reboot "$entry" )" + + if [ -n "$output" ]; then + echo "grub-reboot probably exited with an error:" >&2 + echo "$output" >&2 + return 1 + fi + + reboot +} + +main |