Implement progress messages in the daemon and library.
[libguestfs.git] / daemon / wc.c
1 /* libguestfs - the guestfsd daemon
2  * Copyright (C) 2009 Red Hat Inc.
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17  */
18
19 #include <config.h>
20
21 #include <stdio.h>
22 #include <stdlib.h>
23 #include <string.h>
24 #include <unistd.h>
25 #include <fcntl.h>
26
27 #include "../src/guestfs_protocol.h"
28 #include "daemon.h"
29 #include "actions.h"
30
31 static int
32 wc (const char *flag, const char *path)
33 {
34   char *out, *err;
35   int fd, flags, r;
36
37   CHROOT_IN;
38   fd = open (path, O_RDONLY);
39   CHROOT_OUT;
40
41   if (fd == -1) {
42     reply_with_perror ("wc %s: %s", flag, path);
43     return -1;
44   }
45
46   flags = COMMAND_FLAG_CHROOT_COPY_FILE_TO_STDIN | fd;
47   r = commandf (&out, &err, flags, "wc", flag, NULL);
48   if (r == -1) {
49     reply_with_error ("wc %s: %s", flag, err);
50     free (out);
51     free (err);
52     return -1;
53   }
54
55   free (err);
56
57 #if 0
58   /* Split it at the first whitespace. */
59   len = strcspn (out, " \t\n");
60   out[len] = '\0';
61 #endif
62
63   /* Parse the number. */
64   if (sscanf (out, "%d", &r) != 1) {
65     reply_with_error ("cannot parse number: %s", out);
66     free (out);
67     return -1;
68   }
69
70   free (out);
71   return r;
72 }
73
74 int
75 do_wc_l (const char *path)
76 {
77   return wc ("-l", path);
78 }
79
80 int
81 do_wc_w (const char *path)
82 {
83   return wc ("-w", path);
84 }
85
86 int
87 do_wc_c (const char *path)
88 {
89   return wc ("-c", path);
90 }