This commit is contained in:
Marc Beninca 2023-09-30 19:52:10 +02:00
parent 0dc8e3e6b1
commit 39e1a9b927
15 changed files with 72 additions and 81 deletions

View file

@ -79,15 +79,14 @@ function var_set {
# #
env=\"(\${esp})/grub.env\" env=\"(\${esp})/grub.env\"
live=\"(\${esp})/${PROJECT}/live\" live=\"(\${esp})/${PROJECT}/live\"
menus=\"\${live}/menu\"
# #
for file in \${live}/*.sh ; do for file in \${live}/source/*.sh ; do
source \"\${file}\" source \"\${file}\"
done done
unset file unset file
# #
env_init env_init
normal \"\${menus}/main.sh\" normal \"\${live}/main.sh\"
fi fi
} }

View file

@ -1,25 +1,11 @@
function debsquash { menuentry 'scan →' { menu 'scan' }
boot_toram='true' menuentry 'var →' { menu 'var' }
lmp="${1}" menu_split
sfs="filesystem.squashfs" menuentry 'data / boot / bash / latest / gui' { debsquash '/boot/bash/latest/gui' }
if [ -f "(${data})${lmp}/vmlinuz" ]; then menuentry 'data / boot / bash / latest / tui' { debsquash '/boot/bash/latest/tui' }
linux_path="(${data})${lmp}/vmlinuz" menuentry 'data / boot / bash / stable / gui' { debsquash '/boot/bash/stable/gui' }
initrd_path="(${data})${lmp}/initrd.img" menuentry 'data / boot / bash / stable / tui' { debsquash '/boot/bash/stable/tui' }
else menu_split
linux_path="(squash)/vmlinuz" menuentry "cmd → ${cmdpath}${grub_cpu}-${grub_platform}" { menu 'cmd' }
initrd_path="(squash)/initrd.img" menuentry "env → ${env}${env_mod}" { menu 'env' }
loopback "squash" "${lmp}/${sfs}" menuentry 'gfx → ?' { menu 'gfx' }
fi
boot_linux="linux \
\"${linux_path}\" \
boot=\"live\" \
elevator=\"deadline\" \
ip=\"frommedia\" \
live-media-path=\"${lmp}\" \
toram"
if [ "${boot_toram}" == "true" ]; then
boot_linux="${boot_linux}=\"${sfs}\""
fi
echo_eval "${boot_linux}"
initrd "${initrd_path}"
}

View file

@ -1,13 +0,0 @@
menuentry 'nav →' { menu 'nav' }
menu_split
menuentry 'data / boot / bash / latest / gui' { debsquash '/boot/bash/latest/gui' }
menuentry 'data / boot / bash / latest / tui' { debsquash '/boot/bash/latest/tui' }
menuentry 'data / boot / bash / stable / gui' { debsquash '/boot/bash/stable/gui' }
menuentry 'data / boot / bash / stable / tui' { debsquash '/boot/bash/stable/tui' }
menu_split
menuentry "cmd → ${cmdpath}${grub_cpu}-${grub_platform}" { menu 'cmd' }
menuentry "env → ${env}${env_mod}" { menu 'env' }
menuentry 'gfx → ?' { menu 'gfx' }
menuentry 'ovl → ?' { nop }
menu_split
scan

View file

@ -1,3 +0,0 @@
menu_init "${nav}"
nav "${nav}"

3
live/menu/scan.sh Normal file
View file

@ -0,0 +1,3 @@
menu_init "${scan}"
scan "${scan}"

12
live/menu/var.sh Normal file
View file

@ -0,0 +1,12 @@
menu_init
default='split'
menuentry "check_signatures | ${check_signatures}" { nop }
menuentry "pager | ${pager}" { nop }
menuentry "prefix | ${prefix}" { nop }
menuentry "root | ${root}" { nop }
menu_split 'split'
menuentry "data | ${data}" { nop }
menuentry "esp | ${esp}" { nop }
menuentry "env | ${env}" { nop }
menuentry "env_mod | ${env_mod}" { nop }
menuentry "live | ${live}" { nop }

View file

@ -1,3 +0,0 @@
function scan {
menuentry 'scan' { nop }
}

25
live/source/boot.sh Normal file
View file

@ -0,0 +1,25 @@
function debsquash {
boot_toram='true'
lmp="${1}"
sfs="filesystem.squashfs"
if [ -f "(${data})${lmp}/vmlinuz" ]; then
linux_path="(${data})${lmp}/vmlinuz"
initrd_path="(${data})${lmp}/initrd.img"
else
linux_path="(squash)/vmlinuz"
initrd_path="(squash)/initrd.img"
loopback "squash" "${lmp}/${sfs}"
fi
boot_linux="linux \
\"${linux_path}\" \
boot=\"live\" \
elevator=\"deadline\" \
ip=\"frommedia\" \
live-media-path=\"${lmp}\" \
toram"
if [ "${boot_toram}" == "true" ]; then
boot_linux="${boot_linux}=\"${sfs}\""
fi
echo_eval "${boot_linux}"
initrd "${initrd_path}"
}

View file

@ -1,8 +1,9 @@
function menu { function menu {
if [ "${1}" ] ; then if [ "${1}" ] ; then
menu_load "${1}" "${menus}/${1}.sh" menu_load "${1}"
else else
menu_load 'main' "${menus}/main.sh" export "${menu}"
menu_load "${menu}"
fi fi
} }
@ -37,12 +38,16 @@ function menu_item {
function menu_load { function menu_load {
menu="${1}" menu="${1}"
export menu nav export menu
# env_export # env_export
var_export var_export
configfile "${2}" configfile "${live}/menu/${menu}.sh"
} }
function menu_split { function menu_split {
menuentry '' { nop } if [ "${1}" ] ; then
menuentry '' --id "${1}" { nop }
else
menuentry '' { nop }
fi
} }

View file

@ -1,4 +1,4 @@
function nav { function scan {
if [ "${1}" ] ; then if [ "${1}" ] ; then
paths="${1}/*" paths="${1}/*"
else else
@ -20,8 +20,8 @@ function nav {
if [ "${tmp}" != '*' ] ; then if [ "${tmp}" != '*' ] ; then
if [ -d "${path}" ] ; then if [ -d "${path}" ] ; then
menuentry "${tmp}" "${path}" --id "${path}" { menuentry "${tmp}" "${path}" --id "${path}" {
nav="${2}" scan="${2}"
menu "${menu}" menu
} }
else else
menuentry "${tmp}" { menuentry "${tmp}" {

6
live/source/var.sh Normal file
View file

@ -0,0 +1,6 @@
function var_export {
export \
data esp \
env env_mod \
live
}

View file

@ -1,26 +0,0 @@
function var_echo {
echo "check_signatures: ${check_signatures} | pager: ${pager}"
echo "prefix: ${prefix} | root: ${root}"
echo
echo "data: ${data} | esp: ${esp}"
echo "env: ${env} | env_mod: ${env_mod}"
echo "live: ${live} | menus: ${menus}"
}
function var_export {
export \
data esp \
env env_mod \
live menus
}
function var_menu {
menuentry "check_signatures: ${check_signatures} | pager: ${pager}" {
nop
}
menuentry "prefix: ${prefix} | root: ${root}" { nop }
menu_split
menuentry "data: ${data} | esp: ${esp}" { nop }
menuentry "env: ${env} | env_mod: ${env_mod}" { nop }
menuentry "live: ${live} | menus: ${menus}" { nop }
}