gpg: Change format for the key size in --list-key and --edit-key.
[gnupg.git] / common / mischelp.h
1 /* mischelp.h - Miscellaneous helper macros and functions
2  * Copyright (C) 1999, 2000, 2001, 2002, 2003,
3  *               2006, 2007, 2009  Free Software Foundation, Inc.
4  *
5  * This file is part of JNLIB, which is a subsystem of GnuPG.
6  *
7  * JNLIB is free software; you can redistribute it and/or modify it
8  * under the terms of either
9  *
10  *   - the GNU Lesser General Public License as published by the Free
11  *     Software Foundation; either version 3 of the License, or (at
12  *     your option) any later version.
13  *
14  * or
15  *
16  *   - the GNU General Public License as published by the Free
17  *     Software Foundation; either version 2 of the License, or (at
18  *     your option) any later version.
19  *
20  * or both in parallel, as here.
21  *
22  * JNLIB is distributed in the hope that it will be useful, but
23  * WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * General Public License for more details.
26  *
27  * You should have received a copies of the GNU General Public License
28  * and the GNU Lesser General Public License along with this program;
29  * if not, see <http://www.gnu.org/licenses/>.
30  */
31
32 #ifndef LIBJNLIB_MISCHELP_H
33 #define LIBJNLIB_MISCHHELP_H
34
35
36 /* Because we can't use the internal jnlib_free macro in inline
37    functions we provide a wrapper function as well.   */
38 void _jnlib_free (void *p);
39
40 /* Check whether the files NAME1 and NAME2 are identical.  This is for
41    example achieved by comparing the inode numbers of the files.  */
42 int same_file_p (const char *name1, const char *name2);
43
44
45 #ifndef HAVE_TIMEGM
46 #include <time.h>
47 time_t timegm (struct tm *tm);
48 #endif /*!HAVE_TIMEGM*/
49
50
51 #define DIM(v)               (sizeof(v)/sizeof((v)[0]))
52 #define DIMof(type,member)   DIM(((type *)0)->member)
53
54
55 #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 5 )
56 # define JNLIB_GCC_M_FUNCTION 1
57 # define JNLIB_GCC_A_NR              __attribute__ ((noreturn))
58 # define JNLIB_GCC_A_PRINTF( f, a )  __attribute__ ((format (printf,f,a)))
59 # define JNLIB_GCC_A_NR_PRINTF( f, a ) \
60                             __attribute__ ((noreturn, format (printf,f,a)))
61 #else
62 # define JNLIB_GCC_A_NR
63 # define JNLIB_GCC_A_PRINTF( f, a )
64 # define JNLIB_GCC_A_NR_PRINTF( f, a )
65 #endif
66
67
68 /* To avoid that a compiler optimizes certain memset calls away, these
69    macros may be used instead. */
70 #define wipememory2(_ptr,_set,_len) do { \
71               volatile char *_vptr=(volatile char *)(_ptr); \
72               size_t _vlen=(_len); \
73               while(_vlen) { *_vptr=(_set); _vptr++; _vlen--; } \
74                   } while(0)
75 #define wipememory(_ptr,_len) wipememory2(_ptr,0,_len)
76
77
78 /* Include hacks which are mainly required for Slowaris.  */
79 #ifdef JNLIB_NEED_AFLOCAL
80 #ifndef HAVE_W32_SYSTEM
81 # include <sys/socket.h>
82 # include <sys/un.h>
83 #else
84 # include <windows.h>
85 #endif
86
87 #ifndef PF_LOCAL
88 # ifdef PF_UNIX
89 #  define PF_LOCAL PF_UNIX
90 # else
91 #  define PF_LOCAL AF_UNIX
92 # endif
93 #endif /*PF_LOCAL*/
94 #ifndef AF_LOCAL
95 # define AF_LOCAL AF_UNIX
96 #endif /*AF_UNIX*/
97
98 /* We used to avoid this macro in GnuPG and inlined the AF_LOCAL name
99    length computation directly with the little twist of adding 1 extra
100    byte.  It seems that this was needed once on an old HP/UX box and
101    there are also rumours that 4.3 Reno and DEC systems need it.  This
102    one-off buglet did not harm any current system until it came to Mac
103    OS X where the kernel (as of May 2009) exhibited a strange bug: The
104    systems basically froze in the connect call if the passed name
105    contained an invalid directory part.  Ignore the old Unices.  */
106 #ifndef SUN_LEN
107 # define SUN_LEN(ptr) ((size_t) (((struct sockaddr_un *) 0)->sun_path) \
108                        + strlen ((ptr)->sun_path))
109 #endif /*SUN_LEN*/
110 #endif /*JNLIB_NEED_AFLOCAL*/
111
112
113 #endif /*LIBJNLIB_MISCHELP_H*/