Skip to content

Commit

Permalink
inspect: support the xbps package manager and its format
Browse files Browse the repository at this point in the history
Associate the Void Linux distribution with it.
  • Loading branch information
ptoscano committed May 24, 2016
1 parent 0251c0f commit 5d1dfe8
Show file tree
Hide file tree
Showing 6 changed files with 18 additions and 4 deletions.
5 changes: 3 additions & 2 deletions generator/actions.ml
Expand Up @@ -1826,7 +1826,8 @@ package format I<or> if the operating system does not have
a real packaging system (eg. Windows).
Possible strings include:
C<rpm>, C<deb>, C<ebuild>, C<pisi>, C<pacman>, C<pkgsrc>, C<apk>.
C<rpm>, C<deb>, C<ebuild>, C<pisi>, C<pacman>, C<pkgsrc>, C<apk>,
C<xbps>.
Future versions of libguestfs may return other strings.
Please read L<guestfs(3)/INSPECTION> for more details." };
Expand All @@ -1848,7 +1849,7 @@ a real packaging system (eg. Windows).
Possible strings include: C<yum>, C<dnf>, C<up2date>,
C<apt> (for all Debian derivatives),
C<portage>, C<pisi>, C<pacman>, C<urpmi>, C<zypper>, C<apk>.
C<portage>, C<pisi>, C<pacman>, C<urpmi>, C<zypper>, C<apk>, C<xbps>.
Future versions of libguestfs may return other strings.
Please read L<guestfs(3)/INSPECTION> for more details." };
Expand Down
2 changes: 2 additions & 0 deletions inspector/virt-inspector.rng
Expand Up @@ -126,6 +126,7 @@
<value>pisi</value>
<value>pkgsrc</value>
<value>rpm</value>
<value>xbps</value>
<!-- "unknown" is intentionally left out -->
</choice>
</element>
Expand All @@ -143,6 +144,7 @@
<value>portage</value>
<value>up2date</value>
<value>urpmi</value>
<value>xbps</value>
<value>yum</value>
<value>zypper</value>
<!-- "unknown" is intentionally left out -->
Expand Down
2 changes: 2 additions & 0 deletions src/guestfs-internal.h
Expand Up @@ -581,6 +581,7 @@ enum inspect_os_package_format {
OS_PACKAGE_FORMAT_PISI,
OS_PACKAGE_FORMAT_PKGSRC,
OS_PACKAGE_FORMAT_APK,
OS_PACKAGE_FORMAT_XBPS,
};

enum inspect_os_package_management {
Expand All @@ -595,6 +596,7 @@ enum inspect_os_package_management {
OS_PACKAGE_MANAGEMENT_ZYPPER,
OS_PACKAGE_MANAGEMENT_DNF,
OS_PACKAGE_MANAGEMENT_APK,
OS_PACKAGE_MANAGEMENT_XBPS,
};

struct inspect_fs {
Expand Down
1 change: 1 addition & 0 deletions src/inspect-apps.c
Expand Up @@ -149,6 +149,7 @@ guestfs_impl_inspect_list_applications2 (guestfs_h *g, const char *root)
case OS_PACKAGE_FORMAT_EBUILD:
case OS_PACKAGE_FORMAT_PISI:
case OS_PACKAGE_FORMAT_PKGSRC:
case OS_PACKAGE_FORMAT_XBPS:
case OS_PACKAGE_FORMAT_UNKNOWN:
; /* nothing */
}
Expand Down
10 changes: 8 additions & 2 deletions src/inspect-fs.c
Expand Up @@ -487,6 +487,10 @@ guestfs_int_check_package_format (guestfs_h *g, struct inspect_fs *fs)
fs->package_format = OS_PACKAGE_FORMAT_APK;
break;

case OS_DISTRO_VOID_LINUX:
fs->package_format = OS_PACKAGE_FORMAT_XBPS;
break;

case OS_DISTRO_SLACKWARE:
case OS_DISTRO_TTYLINUX:
case OS_DISTRO_COREOS:
Expand All @@ -499,7 +503,6 @@ guestfs_int_check_package_format (guestfs_h *g, struct inspect_fs *fs)
case OS_DISTRO_OPENBSD:
case OS_DISTRO_FRUGALWARE:
case OS_DISTRO_PLD_LINUX:
case OS_DISTRO_VOID_LINUX:
case OS_DISTRO_UNKNOWN:
fs->package_format = OS_PACKAGE_FORMAT_UNKNOWN;
break;
Expand Down Expand Up @@ -572,6 +575,10 @@ guestfs_int_check_package_management (guestfs_h *g, struct inspect_fs *fs)
fs->package_management = OS_PACKAGE_MANAGEMENT_APK;
break;

case OS_DISTRO_VOID_LINUX:
fs->package_management = OS_PACKAGE_MANAGEMENT_XBPS;
break;

case OS_DISTRO_SLACKWARE:
case OS_DISTRO_TTYLINUX:
case OS_DISTRO_COREOS:
Expand All @@ -584,7 +591,6 @@ guestfs_int_check_package_management (guestfs_h *g, struct inspect_fs *fs)
case OS_DISTRO_OPENBSD:
case OS_DISTRO_FRUGALWARE:
case OS_DISTRO_PLD_LINUX:
case OS_DISTRO_VOID_LINUX:
case OS_DISTRO_UNKNOWN:
fs->package_management = OS_PACKAGE_MANAGEMENT_UNKNOWN;
break;
Expand Down
2 changes: 2 additions & 0 deletions src/inspect.c
Expand Up @@ -539,6 +539,7 @@ guestfs_impl_inspect_get_package_format (guestfs_h *g, const char *root)
case OS_PACKAGE_FORMAT_PISI: ret = safe_strdup (g, "pisi"); break;
case OS_PACKAGE_FORMAT_PKGSRC: ret = safe_strdup (g, "pkgsrc"); break;
case OS_PACKAGE_FORMAT_APK: ret = safe_strdup (g, "apk"); break;
case OS_PACKAGE_FORMAT_XBPS: ret = safe_strdup (g, "xbps"); break;
case OS_PACKAGE_FORMAT_UNKNOWN:
ret = safe_strdup (g, "unknown");
break;
Expand Down Expand Up @@ -567,6 +568,7 @@ guestfs_impl_inspect_get_package_management (guestfs_h *g, const char *root)
case OS_PACKAGE_MANAGEMENT_PORTAGE: ret = safe_strdup (g, "portage"); break;
case OS_PACKAGE_MANAGEMENT_UP2DATE: ret = safe_strdup (g, "up2date"); break;
case OS_PACKAGE_MANAGEMENT_URPMI: ret = safe_strdup (g, "urpmi"); break;
case OS_PACKAGE_MANAGEMENT_XBPS: ret = safe_strdup (g, "xbps"); break;
case OS_PACKAGE_MANAGEMENT_YUM: ret = safe_strdup (g, "yum"); break;
case OS_PACKAGE_MANAGEMENT_ZYPPER: ret = safe_strdup (g, "zypper"); break;
case OS_PACKAGE_MANAGEMENT_UNKNOWN:
Expand Down

0 comments on commit 5d1dfe8

Please sign in to comment.