[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH 3/3]xl: Add "xl rename" command



On Fri, 7 May 2010, Yang Hongyang wrote:
> Hi Keir, Stefano,
> 
> It's based on my previous 2 patchs: Add "xl domid" command / Add "xl domname" 
> command
> 
> ==========================================================
> 
> Add "xl rename" command, a clone of "xm rename".
> 
> Signed-off-by: Yang Hongyang <yanghy@xxxxxxxxxxxxxx>
> 
> diff -r 357eab43f7ee -r 636a21458395 tools/libxl/xl_cmdimpl.c
> --- a/tools/libxl/xl_cmdimpl.c        Fri May 07 20:06:28 2010 +0800
> +++ b/tools/libxl/xl_cmdimpl.c        Fri May 07 22:01:41 2010 +0800
> @@ -1227,6 +1227,9 @@
>      } else if (!strcmp(command, "domname")) {
>          printf("Usage: xl domname <DomainId>\n\n");
>          printf("Convert a domain id to domain name.\n");
> +    } else if (!strcmp(command, "rename")) {
> +        printf("Usage: xl rename <Domain> <NewDomainName>\n\n");
> +        printf("Rename a domain.\n");
>      }
>  }
>  
> @@ -3024,3 +3027,45 @@
>  
>      exit(0);
>  }
> +
> +int main_rename(int argc, char **argv)
> +{
> +    int opt;
> +    char *dom;
> +    char *new_name;
> +    xs_transaction_t t;
> +
> +    while ((opt = getopt(argc, argv, "h")) != -1) {
> +        switch (opt) {
> +        case 'h':
> +            help("rename");
> +            exit(0);
> +        default:
> +            fprintf(stderr, "option `%c' not supported.\n", opt);
> +            break;
> +        }
> +    }
> +
> +    dom = argv[optind++];
> +    if (!dom || !argv[optind]) {
> +        fprintf(stderr, "'xl rename' requires 2 arguments.\n\n");
> +        help("rename");
> +        exit(1);
> +    }
> +
> +    find_domain(dom);
> +    new_name = argv[optind];
> +
> +retry_transaction:
> +    t = xs_transaction_start(ctx.xsh);
> +    if (libxl_domain_rename(&ctx, domid, common_domname, new_name, t)) {
> +        fprintf(stderr, "Can't rename domain '%s'.\n", dom);
> +        exit(1);
> +    }
> +
> +    if (!xs_transaction_end(ctx.xsh, t, 0))
> +        if (errno == EAGAIN)
> +            goto retry_transaction;
> +
> +    exit(0);
> +}

There is no need to explicitly handle the transaction here, just pass 0
to libxl_domain_rename.
In the near future libxl_domain_rename won't take a transaction anymore
(libxl clients shouldn't know about xenstore).



_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.