mirror of
ssh://git.janware.com/janware/proj/jw-pkg
synced 2026-04-24 09:13:37 +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