Gentoo bootstrap: fix ambiguous package names + early-return on os_family mismatch
Three issues caught during tadbit onboarding: 1. run_once_00-install-bootstrap-tools.sh.tmpl (gentoo branch): 'gnupg' is ambiguous (app-crypt/gnupg vs app-vim/gnupg). Use full category/package names: app-crypt/gnupg, app-crypt/age, etc. The previous 'for p in age curl ...' loop fed short names to emerge which printed '!!! The short ebuild name gnupg is ambiguous' and exited 1. 2. run_once_20-install-user-packages-gentoo.sh.tmpl: sys-devel/base-devel doesn't exist on Gentoo (it's an Arch/Fedora concept; Gentoo's toolchain is the @system set which is always installed). Removed base-devel from the package list. 3. Universal scripts (run_once_20 + run_once_40) were running on gentoo and hitting either 'die unsupported os_family' (universal 20) or 'WARNING sway packages not configured for gentoo' (universal 40). Added early-return: 'if os_family == gentoo, exit 0' at the top of each universal script so the gentoo-specific scripts handle the box. (Same pattern the chaotic-aur script already had.) 4. run_once_10-add-gentoo-overlays.sh.tmpl: The cached ~/.cache/eselect-repo/repositories.xml was corrupt on tadbit (lxml.etree.XMLSyntaxError on every 'eselect repository list' call). Added a sanity check: parse the XML with xml.etree.ElementTree, delete if invalid, re-fetch. After these fixes, the bootstrap on tadbit is expected to run cleanly with --keep-going (the four failures above all become no-ops).
This commit is contained in:
parent
b5defc5a20
commit
4556813e78
5 changed files with 57 additions and 6 deletions
|
|
@ -30,7 +30,16 @@ if [[ -d /var/db/repos/guru ]]; then
|
|||
log "GURU overlay already enabled at /var/db/repos/guru — skipping"
|
||||
else
|
||||
log "enabling GURU overlay via eselect repository"
|
||||
# `eselect repository` needs the overlays.xml index; sync first if missing
|
||||
# `eselect repository` needs the overlays.xml index. If the cached
|
||||
# one is corrupt (lxml.etree.XMLSyntaxError), delete it and re-fetch.
|
||||
ESEL_REPO_CACHE="${HOME}/.cache/eselect-repo/repositories.xml"
|
||||
if [[ -f "$ESEL_REPO_CACHE" ]]; then
|
||||
# Quick sanity check: try to parse the XML. If invalid, delete.
|
||||
if ! python3 -c "import xml.etree.ElementTree as ET; ET.parse('$ESEL_REPO_CACHE')" 2>/dev/null; then
|
||||
log "WARN: $ESEL_REPO_CACHE is corrupt; removing and re-fetching"
|
||||
rm -f "$ESEL_REPO_CACHE"
|
||||
fi
|
||||
fi
|
||||
if ! sudo eselect repository list 2>&1 | grep -qi guru; then
|
||||
log "fetching overlays.xml index"
|
||||
sudo emaint sync --auto
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue