2004-06-23 Marcus Brinkmann <marcus@g10code.de>
[gpgme.git] / gpgme / progress.c
1 /* progress.c -  status handler for progress status
2    Copyright (C) 2000 Werner Koch (dd9jn)
3    Copyright (C) 2001, 2002, 2003 g10 Code GmbH
4  
5    This file is part of GPGME.
6  
7    GPGME is free software; you can redistribute it and/or modify it
8    under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11  
12    GPGME is distributed in the hope that it will be useful, but
13    WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15    General Public License for more details.
16  
17    You should have received a copy of the GNU General Public License
18    along with GPGME; if not, write to the Free Software Foundation,
19    Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
20
21 #ifdef HAVE_CONFIG_H
22 #include <config.h>
23 #endif
24 #include <stdlib.h>
25 #include <string.h>
26 #include <errno.h>
27
28 #include "util.h"
29 #include "context.h"
30
31
32 gpgme_error_t
33 _gpgme_progress_status_handler (void *priv, gpgme_status_code_t code,
34                                 char *args)
35 {
36   gpgme_ctx_t ctx = (gpgme_ctx_t) priv;
37   char *p;
38   char *args_cpy;
39   int type = 0;
40   int current = 0;
41   int total = 0;
42
43   if (code != GPGME_STATUS_PROGRESS || !*args || !ctx->progress_cb)
44     return 0;
45
46   args_cpy = strdup (args);
47   if (!args_cpy)
48     return gpg_error_from_errno (errno);
49
50   p = strchr (args_cpy, ' ');
51   if (p)
52     {
53       *p++ = 0;
54       if (*p)
55         {
56           type = *(unsigned char *)p;
57           p = strchr (p+1, ' ');
58           if (p)
59             {
60               *p++ = 0;
61               if (*p)
62                 {
63                   current = atoi (p);
64                   p = strchr (p+1, ' ');
65                   if (p)
66                     {
67                       *p++ = 0;
68                       total = atoi (p);
69                     }
70                 }
71             }
72         }
73     }           
74
75   if (type != 'X')
76     ctx->progress_cb (ctx->progress_cb_value, args_cpy, type, current, total);
77
78   free (args_cpy);
79   return 0;
80 }