[Libguestfs] [PATCH] blkid: split the RHEL5 which can't support some options
Richard W.M. Jones
rjones at redhat.com
Mon Dec 5 08:57:22 UTC 2011
On Mon, Dec 05, 2011 at 02:22:43PM +0800, Wanlong Gao wrote:
> RHEL5 shoult not support '-p', '-i' and '-o export' options.
> But we just split it according to the '-p' option.
>
> Signed-off-by: Wanlong Gao <gaowanlong at cn.fujitsu.com>
> ---
> daemon/blkid.c | 80 +++++++++++++++++++++++++++++++++++++++++++++++++++-----
> 1 files changed, 73 insertions(+), 7 deletions(-)
>
> diff --git a/daemon/blkid.c b/daemon/blkid.c
> index a7fd6bc..8c2cdc6 100644
> --- a/daemon/blkid.c
> +++ b/daemon/blkid.c
> @@ -84,18 +84,42 @@ do_vfs_uuid (const char *device)
> return get_blkid_tag (device, "UUID");
> }
>
> -char **
> -do_blkid(const char *device)
> +/* RHEL5 blkid doesn't have the -p(partition info) option and the
> + * -i(I/O limits) option so we must test for these options the first
> + * time the function is called.
> + */
> +static int
> +test_blkid_p_opt(void)
> +{
> + static int result = -1;
Don't initialize 'result' as it prevents the compiler from warning
about problems in the code.
> + char *err = NULL;
> +
> + int r = commandr (NULL, &err, "blkid", "-p", "/dev/null", NULL);
> + if (r == -1) {
> + reply_with_error("Could not run 'blkid' command");
reply_with_error("could not run 'blkid' command: %s", err);
> + free(err);
> + return -1;
> + }
> +
> + if (err && strstr(err, "invalid option --"))
err is never NULL here, since commandr always sets it, so you don't
need the 'err &&' ... part.
> + result = 0;
> + else
> + result = 1;
> + free(err);
> + return result;
> +}
> +
> +static char **
> +blkid_with_p_opt(const char *device)
> {
> int r;
> char *out = NULL, *err = NULL;
> char **lines = NULL;
> -
> char **ret = NULL;
> int size = 0, alloc = 0;
>
> - const char *blkid[] = {"blkid", "-p", "-i", "-o", "export", device, NULL};
> - r = commandv(&out, &err, blkid);
> + r = command(&out, &err, "blkid", "-c", "/dev/null",
> + "-p", "-i", "-o", "export", device, NULL);
> if (r == -1) {
> reply_with_error("%s", err);
> goto error;
> @@ -142,12 +166,12 @@ do_blkid(const char *device)
> }
> }
>
> + if (add_string(&ret, &size, &alloc, NULL) == -1) goto error;
> +
> free(out);
> free(err);
> free(lines);
>
> - if (add_string(&ret, &size, &alloc, NULL) == -1) return NULL;
> -
> return ret;
>
> error:
> @@ -158,3 +182,45 @@ error:
>
> return NULL;
> }
> +
> +static char **
> +blkid_without_p_opt(const char *device)
> +{
> + char **ret = NULL;
> + int size = 0, alloc = 0;
> +
> + if (add_string(&ret, &size, &alloc, "TYPE") == -1) goto error;
> + if (add_string(&ret, &size, &alloc, get_blkid_tag(device, "TYPE")) == -1)
> + goto error;
> + if (add_string(&ret, &size, &alloc, "LABEL") == -1) goto error;
> + if (add_string(&ret, &size, &alloc, get_blkid_tag(device, "LABEL")) == -1)
> + goto error;
> + if (add_string(&ret, &size, &alloc, "UUID") == -1) goto error;
> + if (add_string(&ret, &size, &alloc, get_blkid_tag(device, "UUID")) == -1)
> + goto error;
> + if (add_string_nodup(&ret, &size, &alloc, NULL) == -1) goto error;
> +
> + return ret;
> +error:
> + if (ret) free_strings(ret);
> + return NULL;
> +}
> +
> +char **
> +do_blkid(const char *device)
> +{
> + int r;
> + char *out = NULL, *err = NULL;
> + char **lines = NULL;
> +
> + char **ret = NULL;
> + int size = 0, alloc = 0;
> + int blkid_has_p_opt = -1;
^ blkid_has_p_opt shouldn't be initialized, since we are about to
unconditionally assign to it here:
> + if ((blkid_has_p_opt = test_blkid_p_opt()) == -1)
> + return NULL;
> + else if (blkid_has_p_opt)
> + return blkid_with_p_opt(device);
> + else
> + return blkid_without_p_opt(device);
> +}
> --
> 1.7.8.rc4
OK, but can you fix those things.
Rich.
--
Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones
libguestfs lets you edit virtual machines. Supports shell scripting,
bindings from many languages. http://libguestfs.org
More information about the Libguestfs
mailing list