2026-03-05 10:54:32 +01:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
|
|
import re, sys
|
|
|
|
|
from argparse import ArgumentParser
|
|
|
|
|
|
lib.Distro, ExecContext: Add classes, refactor lib.distro
The code below lib.distro, as left behind by the previous commit, is
geared towards being directly used as a command-line API. This commit
introduces the abstract base class Distro, a proxy for
distribution-specific interactions. The proxy abstracts distro
specifics into an API with proper method prototypes, not
argparse.Namespace contents, and can thus be more easily driven by
arbitrary code.
The Distro class is initialized with a member variable of type
ExecContext, another new class introduced by this commit. It is
designed to abstract the communication channel to the distribution
instance. Currently only one specialization exists, Local, which
interacts with the distribution and root file system it is running
in, but is planned to be subclassed to support interaction via SSH,
serial, chroot, or chains thereof.
Signed-off-by: Jan Lindemann <jan@janware.com>
2026-03-05 17:33:52 +01:00
|
|
|
from ..lib.Distro import Distro
|
2026-03-05 10:54:32 +01:00
|
|
|
from ..App import App
|
|
|
|
|
from .Cmd import Cmd as Base
|
|
|
|
|
|
|
|
|
|
class DistroBase(Base): # export
|
|
|
|
|
|
|
|
|
|
def __init__(self, parent: App|Base, name: str, help: str) -> None:
|
|
|
|
|
self.__id = None
|
|
|
|
|
super().__init__(parent, name, help)
|
|
|
|
|
self._add_subcommands()
|
lib.Distro, ExecContext: Add classes, refactor lib.distro
The code below lib.distro, as left behind by the previous commit, is
geared towards being directly used as a command-line API. This commit
introduces the abstract base class Distro, a proxy for
distribution-specific interactions. The proxy abstracts distro
specifics into an API with proper method prototypes, not
argparse.Namespace contents, and can thus be more easily driven by
arbitrary code.
The Distro class is initialized with a member variable of type
ExecContext, another new class introduced by this commit. It is
designed to abstract the communication channel to the distribution
instance. Currently only one specialization exists, Local, which
interacts with the distribution and root file system it is running
in, but is planned to be subclassed to support interaction via SSH,
serial, chroot, or chains thereof.
Signed-off-by: Jan Lindemann <jan@janware.com>
2026-03-05 17:33:52 +01:00
|
|
|
self.__distro: Distro|None = None
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def distro(self) -> Distro:
|
|
|
|
|
if self.__distro is None:
|
|
|
|
|
ret = Distro.instantiate(self.distro_id, ec=self.app.exec_context)
|
|
|
|
|
self.__distro = ret
|
|
|
|
|
return self.__distro
|
|
|
|
|
|
|
|
|
|
# --------------- legacy methods
|
2026-03-05 10:54:32 +01:00
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
def distro_id(self):
|
|
|
|
|
if self.__id is None:
|
|
|
|
|
if self.app.args.id is not None:
|
|
|
|
|
# The distribution ID requested by the command line
|
|
|
|
|
self.__id = self.app.args.id
|
|
|
|
|
else:
|
|
|
|
|
# The ID of the distribution we run on
|
|
|
|
|
self.__id = self.app.distro_id
|
|
|
|
|
return self.__id
|
|
|
|
|
|
|
|
|
|
def add_arguments(self, p: ArgumentParser) -> None:
|
|
|
|
|
super().add_arguments(p)
|
|
|
|
|
p.add_argument('--id', default=None, help='Distribution ID (default is taken from /etc/os-release)')
|
|
|
|
|
|
|
|
|
|
async def _run(self, args):
|
|
|
|
|
# Missing subcommand
|
|
|
|
|
self.parser.print_help()
|
|
|
|
|
sys.exit(1)
|