move pacman.conf body to generator.py, fix check_space for build chroots
with check_space=True, build chroots fail to pacman -S anything, because their rootfs is not a mountpoint, hence pacman's space calculations will fail and return not enough free space. We do want these space checks when pacstrapping device rootfilesystems though.
This commit is contained in:
parent
59747f7a14
commit
2ece1f288c
3 changed files with 84 additions and 76 deletions
|
@ -243,10 +243,10 @@ class Chroot:
|
||||||
# base chroot
|
# base chroot
|
||||||
if reset:
|
if reset:
|
||||||
logging.info(f'Resetting {self.name}')
|
logging.info(f'Resetting {self.name}')
|
||||||
for dir in glob(os.join(self.path, '*')):
|
for dir in glob(os.path.join(self.path, '*')):
|
||||||
rmtree(dir)
|
rmtree(dir)
|
||||||
|
|
||||||
self.write_pacman_conf()
|
self.write_pacman_conf(check_space=True)
|
||||||
self.mount_pacman_cache()
|
self.mount_pacman_cache()
|
||||||
|
|
||||||
logging.info(f'Pacstrapping chroot {self.name}: {", ".join(self.base_packages)}')
|
logging.info(f'Pacstrapping chroot {self.name}: {", ".join(self.base_packages)}')
|
||||||
|
@ -539,9 +539,9 @@ class Chroot:
|
||||||
f.write(makepkg_cross_conf)
|
f.write(makepkg_cross_conf)
|
||||||
return makepkg_conf_path_relative
|
return makepkg_conf_path_relative
|
||||||
|
|
||||||
def write_pacman_conf(self):
|
def write_pacman_conf(self, check_space: bool = False):
|
||||||
os.makedirs(self.get_path('/etc'), exist_ok=True)
|
os.makedirs(self.get_path('/etc'), exist_ok=True)
|
||||||
conf_text = get_base_distro(self.arch).get_pacman_conf(self.extra_repos)
|
conf_text = get_base_distro(self.arch).get_pacman_conf(self.extra_repos, check_space=check_space)
|
||||||
with open(self.get_path('etc/pacman.conf'), 'w') as file:
|
with open(self.get_path('etc/pacman.conf'), 'w') as file:
|
||||||
file.write(conf_text)
|
file.write(conf_text)
|
||||||
|
|
||||||
|
|
75
distro.py
75
distro.py
|
@ -6,6 +6,7 @@ import tarfile
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
from constants import ARCHES, BASE_DISTROS, REPOSITORIES, KUPFER_HTTPS, CHROOT_PATHS
|
from constants import ARCHES, BASE_DISTROS, REPOSITORIES, KUPFER_HTTPS, CHROOT_PATHS
|
||||||
|
from generator import generate_pacman_conf_body
|
||||||
from config import config
|
from config import config
|
||||||
|
|
||||||
|
|
||||||
|
@ -133,77 +134,9 @@ class Distro:
|
||||||
extras = [Repo(name, url_template=info.url_template, arch=self.arch, options=info.options, scan=False) for name, info in extra_repos.items()]
|
extras = [Repo(name, url_template=info.url_template, arch=self.arch, options=info.options, scan=False) for name, info in extra_repos.items()]
|
||||||
return '\n\n'.join(repo.config_snippet() for repo in (list(self.repos.values()) + extras))
|
return '\n\n'.join(repo.config_snippet() for repo in (list(self.repos.values()) + extras))
|
||||||
|
|
||||||
def get_pacman_conf(self, extra_repos: dict[str, RepoInfo] = {}, check_space=True):
|
def get_pacman_conf(self, extra_repos: dict[str, RepoInfo] = {}, check_space: bool = True):
|
||||||
header = f'''
|
body = generate_pacman_conf_body(self.arch, check_space=check_space)
|
||||||
#
|
return body + self.repos_config_snippet(extra_repos)
|
||||||
# /etc/pacman.conf
|
|
||||||
#
|
|
||||||
# See the pacman.conf(5) manpage for option and repository directives
|
|
||||||
|
|
||||||
#
|
|
||||||
# GENERAL OPTIONS
|
|
||||||
#
|
|
||||||
[options]
|
|
||||||
# The following paths are commented out with their default values listed.
|
|
||||||
# If you wish to use different paths, uncomment and update the paths.
|
|
||||||
#RootDir = /
|
|
||||||
#DBPath = /var/lib/pacman/
|
|
||||||
CacheDir = {CHROOT_PATHS['pacman']}/{self.arch}
|
|
||||||
#LogFile = /var/log/pacman.log
|
|
||||||
#GPGDir = /etc/pacman.d/gnupg/
|
|
||||||
#HookDir = /etc/pacman.d/hooks/
|
|
||||||
HoldPkg = pacman glibc
|
|
||||||
#XferCommand = /usr/bin/curl -L -C - -f -o %o %u
|
|
||||||
#XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u
|
|
||||||
#CleanMethod = KeepInstalled
|
|
||||||
Architecture = {self.arch}
|
|
||||||
|
|
||||||
# Pacman won't upgrade packages listed in IgnorePkg and members of IgnoreGroup
|
|
||||||
#IgnorePkg =
|
|
||||||
#IgnoreGroup =
|
|
||||||
|
|
||||||
#NoUpgrade =
|
|
||||||
#NoExtract =
|
|
||||||
|
|
||||||
# Misc options
|
|
||||||
#UseSyslog
|
|
||||||
Color
|
|
||||||
#NoProgressBar
|
|
||||||
{'' if check_space else '#'}CheckSpace
|
|
||||||
VerbosePkgLists
|
|
||||||
ParallelDownloads = {config.file['pacman']['parallel_downloads']}
|
|
||||||
|
|
||||||
# By default, pacman accepts packages signed by keys that its local keyring
|
|
||||||
# trusts (see pacman-key and its man page), as well as unsigned packages.
|
|
||||||
SigLevel = Required DatabaseOptional
|
|
||||||
LocalFileSigLevel = Optional
|
|
||||||
#RemoteFileSigLevel = Required
|
|
||||||
|
|
||||||
# NOTE: You must run `pacman-key --init` before first using pacman; the local
|
|
||||||
# keyring can then be populated with the keys of all official Arch Linux ARM
|
|
||||||
# packagers with `pacman-key --populate archlinuxarm`.
|
|
||||||
|
|
||||||
#
|
|
||||||
# REPOSITORIES
|
|
||||||
# - can be defined here or included from another file
|
|
||||||
# - pacman will search repositories in the order defined here
|
|
||||||
# - local/custom mirrors can be added here or in separate files
|
|
||||||
# - repositories listed first will take precedence when packages
|
|
||||||
# have identical names, regardless of version number
|
|
||||||
# - URLs will have $repo replaced by the name of the current repo
|
|
||||||
# - URLs will have $arch replaced by the name of the architecture
|
|
||||||
#
|
|
||||||
# Repository entries are of the format:
|
|
||||||
# [repo-name]
|
|
||||||
# Server = ServerName
|
|
||||||
# Include = IncludePath
|
|
||||||
#
|
|
||||||
# The header [repo-name] is crucial - it must be present and
|
|
||||||
# uncommented to enable the repo.
|
|
||||||
#
|
|
||||||
|
|
||||||
'''
|
|
||||||
return header + self.repos_config_snippet(extra_repos)
|
|
||||||
|
|
||||||
|
|
||||||
def get_base_distro(arch: str) -> Distro:
|
def get_base_distro(arch: str) -> Distro:
|
||||||
|
|
77
generator.py
77
generator.py
|
@ -1,4 +1,4 @@
|
||||||
from constants import Arch, GCC_HOSTSPECS, CFLAGS_GENERAL, CFLAGS_ARCHES, COMPILE_ARCHES
|
from constants import Arch, GCC_HOSTSPECS, CFLAGS_GENERAL, CFLAGS_ARCHES, COMPILE_ARCHES, CHROOT_PATHS
|
||||||
from config import config
|
from config import config
|
||||||
|
|
||||||
|
|
||||||
|
@ -187,3 +187,78 @@ export LDFLAGS="$LDFLAGS,-L/usr/{hostspec}/lib,-L/{chroot}/usr/lib,-rpath-link,/
|
||||||
'''
|
'''
|
||||||
|
|
||||||
return conf
|
return conf
|
||||||
|
|
||||||
|
|
||||||
|
def generate_pacman_conf_body(
|
||||||
|
arch: Arch,
|
||||||
|
check_space: bool = True,
|
||||||
|
):
|
||||||
|
return f'''
|
||||||
|
#
|
||||||
|
# /etc/pacman.conf
|
||||||
|
#
|
||||||
|
# See the pacman.conf(5) manpage for option and repository directives
|
||||||
|
|
||||||
|
#
|
||||||
|
# GENERAL OPTIONS
|
||||||
|
#
|
||||||
|
[options]
|
||||||
|
# The following paths are commented out with their default values listed.
|
||||||
|
# If you wish to use different paths, uncomment and update the paths.
|
||||||
|
#RootDir = /
|
||||||
|
#DBPath = /var/lib/pacman/
|
||||||
|
CacheDir = {CHROOT_PATHS['pacman']}/{arch}
|
||||||
|
#LogFile = /var/log/pacman.log
|
||||||
|
#GPGDir = /etc/pacman.d/gnupg/
|
||||||
|
#HookDir = /etc/pacman.d/hooks/
|
||||||
|
HoldPkg = pacman glibc
|
||||||
|
#XferCommand = /usr/bin/curl -L -C - -f -o %o %u
|
||||||
|
#XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u
|
||||||
|
#CleanMethod = KeepInstalled
|
||||||
|
Architecture = {arch}
|
||||||
|
|
||||||
|
# Pacman won't upgrade packages listed in IgnorePkg and members of IgnoreGroup
|
||||||
|
#IgnorePkg =
|
||||||
|
#IgnoreGroup =
|
||||||
|
|
||||||
|
#NoUpgrade =
|
||||||
|
#NoExtract =
|
||||||
|
|
||||||
|
# Misc options
|
||||||
|
#UseSyslog
|
||||||
|
Color
|
||||||
|
#NoProgressBar
|
||||||
|
{'' if check_space else '#'}CheckSpace
|
||||||
|
VerbosePkgLists
|
||||||
|
ParallelDownloads = {config.file['pacman']['parallel_downloads']}
|
||||||
|
|
||||||
|
# By default, pacman accepts packages signed by keys that its local keyring
|
||||||
|
# trusts (see pacman-key and its man page), as well as unsigned packages.
|
||||||
|
SigLevel = Required DatabaseOptional
|
||||||
|
LocalFileSigLevel = Optional
|
||||||
|
#RemoteFileSigLevel = Required
|
||||||
|
|
||||||
|
# NOTE: You must run `pacman-key --init` before first using pacman; the local
|
||||||
|
# keyring can then be populated with the keys of all official Arch Linux ARM
|
||||||
|
# packagers with `pacman-key --populate archlinuxarm`.
|
||||||
|
|
||||||
|
#
|
||||||
|
# REPOSITORIES
|
||||||
|
# - can be defined here or included from another file
|
||||||
|
# - pacman will search repositories in the order defined here
|
||||||
|
# - local/custom mirrors can be added here or in separate files
|
||||||
|
# - repositories listed first will take precedence when packages
|
||||||
|
# have identical names, regardless of version number
|
||||||
|
# - URLs will have $repo replaced by the name of the current repo
|
||||||
|
# - URLs will have $arch replaced by the name of the architecture
|
||||||
|
#
|
||||||
|
# Repository entries are of the format:
|
||||||
|
# [repo-name]
|
||||||
|
# Server = ServerName
|
||||||
|
# Include = IncludePath
|
||||||
|
#
|
||||||
|
# The header [repo-name] is crucial - it must be present and
|
||||||
|
# uncommented to enable the repo.
|
||||||
|
#
|
||||||
|
|
||||||
|
'''
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue