* options.h, import.c, keyserver-internal.h, g10.c, mainproc.c,
[gnupg.git] / include / util.h
1 /* util.h
2  * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003
3  *               2004 Free Software Foundation, Inc.
4  *
5  * This file is part of GNUPG.
6  *
7  * GNUPG is free software; you can redistribute it and/or modify
8  * it 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  * GNUPG is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20  */
21 #ifndef G10_UTIL_H
22 #define G10_UTIL_H
23
24 #if defined (_WIN32) || defined (__CYGWIN32__)
25 #include <stdarg.h>
26 #endif
27
28 #include "types.h"
29 #include "errors.h"
30 #include "types.h"
31 #include "mpi.h"
32
33
34 typedef struct {
35      int  *argc;            /* pointer to argc (value subject to change) */
36      char ***argv;          /* pointer to argv (value subject to change) */
37      unsigned flags;        /* Global flags (DO NOT CHANGE) */
38      int err;               /* print error about last option */
39                             /* 1 = warning, 2 = abort */
40      int r_opt;             /* return option */
41      int r_type;            /* type of return value (0 = no argument found)*/
42      union {
43          int   ret_int;
44          long  ret_long;
45          ulong ret_ulong;
46          char *ret_str;
47      } r;                   /* Return values */
48      struct {
49          int idx;
50          int inarg;
51          int stopped;
52          const char *last;
53          void *aliases;
54          const void *cur_alias;
55      } internal;            /* DO NOT CHANGE */
56 } ARGPARSE_ARGS;
57
58 typedef struct {
59     int         short_opt;
60     const char *long_opt;
61     unsigned flags;
62     const char *description; /* optional option description */
63 } ARGPARSE_OPTS;
64
65 /*-- logger.c --*/
66 void log_set_logfile( const char *name, int fd );
67 FILE *log_stream(void);
68 void g10_log_print_prefix(const char *text);
69 void log_set_name( const char *name );
70 const char *log_get_name(void);
71 void log_set_pid( int pid );
72 int  log_get_errorcount( int clear );
73 void log_inc_errorcount(void);
74 int log_set_strict(int val);
75 void g10_log_hexdump( const char *text, const char *buf, size_t len );
76
77 #if defined (__riscos__) \
78     || (__GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 5 ))
79   void g10_log_bug( const char *fmt, ... )
80                             __attribute__ ((noreturn, format (printf,1,2)));
81   void g10_log_bug0( const char *, int, const char * ) __attribute__ ((noreturn));
82   void g10_log_fatal( const char *fmt, ... )
83                             __attribute__ ((noreturn, format (printf,1,2)));
84   void g10_log_error( const char *fmt, ... ) __attribute__ ((format (printf,1,2)));
85   void g10_log_info( const char *fmt, ... )  __attribute__ ((format (printf,1,2)));
86   void g10_log_warning( const char *fmt, ... )  __attribute__ ((format (printf,1,2)));
87   void g10_log_debug( const char *fmt, ... ) __attribute__ ((format (printf,1,2)));
88   void g10_log_fatal_f( const char *fname, const char *fmt, ... )
89                             __attribute__ ((noreturn, format (printf,2,3)));
90   void g10_log_error_f( const char *fname, const char *fmt, ... )
91                             __attribute__ ((format (printf,2,3)));
92   void g10_log_info_f( const char *fname, const char *fmt, ... )
93                             __attribute__ ((format (printf,2,3)));
94   void g10_log_debug_f( const char *fname,  const char *fmt, ... )
95                             __attribute__ ((format (printf,2,3)));
96 #ifndef __riscos__
97 #define BUG() g10_log_bug0(  __FILE__ , __LINE__, __FUNCTION__ )
98 #else
99 #define BUG() g10_log_bug0(  __FILE__ , __LINE__, __func__ )
100 #endif
101 #else
102   void g10_log_bug( const char *fmt, ... );
103   void g10_log_bug0( const char *, int );
104   void g10_log_fatal( const char *fmt, ... );
105   void g10_log_error( const char *fmt, ... );
106   void g10_log_info( const char *fmt, ... );
107   void g10_log_warning( const char *fmt, ... );
108   void g10_log_debug( const char *fmt, ... );
109   void g10_log_fatal_f( const char *fname, const char *fmt, ... );
110   void g10_log_error_f( const char *fname, const char *fmt, ... );
111   void g10_log_info_f( const char *fname, const char *fmt, ... );
112   void g10_log_debug_f( const char *fname, const char *fmt, ... );
113 #define BUG() g10_log_bug0( __FILE__ , __LINE__ )
114 #endif
115
116 #define log_hexdump g10_log_hexdump
117 #define log_bug     g10_log_bug
118 #define log_bug0    g10_log_bug0
119 #define log_fatal   g10_log_fatal
120 #define log_error   g10_log_error
121 #define log_info    g10_log_info
122 #define log_warning g10_log_warning
123 #define log_debug   g10_log_debug
124 #define log_fatal_f g10_log_fatal_f
125 #define log_error_f g10_log_error_f
126 #define log_info_f  g10_log_info_f
127 #define log_debug_f g10_log_debug_f
128
129
130 /*-- errors.c --*/
131 const char * g10_errstr( int no );
132
133 /*-- argparse.c --*/
134 int arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts);
135 int optfile_parse( FILE *fp, const char *filename, unsigned *lineno,
136                    ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts);
137 void usage( int level );
138 const char *default_strusage( int level );
139
140
141 /*-- (main program) --*/
142 const char *strusage( int level );
143
144
145 /*-- dotlock.c --*/
146 struct dotlock_handle;
147 typedef struct dotlock_handle *DOTLOCK;
148
149 void disable_dotlock(void);
150 DOTLOCK create_dotlock( const char *file_to_lock );
151 int make_dotlock( DOTLOCK h, long timeout );
152 int release_dotlock( DOTLOCK h );
153 void remove_lockfiles (void);
154
155 /*-- fileutil.c --*/
156 char * make_basename(const char *filepath, const char *inputpath);
157 char * make_dirname(const char *filepath);
158 char *make_filename( const char *first_part, ... );
159 int compare_filenames( const char *a, const char *b );
160 const char *print_fname_stdin( const char *s );
161 const char *print_fname_stdout( const char *s );
162 int is_file_compressed(const char *s, int *r_status);
163
164 /*-- miscutil.c --*/
165 u32 make_timestamp(void);
166 u32 scan_isodatestr( const char *string );
167 u32 add_days_to_timestamp( u32 stamp, u16 days );
168 const char *strtimevalue( u32 stamp );
169 const char *strtimestamp( u32 stamp ); /* GMT */
170 const char *asctimestamp( u32 stamp ); /* localized */
171 void print_string( FILE *fp, const byte *p, size_t n, int delim );
172 void print_string2( FILE *fp, const byte *p, size_t n, int delim, int delim2 );
173 void  print_utf8_string( FILE *fp, const byte *p, size_t n );
174 void  print_utf8_string2( FILE *fp, const byte *p, size_t n, int delim);
175 char *make_printable_string( const byte *p, size_t n, int delim );
176 int answer_is_yes_no_default( const char *s, int def_answer );
177 int answer_is_yes( const char *s );
178 int answer_is_yes_no_quit( const char *s );
179 int answer_is_okay_cancel (const char *s, int def_answer);
180 int match_multistr(const char *multistr,const char *match);
181 int hextobyte( const char *s );
182
183 /*-- strgutil.c --*/
184 void free_strlist( STRLIST sl );
185 #define FREE_STRLIST(a) do { free_strlist((a)); (a) = NULL ; } while(0)
186 STRLIST add_to_strlist( STRLIST *list, const char *string );
187 STRLIST add_to_strlist2( STRLIST *list, const char *string, int is_utf8 );
188 STRLIST append_to_strlist( STRLIST *list, const char *string );
189 STRLIST append_to_strlist2( STRLIST *list, const char *string, int is_utf8 );
190 STRLIST strlist_prev( STRLIST head, STRLIST node );
191 STRLIST strlist_last( STRLIST node );
192 char *pop_strlist( STRLIST *list );
193 const char *memistr( const char *buf, size_t buflen, const char *sub );
194 const char *ascii_memistr( const char *buf, size_t buflen, const char *sub );
195 char *mem2str( char *, const void *, size_t);
196 char *trim_spaces( char *string );
197 unsigned int trim_trailing_chars( byte *line, unsigned int len,
198                                   const char *trimchars);
199 unsigned int trim_trailing_ws( byte *line, unsigned len );
200 unsigned int check_trailing_chars( const byte *line, unsigned int len,
201                                    const char *trimchars );
202 unsigned int check_trailing_ws( const byte *line, unsigned int len );
203 int string_count_chr( const char *string, int c );
204 int set_native_charset( const char *newset );
205 const char* get_native_charset(void);
206 char *native_to_utf8( const char *string );
207 char *utf8_to_native( const char *string, size_t length, int delim);
208 int  check_utf8_string( const char *string );
209
210 int ascii_isupper (int c);
211 int ascii_islower (int c);
212 int ascii_toupper (int c);
213 int ascii_tolower (int c);
214 int ascii_strcasecmp( const char *a, const char *b );
215 int ascii_strncasecmp( const char *a, const char *b, size_t n);
216 int ascii_memcasecmp( const char *a, const char *b, size_t n);
217
218 #ifndef HAVE_STPCPY
219 char *stpcpy(char *a,const char *b);
220 #endif
221 #ifndef HAVE_STRLWR
222 char *strlwr(char *a);
223 #endif
224 #ifndef HAVE_STRSEP
225 char *strsep (char **stringp, const char *delim);
226 #endif
227 #ifndef HAVE_STRCASECMP
228 int strcasecmp( const char *, const char *b);
229 #endif
230 #ifndef HAVE_STRNCASECMP
231 int strncasecmp (const char *, const char *b, size_t n);
232 #endif
233 #ifndef HAVE_STRTOUL
234 #define strtoul(a,b,c)  ((unsigned long)strtol((a),(b),(c)))
235 #endif
236 #ifndef HAVE_MEMMOVE
237 #define memmove(d, s, n) bcopy((s), (d), (n))
238 #endif
239
240 #if defined (_WIN32)
241 /*-- w32reg.c --*/
242 char *read_w32_registry_string( const char *root,
243                                 const char *dir, const char *name );
244 int write_w32_registry_string(const char *root, const char *dir,
245                               const char *name, const char *value);
246
247 /*-- strgutil.c --*/
248 int vasprintf (char **result, const char *format, va_list args);
249 int asprintf (char **buf, const char *fmt, ...);
250 #endif
251
252 /**** other missing stuff ****/
253 #ifndef HAVE_ATEXIT  /* For SunOS */
254 #define atexit(a)    (on_exit((a),0))
255 #endif
256
257 #ifndef HAVE_RAISE
258 #define raise(a) kill(getpid(), (a))
259 #endif
260
261 /******** some macros ************/
262 #ifndef STR
263 #define STR(v) #v
264 #endif
265 #define STR2(v) STR(v)
266 #define DIM(v) (sizeof(v)/sizeof((v)[0]))
267 #define DIMof(type,member)   DIM(((type *)0)->member)
268
269 #define wipememory2(_ptr,_set,_len) do { volatile char *_vptr=(volatile char *)(_ptr); size_t _vlen=(_len); while(_vlen) { *_vptr=(_set); _vptr++; _vlen--; } } while(0)
270 #define wipememory(_ptr,_len) wipememory2(_ptr,0,_len)
271
272 /*-- macros to replace ctype ones and avoid locale problems --*/
273 #define spacep(p)   (*(p) == ' ' || *(p) == '\t')
274 #define digitp(p)   (*(p) >= '0' && *(p) <= '9')
275 #define hexdigitp(a) (digitp (a)                     \
276                       || (*(a) >= 'A' && *(a) <= 'F')  \
277                       || (*(a) >= 'a' && *(a) <= 'f'))
278 /* the atoi macros assume that the buffer has only valid digits */
279 #define atoi_1(p)   (*(p) - '0' )
280 #define atoi_2(p)   ((atoi_1(p) * 10) + atoi_1((p)+1))
281 #define atoi_4(p)   ((atoi_2(p) * 100) + atoi_2((p)+2))
282 #define xtoi_1(p)   (*(p) <= '9'? (*(p)- '0'): \
283                      *(p) <= 'F'? (*(p)-'A'+10):(*(p)-'a'+10))
284 #define xtoi_2(p)   ((xtoi_1(p) * 16) + xtoi_1((p)+1))
285
286 /* Note this isn't identical to a C locale isspace() without \f and
287    \v, but works for the purposes used here. */
288 #define ascii_isspace(a) ((a)==' ' || (a)=='\n' || (a)=='\r' || (a)=='\t')
289
290 /******* RISC OS stuff ***********/
291 #ifdef __riscos__
292 int riscos_load_module(const char *name, const char * const path[], int fatal);
293 int riscos_get_filetype_from_string(const char *string, int len);
294 int riscos_get_filetype(const char *filename);
295 void riscos_set_filetype_by_number(const char *filename, int type);
296 void riscos_set_filetype_by_mimetype(const char *filename, const char *mimetype);
297 pid_t riscos_getpid(void);
298 int riscos_kill(pid_t pid, int sig);
299 int riscos_access(const char *path, int amode);
300 int riscos_getchar(void);
301 char *riscos_make_basename(const char *filepath, const char *inputpath);
302 int riscos_check_regexp(const char *exp, const char *string, int debug);
303 int riscos_fdopenfile(const char *filename, const int allow_write);
304 void riscos_close_fds(void);
305 int riscos_renamefile(const char *old, const char *new);
306 char *riscos_gstrans(const char *old);
307 void riscos_not_implemented(const char *feature);
308 #ifdef DEBUG
309 void riscos_dump_fdlist(void);
310 void riscos_list_openfiles(void);
311 #endif
312 #ifndef __RISCOS__C__
313 #define getpid riscos_getpid
314 #define kill(a,b) riscos_kill((a),(b))
315 #define access(a,b) riscos_access((a),(b))
316 #endif /* !__RISCOS__C__ */
317 #endif /* __riscos__ */
318
319 #endif /*G10_UTIL_H*/