mirror of
ssh://git.janware.com/janware/proj/jw-pkg
synced 2026-04-24 17:23:36 +02:00
jw.pkg.cmds.distro.backend.arch: Add Module
Add Arch backend for pacman-based package management. Signed-off-by: Jan Lindemann <jan@janware.com>
This commit is contained in:
parent
f6a8b6307a
commit
45af308ae6
5 changed files with 64 additions and 0 deletions
16
src/python/jw/pkg/cmds/distro/backend/arch/Base.py
Normal file
16
src/python/jw/pkg/cmds/distro/backend/arch/Base.py
Normal file
|
|
@ -0,0 +1,16 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
from ...Cmd import Cmd
|
||||||
|
from ..BackendCmd import BackendCmd
|
||||||
|
|
||||||
|
class Base(BackendCmd):
|
||||||
|
|
||||||
|
def __init__(self, parent: Cmd):
|
||||||
|
super().__init__(parent)
|
||||||
|
|
||||||
|
async def pacman(self, *args):
|
||||||
|
cmd = ['/usr/bin/pacman']
|
||||||
|
if not self.interactive:
|
||||||
|
cmd.extend(['--noconfirm'])
|
||||||
|
cmd.extend(args)
|
||||||
|
return await self._sudo(cmd)
|
||||||
14
src/python/jw/pkg/cmds/distro/backend/arch/Dup.py
Normal file
14
src/python/jw/pkg/cmds/distro/backend/arch/Dup.py
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
from argparse import Namespace
|
||||||
|
|
||||||
|
from ...Cmd import Cmd
|
||||||
|
from .Base import Base
|
||||||
|
|
||||||
|
class Dup(Base):
|
||||||
|
|
||||||
|
def __init__(self, parent: Cmd):
|
||||||
|
super().__init__(parent)
|
||||||
|
|
||||||
|
async def run(self, args: Namespace):
|
||||||
|
raise NotImplementedError('distro dup is not yet implemented for Arch-like distributions')
|
||||||
16
src/python/jw/pkg/cmds/distro/backend/arch/Install.py
Normal file
16
src/python/jw/pkg/cmds/distro/backend/arch/Install.py
Normal file
|
|
@ -0,0 +1,16 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
from argparse import Namespace
|
||||||
|
|
||||||
|
from ...Cmd import Cmd
|
||||||
|
from .Base import Base
|
||||||
|
|
||||||
|
class Install(Base):
|
||||||
|
|
||||||
|
def __init__(self, parent: Cmd):
|
||||||
|
super().__init__(parent)
|
||||||
|
|
||||||
|
async def run(self, args: Namespace):
|
||||||
|
pacman_args = ['-S', '--needed']
|
||||||
|
pacman_args.extend(args.packages)
|
||||||
|
await self.pacman(*pacman_args)
|
||||||
4
src/python/jw/pkg/cmds/distro/backend/arch/Makefile
Normal file
4
src/python/jw/pkg/cmds/distro/backend/arch/Makefile
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
TOPDIR = ../../../../../../../..
|
||||||
|
|
||||||
|
include $(TOPDIR)/make/proj.mk
|
||||||
|
include $(JWBDIR)/make/py-mod.mk
|
||||||
14
src/python/jw/pkg/cmds/distro/backend/arch/Refresh.py
Normal file
14
src/python/jw/pkg/cmds/distro/backend/arch/Refresh.py
Normal file
|
|
@ -0,0 +1,14 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
from argparse import Namespace
|
||||||
|
|
||||||
|
from ...Cmd import Cmd
|
||||||
|
from .Base import Base
|
||||||
|
|
||||||
|
class Refresh(Base):
|
||||||
|
|
||||||
|
def __init__(self, parent: Cmd):
|
||||||
|
super().__init__(parent)
|
||||||
|
|
||||||
|
async def run(self, args: Namespace):
|
||||||
|
raise NotImplementedError('distro refresh is not yet implemented for Arch-like distributions')
|
||||||
Loading…
Add table
Add a link
Reference in a new issue