gpg: Add dedicated error code for PGP-2 keys.
[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_MISCHELP_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 #undef JNLIB_GCC_HAVE_PUSH_PRAGMA
56 #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 5 )
57 # define JNLIB_GCC_M_FUNCTION 1
58 # define JNLIB_GCC_A_NR              __attribute__ ((noreturn))
59 # if __GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 4 )
60 #   define JNLIB_GCC_HAVE_PUSH_PRAGMA 1
61 #   define JNLIB_GCC_A_PRINTF( f, a ) \
62                     __attribute__ ((format (__gnu_printf__,f,a)))
63 #   define JNLIB_GCC_A_NR_PRINTF( f, a ) \
64                     __attribute__ ((noreturn, format (__gnu_printf__,f,a)))
65 # else
66 #   define JNLIB_GCC_A_PRINTF( f, a )  __attribute__ ((format (printf,f,a)))
67 #   define JNLIB_GCC_A_NR_PRINTF( f, a ) \
68                             __attribute__ ((noreturn, format (printf,f,a)))
69 # endif
70 #else
71 # define JNLIB_GCC_A_NR
72 # define JNLIB_GCC_A_PRINTF( f, a )
73 # define JNLIB_GCC_A_NR_PRINTF( f, a )
74 #endif
75
76
77 /* To avoid that a compiler optimizes certain memset calls away, these
78    macros may be used instead. */
79 #define wipememory2(_ptr,_set,_len) do { \
80               volatile char *_vptr=(volatile char *)(_ptr); \
81               size_t _vlen=(_len); \
82               while(_vlen) { *_vptr=(_set); _vptr++; _vlen--; } \
83                   } while(0)
84 #define wipememory(_ptr,_len) wipememory2(_ptr,0,_len)
85
86
87 /* Include hacks which are mainly required for Slowaris.  */
88 #ifdef JNLIB_NEED_AFLOCAL
89 #ifndef HAVE_W32_SYSTEM
90 # include <sys/socket.h>
91 # include <sys/un.h>
92 #else
93 # ifdef HAVE_WINSOCK2_H
94 #  include <winsock2.h>
95 # endif
96 # include <windows.h>
97 #endif
98
99 #ifndef PF_LOCAL
100 # ifdef PF_UNIX
101 #  define PF_LOCAL PF_UNIX
102 # else
103 #  define PF_LOCAL AF_UNIX
104 # endif
105 #endif /*PF_LOCAL*/
106 #ifndef AF_LOCAL
107 # define AF_LOCAL AF_UNIX
108 #endif /*AF_UNIX*/
109
110 /* We used to avoid this macro in GnuPG and inlined the AF_LOCAL name
111    length computation directly with the little twist of adding 1 extra
112    byte.  It seems that this was needed once on an old HP/UX box and
113    there are also rumours that 4.3 Reno and DEC systems need it.  This
114    one-off buglet did not harm any current system until it came to Mac
115    OS X where the kernel (as of May 2009) exhibited a strange bug: The
116    systems basically froze in the connect call if the passed name
117    contained an invalid directory part.  Ignore the old Unices.  */
118 #ifndef SUN_LEN
119 # define SUN_LEN(ptr) ((size_t) (((struct sockaddr_un *) 0)->sun_path) \
120                        + strlen ((ptr)->sun_path))
121 #endif /*SUN_LEN*/
122 #endif /*JNLIB_NEED_AFLOCAL*/
123
124
125 #endif /*LIBJNLIB_MISCHELP_H*/