d322052e4b68219ed46c98a004f9165f483290dd
[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
27 #include "util.h"
28 #include "context.h"
29
30
31 GpgmeError
32 _gpgme_progress_status_handler (void *priv, GpgmeStatusCode code, char *args)
33 {
34   GpgmeCtx ctx = (GpgmeCtx) priv;
35   char *p;
36   char *args_cpy;
37   int type = 0;
38   int current = 0;
39   int total = 0;
40
41   if (code != GPGME_STATUS_PROGRESS || !*args || !ctx->progress_cb)
42     return 0;
43
44   args_cpy = strdup (args);
45   if (!args_cpy)
46     return GPGME_Out_Of_Core;
47
48   p = strchr (args_cpy, ' ');
49   if (p)
50     {
51       *p++ = 0;
52       if (*p)
53         {
54           type = *(unsigned char *)p;
55           p = strchr (p+1, ' ');
56           if (p)
57             {
58               *p++ = 0;
59               if (*p)
60                 {
61                   current = atoi (p);
62                   p = strchr (p+1, ' ');
63                   if (p)
64                     {
65                       *p++ = 0;
66                       total = atoi (p);
67                     }
68                 }
69             }
70         }
71     }           
72
73   if (type != 'X')
74     ctx->progress_cb (ctx->progress_cb_value, args_cpy, type, current, total);
75
76   free (args_cpy);
77   return 0;
78 }