* mainproc.c (list_node): Show sigs with --verbose.
[gnupg.git] / g10 / progress.c
1 /* progress.c
2  * Copyright (C) 2003 Free Software Foundation, Inc.
3  *
4  * This file is part of GnuPG.
5  *
6  * GnuPG is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * GnuPG is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
19  */
20
21 #include <config.h>
22 #include <stdio.h>
23
24 #include "iobuf.h"
25 #include "filter.h"
26 #include "status.h"
27 #include "util.h"
28 #include "options.h"
29
30 /****************
31  * The filter is used to report progress to the user.
32  */
33 int
34 progress_filter (void *opaque, int control,
35                  IOBUF a, byte *buf, size_t *ret_len)
36 {
37   int rc = 0;
38   progress_filter_context_t *pfx = opaque;
39
40   if (control == IOBUFCTRL_INIT)
41     {
42       char buffer[50];
43
44       pfx->last = 0;
45       pfx->offset = 0;
46       pfx->last_time = make_timestamp ();
47
48       sprintf (buffer, "%.20s ? %lu %lu",
49                pfx->what? pfx->what : "?",
50                pfx->offset,
51                pfx->total);
52       write_status_text (STATUS_PROGRESS, buffer);
53     }
54   else if (control == IOBUFCTRL_UNDERFLOW)
55     {
56       u32 timestamp = make_timestamp ();
57       int len = iobuf_read (a, buf, *ret_len);
58
59       if (len >= 0)
60         {
61           pfx->offset += len;
62           *ret_len = len;
63         }
64       else
65         {
66           *ret_len = 0;
67           rc = -1;
68         }
69       if ((len == -1 && pfx->offset != pfx->last)
70           || timestamp - pfx->last_time > 0)
71         {
72           char buffer[50];
73           
74           sprintf (buffer, "%.20s ? %lu %lu",
75                    pfx->what? pfx->what : "?", 
76                    pfx->offset,
77                    pfx->total);
78           write_status_text (STATUS_PROGRESS, buffer);
79
80           pfx->last = pfx->offset;
81           pfx->last_time = timestamp;
82         }
83     }
84   else if (control == IOBUFCTRL_FREE)
85     {
86       /* Note, that we must always dealloc resources of a filter
87          within the filter handler and not anywhere else.  (We set it
88          to NULL and check all uses just in case.) */
89       m_free (pfx->what);
90       pfx->what = NULL;
91     }
92   else if (control == IOBUFCTRL_DESC)
93     *(char**)buf = "progress_filter";
94   return rc;
95 }
96
97 void
98 handle_progress (progress_filter_context_t *pfx, IOBUF inp, const char *name)
99 {
100   off_t filesize = 0;
101
102   if (!opt.enable_progress_filter)
103     return;
104
105   if (!is_status_enabled ())
106     return;
107
108   if (name && *name && !(*name == '-' && !name[1]))
109     filesize = iobuf_get_filelength (inp);
110   else if (opt.set_filesize)
111     filesize = opt.set_filesize;
112
113   /* register the progress filter */
114   pfx->what = m_strdup (name ? name : "stdin");
115   pfx->total = filesize;
116   iobuf_push_filter (inp, progress_filter, pfx);
117 }