X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Fcpmv.c;h=587e017d61ed5a354828c883e7d683598fff5b08;hp=b87d7a46a4b4664ad47d3c7d47ed4514c9ae691d;hb=3aa8182c3cc478bf723205f1a4dd84e160768448;hpb=887290e949d54c6ac4c9b787231e588f84f2367c diff --git a/daemon/cpmv.c b/daemon/cpmv.c index b87d7a4..587e017 100644 --- a/daemon/cpmv.c +++ b/daemon/cpmv.c @@ -1,5 +1,5 @@ /* libguestfs - the guestfsd daemon - * Copyright (C) 2009 Red Hat Inc. + * Copyright (C) 2009 Red Hat Inc. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -28,19 +28,19 @@ static int cpmv_cmd (const char *cmd, const char *flags, const char *src, const char *dest); int -do_cp (char *src, char *dest) +do_cp (const char *src, const char *dest) { return cpmv_cmd ("cp", NULL, src, dest); } int -do_cp_a (char *src, char *dest) +do_cp_a (const char *src, const char *dest) { return cpmv_cmd ("cp", "-a", src, dest); } int -do_mv (char *src, char *dest) +do_mv (const char *src, const char *dest) { return cpmv_cmd ("mv", NULL, src, dest); } @@ -49,32 +49,22 @@ static int cpmv_cmd (const char *cmd, const char *flags, const char *src, const char *dest) { char *srcbuf, *destbuf; - int srclen, destlen; char *err; int r; - NEED_ROOT (-1); - ABS_PATH (src, -1); - ABS_PATH (dest, -1); - - srclen = strlen (src) + 32; - srcbuf = malloc (srclen); + srcbuf = sysroot_path (src); if (srcbuf == NULL) { reply_with_perror ("malloc"); return -1; } - destlen = strlen (dest) + 32; - destbuf = malloc (destlen); + destbuf = sysroot_path (dest); if (destbuf == NULL) { reply_with_perror ("malloc"); free (srcbuf); return -1; } - snprintf (srcbuf, srclen, "/sysroot%s", src); - snprintf (destbuf, destlen, "/sysroot%s", dest); - if (flags) r = command (NULL, &err, cmd, flags, srcbuf, destbuf, NULL); else @@ -84,7 +74,7 @@ cpmv_cmd (const char *cmd, const char *flags, const char *src, const char *dest) free (destbuf); if (r == -1) { - reply_with_error ("%s: %s", cmd, err); + reply_with_error ("%s", err); free (err); return -1; }