Pino Toscano
2018-Nov-06 12:33 UTC
[Libguestfs] [PATCH] p2v: make-disk: rely on os-release for host distro detection
Instead of assuming the latest Fedora version if /etc/redhat-release is available, or the latest Debian with /etc/debian_version, use only /etc/os-release. The possible name of the virt-builder template is created by concatenating $ID and $VERSION_ID, which is generally a better guess than what previously done, and better matches the host OS. This affects only the case when os-version is not specified as command line argument. --- p2v/virt-p2v-make-disk.in | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/p2v/virt-p2v-make-disk.in b/p2v/virt-p2v-make-disk.in index bdf7fd96e..ee65716f2 100644 --- a/p2v/virt-p2v-make-disk.in +++ b/p2v/virt-p2v-make-disk.in @@ -122,12 +122,8 @@ if [ $# -eq 1 ]; then else # If osversion was not set, then we must guess a good value # based on the host distro. - if test -f /etc/redhat-release; then - osversion="$(virt-builder -l | sort | - @AWK@ '/^fedora-[1-9]/ {print $1}' | tail -1)" - elif test -f /etc/debian_version; then - osversion="$(virt-builder -l | sort | - @AWK@ '/^debian-[1-9]/ {print $1}' | tail -1)" + if test -f /etc/os-release; then + osversion="`. /etc/os-release && echo ${ID}-${VERSION_ID}`" fi if [ "x$osversion" = "x" ]; then echo "$program: unable to guess a suitable os-version." -- 2.17.2
Richard W.M. Jones
2018-Nov-06 13:08 UTC
Re: [Libguestfs] [PATCH] p2v: make-disk: rely on os-release for host distro detection
On Tue, Nov 06, 2018 at 01:33:11PM +0100, Pino Toscano wrote:> Instead of assuming the latest Fedora version if /etc/redhat-release is > available, or the latest Debian with /etc/debian_version, use only > /etc/os-release. The possible name of the virt-builder template is > created by concatenating $ID and $VERSION_ID, which is generally a > better guess than what previously done, and better matches the host OS. > > This affects only the case when os-version is not specified as command > line argument. > --- > p2v/virt-p2v-make-disk.in | 8 ++------ > 1 file changed, 2 insertions(+), 6 deletions(-) > > diff --git a/p2v/virt-p2v-make-disk.in b/p2v/virt-p2v-make-disk.in > index bdf7fd96e..ee65716f2 100644 > --- a/p2v/virt-p2v-make-disk.in > +++ b/p2v/virt-p2v-make-disk.in > @@ -122,12 +122,8 @@ if [ $# -eq 1 ]; then > else > # If osversion was not set, then we must guess a good value > # based on the host distro. > - if test -f /etc/redhat-release; then > - osversion="$(virt-builder -l | sort | > - @AWK@ '/^fedora-[1-9]/ {print $1}' | tail -1)" > - elif test -f /etc/debian_version; then > - osversion="$(virt-builder -l | sort | > - @AWK@ '/^debian-[1-9]/ {print $1}' | tail -1)" > + if test -f /etc/os-release; then > + osversion="`. /etc/os-release && echo ${ID}-${VERSION_ID}`" > fi > if [ "x$osversion" = "x" ]; then > echo "$program: unable to guess a suitable os-version."Makes more sense, ACK. Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones Read my programming and virtualization blog: http://rwmj.wordpress.com Fedora Windows cross-compiler. Compile Windows programs, test, and build Windows installers. Over 100 libraries supported. http://fedoraproject.org/wiki/MinGW
Maybe Matching Threads
- [REPOST] Differentiate 'distro' and 'distrofamily' in Sys::Guestfs::Lib
- [PATCH] Differentiate 'distro' and 'distrofamily' in Sys::Guestfs::Lib
- [PATCH] Split $os->{version} into $os->{major_version} and $os->{minor_version}
- [p2v PATCH] make-disk: set p2v.local as hostname
- [PATCH] Replace 'distrofamily' with feature tags