X-Git-Url: http://git.jankratochvil.net/?p=gnokii.git;a=blobdiff_plain;f=include%2Fmisc.h;fp=include%2Fmisc.h;h=c925d6e092959f4bd6c21b1d5b28a7ae20bb2242;hp=3e91ff0eb6cef6852522127efd216662699df8c4;hb=fd99203296000c439603bf62a1cbf289eeba7b9f;hpb=9d80f3acb04fd990119dbefc10aaf5a56de13ea9 diff --git a/include/misc.h b/include/misc.h index 3e91ff0..c925d6e 100644 --- a/include/misc.h +++ b/include/misc.h @@ -13,8 +13,14 @@ Header file for miscellaneous defines, typedefs etc. $Log$ - Revision 1.1.1.1 2001/11/25 21:59:21 short - :pserver:cvs@pserver.samba.org:/cvsroot - gnokii - Sun Nov 25 22:56 CET 2001 + Revision 1.1.1.1.2.1 2001/11/27 04:37:59 short + Update: orig2001_11_25_22_56 -> orig2001_11_27_05_17 + + Revision 1.1.1.2 2001/11/27 04:19:40 short + :pserver:cvs@pserver.samba.org:/cvsroot - gnokii - Tue Nov 27 05:17 CET 2001 + + Revision 1.27 2001/11/26 18:06:08 pkot + Checking for *printf functions, N_(x) for localization, generic ARRAY_LEN, SAFE_STRNCPY, G_GNUC_PRINTF (Jan Kratochvil) Revision 1.26 2001/11/14 10:46:12 pkot Small cleanup with __unices__ @@ -37,117 +43,157 @@ /* Some general defines. */ #ifndef false - #define false (0) +# define false (0) #endif #ifndef true - #define true (!false) +# define true (!false) #endif #ifndef bool - #define bool int +# define bool int #endif +#define ARRAY_LEN(x) (sizeof((x)) / sizeof((x)[0])) + +#define SAFE_STRNCPY(dest, src, n) do { \ + strncpy((dest), (src), (n)); \ + if ((n) > 0) \ + (dest)[(n)-1] = '\0'; \ + } while (0) + +#define SAFE_STRNCPY_SIZEOF(dest,src) \ + SAFE_STRNCPY((dest), (src), sizeof((dest))) + +/* Stolen from : */ +#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ > 4) +# define G_GNUC_PRINTF( format_idx, arg_idx ) \ + __attribute__((format (printf, format_idx, arg_idx))) +#else /* !__GNUC__ */ +# define G_GNUC_PRINTF( format_idx, arg_idx ) +#endif /* !__GNUC__ */ + +#define GNOKII_MAX(a, b) (((a) > (b)) ? (a) : (b)) +#define GNOKII_MIN(a, b) (((a) < (b)) ? (a) : (b)) + /* A define to make debug printfs neat */ #ifndef DEBUG -#define dprintf(a...) do { } while (0) +# define dprintf(a...) do { } while (0) #else -#define dprintf(a...) do { fprintf(stderr, a); fflush(stderr); } while (0) +# define dprintf(a...) do { fprintf(stderr, a); fflush(stderr); } while (0) #endif /* Use gsprintf instead of sprintf and sprintf */ #ifdef HAVE_SNPRINTF -# define gsprintf(a, b, c...) snprintf(a, b, c) +# define gsprintf(a, b, c...) snprintf(a, b, c) +#else +# define gsprintf(a, b, c...) sprintf(a, c) +#endif +#ifdef HAVE_VSNPRINTF +# define gvsprintf(a, b, c...) vsnprintf(a, b, c) #else -# define gsprintf(a, b, c...) sprintf(a, c) +# define gvsprintf(a, b, c...) vsprintf(a, c) +#endif +#ifdef HAVE_ASPRINTF +# define gasprintf(a...) asprintf(a) +#else +#include +extern int gasprintf(char **destp, const char *fmt,...); +#endif +#ifdef HAVE_VASPRINTF +# define gvasprintf(a...) vasprintf(a) +#else +#include +extern int gvasprintf(char **destp, const char *fmt, va_list ap); #endif /* Get rid of long defines. Use #if __unices__ */ #define __unices__ defined(__svr4__) || defined(__FreeBSD__) || defined(__bsdi__) #if __unices__ -# include -# include +# include +# include #endif /* This one is for NLS. */ #ifdef USE_NLS - #include - #define _(x) gettext(x) +# include +# define _(x) gettext(x) +# define N_(x) gettext_noop(x) #else - #define _(x) (x) +# define _(x) (x) +# define N_(x) (x) #endif /* USE_NLS */ /* Definitions for u8, u16, u32 and u64, borrowed from /usr/src/linux/include/asm-i38/types.h */ #ifndef u8 - typedef unsigned char u8; + typedef unsigned char u8; #endif #ifndef u16 - typedef unsigned short u16; + typedef unsigned short u16; #endif #ifndef u32 - typedef unsigned int u32; + typedef unsigned int u32; #endif #ifndef s32 - typedef int s32; + typedef int s32; #endif #if defined(__GNUC__) && !defined(__STRICT_ANSI__) - #ifndef u64 - typedef unsigned long long u64; - #endif +# ifndef u64 + typedef unsigned long long u64; +# endif - #ifndef s64 - typedef signed long long s64; - #endif +# ifndef s64 + typedef signed long long s64; +# endif #endif /* This one is for FreeBSD and similar systems without __ptr_t_ */ /* FIXME: autoconf should take care of this. */ - #ifndef __ptr_t - typedef void * __ptr_t; + typedef void * __ptr_t; #endif /* __ptr_t */ /* Add here any timer operations which are not supported by libc5 */ #ifndef HAVE_TIMEOPS -#ifdef WIN32 - -#include -#include -#define timersub(a, b, result) - do { - (result)->tv_sec = (a)->time - (b)->time; - (result)->tv_usec = ((a)->millitm - (b)->millitm) * 1000; - if ((result)->tv_usec < 0) { - --(result)->tv_sec; - (result)->tv_usec += 1000000; - } - } while (0) -#define gettimeofday(a, b) _ftime(a) - -#else -#include - -#ifndef timersub -#define timersub(a, b, result) \ - do { \ - (result)->tv_sec = (a)->tv_sec - (b)->tv_sec; \ - (result)->tv_usec = (a)->tv_usec - (b)->tv_usec; \ - if ((result)->tv_usec < 0) { \ - --(result)->tv_sec; \ - (result)->tv_usec += 1000000; \ - } \ - } while (0) -#endif - -#endif /* WIN32 */ +# ifdef WIN32 + +# include +# include +# define timersub(a, b, result) + do { + (result)->tv_sec = (a)->time - (b)->time; + (result)->tv_usec = ((a)->millitm - (b)->millitm) * 1000; + if ((result)->tv_usec < 0) { + --(result)->tv_sec; + (result)->tv_usec += 1000000; + } + } while (0) +# define gettimeofday(a, b) _ftime(a) + +# else /* !WIN32 */ +# include + +# ifndef timersub +# define timersub(a, b, result) \ + do { \ + (result)->tv_sec = (a)->tv_sec - (b)->tv_sec; \ + (result)->tv_usec = (a)->tv_usec - (b)->tv_usec; \ + if ((result)->tv_usec < 0) { \ + --(result)->tv_sec; \ + (result)->tv_usec += 1000000; \ + } \ + } while (0) +# endif /* timersub */ + +# endif /* WIN32 */ #endif /* HAVE_TIMEOPS */ @@ -156,9 +202,9 @@ extern int GetLine(FILE *File, char *Line, int count); /* For models table */ typedef struct { - char *model; - char *number; - int flags; + char *model; + char *number; + int flags; } PhoneModel; #define PM_CALLERGROUP 0x0001