diff options
author | Richard Jones <rjones@redhat.com> | 2010-09-09 14:11:32 +0100 |
---|---|---|
committer | Richard Jones <rjones@redhat.com> | 2010-09-09 14:11:32 +0100 |
commit | 639ca1828b167bf59353f0cd3c8c79c6289bbd5d (patch) | |
tree | a9bb3fbd7de0fb674e050c4de64a5ce480291fdf /fish/more.c | |
parent | b5c287bcd456bdb02d8ec0443483df34f4fd6b5d (diff) | |
download | libguestfs-639ca1828b167bf59353f0cd3c8c79c6289bbd5d.tar.gz libguestfs-639ca1828b167bf59353f0cd3c8c79c6289bbd5d.tar.xz libguestfs-639ca1828b167bf59353f0cd3c8c79c6289bbd5d.zip |
fish: Fix 'more' command to work with any file.
Diffstat (limited to 'fish/more.c')
-rw-r--r-- | fish/more.c | 12 |
1 files changed, 2 insertions, 10 deletions
diff --git a/fish/more.c b/fish/more.c index a32d5b41..55faefa8 100644 --- a/fish/more.c +++ b/fish/more.c @@ -33,7 +33,6 @@ do_more (const char *cmd, int argc, char *argv[]) char filename[] = "/tmp/guestfishXXXXXX"; char buf[256]; const char *pager; - char *content; int r, fd; if (argc != 1) { @@ -57,21 +56,14 @@ do_more (const char *cmd, int argc, char *argv[]) return -1; } - if ((content = guestfs_cat (g, argv[0])) == NULL) { - close (fd); - unlink (filename); - return -1; - } + snprintf (buf, sizeof buf, "/dev/fd/%d", fd); - if (xwrite (fd, content, strlen (content)) == -1) { + if (guestfs_download (g, argv[0], buf) == -1) { close (fd); unlink (filename); - free (content); return -1; } - free (content); - if (close (fd) == -1) { perror (filename); unlink (filename); |