Richard W.M. Jones
2014-Nov-09 16:14 UTC
Re: [Libguestfs] Add support for slackware in supermin
On Sat, Nov 08, 2014 at 02:27:49PM +0100, Mathieu Bouillaguet wrote:> Hi, > > What needs to be implemented to add support for slackware distribution in > supermin ?hi Mathieu I'm on holiday at the moment and will give a more complete reply when I get back. In brief you need to be able to do a few simple package database meta operations such as listing all files in a package and listing the installed deps of a named pkg. This pre- supposes that slackware has such a packaging db. Pino CCd can give more details, and you can look at existing pkg systems in src/*.ml. Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones Read my programming and virtualization blog: http://rwmj.wordpress.com virt-top is 'top' for virtual machines. Tiny program with many powerful monitoring features, net stats, disk stats, logging, etc. http://people.redhat.com/~rjones/virt-top
Hi Mathieu, On Sunday 09 November 2014 16:14:32 Richard W.M. Jones wrote:> On Sat, Nov 08, 2014 at 02:27:49PM +0100, Mathieu Bouillaguet wrote: > > Hi, > > > > What needs to be implemented to add support for slackware > > distribution in supermin ? > > hi Mathieu > > I'm on holiday at the moment and will give a more complete reply > when I get back. In brief you need to be able to do a few simple > package database meta operations such as listing all files in a > package and listing the installed deps of a named pkg. This pre- > supposes that slackware has such a packaging db. Pino CCd can > give more details, and you can look at existing pkg systems in > src/*.ml.As Rich said briefly, supermin needs to be taught about the package manager running on Slackware. supermin needs it to perform some operations on the system, such as: - query the basic information about a package (name, version, and all the basic attributes such as epoch and architecture, if present/needed to unequivocally identify a package later) given its name - get the last time the package system has "changed" (like after an update, or having installed/removed some package); this is needed so supermin can avoid querying the package system when the set of installed packages has not changed since last time supermin was run - get the list of dependencies of a package - get the list of files of a package, marking whether a file is considered "configuration file" by the package manager; usually this is the case for files in /etc, which the admin can edit, and the package manager carefully handles when updating packages providing them - download and extract packages from the sources of the package manager; this is needed so supermin can pick pristine copies of the files of an installed package, usually to have unedited configuration files supermin supports already few package manager, and you can find in the src/ subdirectory their implementations: dpkg.ml, pacman.ml, rpm.ml. -- Pino Toscano
Mathieu Bouillaguet
2014-Nov-11 14:23 UTC
Re: [Libguestfs] Add support for slackware in supermin
Hi Pino, Thanks for your reply and details. I started looking at the others package manager code and as I see it there is one main problem to port supermin to slackware distro. Slackware builtin package management tools (pkgtool and slackpkg) do not manage package dependencies. There is no easy solution to solve this problem. There are third party packet manager which manage dependencies but they are not supported and I don't personnaly use it. It would be possible to make supermin install only the packages entered on the command line by the user for slackware distro but maybe other tools rely on the package dependency installation semantic. What is your opinion about this ? How supermin is used by other tools like libguestfs ? Thanks for your reply Mathieu Le 10 nov. 2014 19:06, "Pino Toscano" <ptoscano@redhat.com> a écrit :> Hi Mathieu, > > On Sunday 09 November 2014 16:14:32 Richard W.M. Jones wrote: > > On Sat, Nov 08, 2014 at 02:27:49PM +0100, Mathieu Bouillaguet wrote: > > > Hi, > > > > > > What needs to be implemented to add support for slackware > > > distribution in supermin ? > > > > hi Mathieu > > > > I'm on holiday at the moment and will give a more complete reply > > when I get back. In brief you need to be able to do a few simple > > package database meta operations such as listing all files in a > > package and listing the installed deps of a named pkg. This pre- > > supposes that slackware has such a packaging db. Pino CCd can > > give more details, and you can look at existing pkg systems in > > src/*.ml. > > As Rich said briefly, supermin needs to be taught about the package > manager running on Slackware. supermin needs it to perform some > operations on the system, such as: > - query the basic information about a package (name, version, and all > the basic attributes such as epoch and architecture, if present/needed > to unequivocally identify a package later) given its name > - get the last time the package system has "changed" (like after an > update, or having installed/removed some package); this is needed so > supermin can avoid querying the package system when the set of > installed packages has not changed since last time supermin was run > - get the list of dependencies of a package > - get the list of files of a package, marking whether a file is > considered "configuration file" by the package manager; usually this > is the case for files in /etc, which the admin can edit, and the > package manager carefully handles when updating packages providing > them > - download and extract packages from the sources of the package manager; > this is needed so supermin can pick pristine copies of the files of an > installed package, usually to have unedited configuration files > > supermin supports already few package manager, and you can find in the > src/ subdirectory their implementations: dpkg.ml, pacman.ml, rpm.ml. > > -- > Pino Toscano >