X-Git-Url: http://git.annexia.org/?p=libguestfs.git;a=blobdiff_plain;f=daemon%2Fstrings.c;h=1ba02419e8fb81c77b9edb3001e165ee7fba02a5;hp=2c52532d38b425077f93090e1d45a1af7d500d29;hb=42f59b28f123f53ae038df23a9abee08e959e46b;hpb=a7b73d4a1e09f12b2002083618056f0c823c1dcf diff --git a/daemon/strings.c b/daemon/strings.c index 2c52532..1ba0241 100644 --- a/daemon/strings.c +++ b/daemon/strings.c @@ -21,35 +21,32 @@ #include #include #include +#include +#include #include "daemon.h" #include "actions.h" char ** -do_strings_e (char *encoding, char *path) +do_strings_e (const char *encoding, const char *path) { - int len; - char *buf; - int r; + int fd, flags, r; char *out, *err; char **lines; - NEED_ROOT (NULL); - ABS_PATH (path, NULL); + CHROOT_IN; + fd = open (path, O_RDONLY); + CHROOT_OUT; - len = strlen (path) + 9; - buf = malloc (len); - if (!buf) { - reply_with_perror ("malloc"); + if (fd == -1) { + reply_with_perror ("%s", path); return NULL; } - snprintf (buf, len, "/sysroot%s", path); - - r = command (&out, &err, "strings", "-e", encoding, buf, NULL); - free (buf); + flags = COMMAND_FLAG_CHROOT_COPY_FILE_TO_STDIN | fd; + r = commandf (&out, &err, flags, "strings", "-e", encoding, NULL); if (r == -1) { - reply_with_error ("strings: %s: %s", path, err); + reply_with_error ("%s: %s", path, err); free (err); free (out); return NULL; @@ -68,7 +65,7 @@ do_strings_e (char *encoding, char *path) } char ** -do_strings (char *path) +do_strings (const char *path) { return do_strings_e ("s", path); }