Header file for miscellaneous defines, typedefs etc.
$Log$
- 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__
+ Revision 1.1.1.4 2002/04/03 00:08:19 short
+ Found in "gnokii-working" directory, some November-patches version
Revision 1.25 2001/07/03 15:27:14 pkot
AT commands for SMS handling support (Tamas Bondar)
#ifndef __misc_h
#define __misc_h
-#include "config.h"
+#include <config.h>
/* 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 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'; \
+#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)))
+ SAFE_STRNCPY((dest),(src),sizeof((dest)))
/* Stolen from <glib.h>: */
#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ > 4)
-# define G_GNUC_PRINTF( format_idx, arg_idx ) \
- __attribute__((format (printf, format_idx, arg_idx)))
+#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 )
+#define G_GNUC_PRINTF( format_idx, arg_idx )
#endif /* !__GNUC__ */
#define GNOKII_MAX(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)
+# define gsprintf(a, b, c...) sprintf(a, c)
#endif
#ifdef HAVE_VSNPRINTF
-# define gvsprintf(a, b, c...) vsnprintf(a, b, c)
+# define gvsprintf(a, b, c...) vsnprintf(a, b, c)
#else
-# define gvsprintf(a, b, c...) vsprintf(a, c)
+# define gvsprintf(a, b, c...) vsprintf(a, c)
#endif
#ifdef HAVE_ASPRINTF
-# define gasprintf(a...) asprintf(a)
+# define gasprintf(a...) asprintf(a)
#else
#include <stdarg.h>
-extern int gasprintf(char **destp, const char *fmt,...);
+extern int gasprintf(char **destp,const char *fmt,...);
#endif
#ifdef HAVE_VASPRINTF
-# define gvasprintf(a...) vasprintf(a)
+# define gvasprintf(a...) vasprintf(a)
#else
#include <stdarg.h>
-extern int gvasprintf(char **destp, const char *fmt, va_list ap);
+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 <strings.h>
-# include <sys/file.h>
-#endif
/* This one is for NLS. */
#ifdef USE_NLS
-# include <libintl.h>
-# define _(x) gettext(x)
-# define N_(x) gettext_noop(x)
+ #include <libintl.h>
+ #define _(x) gettext(x)
#else
-# define _(x) (x)
-# define N_(x) (x)
+ #define _(x) (x)
#endif /* USE_NLS */
+#define N_(x) (x)
/* 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 <windows.h>
-# include <sys/timeb.h>
-# 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 <sys/time.h>
-
-# 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 */
+#ifdef WIN32
+
+#include <windows.h>
+#include <sys/timeb.h>
+#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 <sys/time.h>
+
+#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 */
+#endif /* WIN32 */
#endif /* HAVE_TIMEOPS */
/* For models table */
typedef struct {
- char *model;
- char *number;
- int flags;
+ char *model;
+ char *number;
+ int flags;
} PhoneModel;
#define PM_CALLERGROUP 0x0001