#ifndef _CL_MACROS_H
#define _CL_MACROS_H
+#include "cln/types.h"
+#include "cln/exception.h"
+
// Concatenation of macroexpanded tokens.
// Example:
// #undef x
// Declare functions that don't return.
// nonreturning_function(extern,exit,(void)); == extern void exit (void);
#ifdef __GNUC__
- #if (__GNUC__ >= 3) || ((__GNUC__ == 2) && (__GNUC_MINOR__ >= 90))
+ #if (__GNUC__ >= 3) || ((__GNUC__ == 2) && (__GNUC_MINOR__ >= 9))
#define nonreturning_function(storclass,funname,arguments) \
storclass void funname arguments __attribute__((__noreturn__))
#else
// Denotes a point where control flow can never arrive.
// NOTREACHED
- #define NOTREACHED cl_notreached_abort(__FILE__,__LINE__);
-namespace cln {
- nonreturning_function(extern,cl_notreached_abort, (const char* filename, int lineno));
-} // namespace cln
+ #define NOTREACHED throw notreached_exception(__FILE__,__LINE__);
// Check an arithmetic expression.
// ASSERT(expr)
#if defined(__osf__)
extern "C" char* alloca (int size);
#else
- extern "C" void* alloca (int size);
+ extern "C" void* alloca (size_t size);
#endif
#endif
#elif defined(_AIX)
#elif defined(WATCOM)
#include <malloc.h> // defines `alloca' as a macro
#elif !defined(NO_ALLOCA)
- extern "C" void* alloca (int size);
+ extern "C" void* alloca (size_t size);
#endif
// NULL pointer.
#undef NULL
#define NULL 0
-// Bit number n (0<=n<32)
- #define bit(n) (1L<<(n))
+// Bit number n (0<=n<32 or 0<=n<64)
+ #ifdef HAVE_FAST_LONGLONG
+ #define bit(n) (1LL<<(n))
+ #else
+ #define bit(n) (1L<<(n))
+ #endif
// Bit number n (0<n<=32) mod 2^32
- #define bitm(n) (2L<<((n)-1))
+ #ifdef HAVE_FAST_LONGLONG
+ #define bitm(n) (2LL<<((n)-1))
+ #else
+ #define bitm(n) (2L<<((n)-1))
+ #endif
// Test bit n in x, n constant, x a cl_uint:
#if !(defined(__sparc__) || defined(__sparc64__))
#define bit_test(x,n) ((x) & bit(n))
)
#endif
#endif
-// minus bit number n (0<=n<32)
- #define minus_bit(n) (-1L<<(n))
+// minus bit number n (0<=n<32 or 0<=n<64)
+ #ifdef HAVE_FAST_LONGLONG
+ #define minus_bit(n) (-1LL<<(n))
+ #else
+ #define minus_bit(n) (-1L<<(n))
+ #endif
// minus bit number n (0<n<=32) mod 2^32
- #define minus_bitm(n) (-2L<<((n)-1))
+ #ifdef HAVE_FAST_LONGLONG
+ #define minus_bitm(n) (-2LL<<((n)-1))
+ #else
+ #define minus_bitm(n) (-2L<<((n)-1))
+ #endif
// Return 2^n, n a constant expression.
-// Same as bit(n), but undefined if n<0 or n>=long_bitsize.
- #define bitc(n) (1UL << (((n) >= 0 && (n) < long_bitsize) ? (n) : 0))
+// Same as bit(n), but undefined if n<0 or n>={long_}long_bitsize.
+ #if defined(HAVE_FAST_LONGLONG) || defined(intQsize)
+ #define bitc(n) (1ULL << (((n) >= 0 && (n) < long_long_bitsize) ? (n) : 0))
+ #else
+ #define bitc(n) (1UL << (((n) >= 0 && (n) < long_bitsize) ? (n) : 0))
+ #endif
// floor(a,b) for a>=0, b>0 returns floor(a/b).
// b should be a constant expression.
}
// doconsttimes(count,statement);
-// führt statement count mal aus (count mal der Code!),
+// führt statement count mal aus (count mal der Code!),
// wobei count eine constant-expression >=0, <=8 ist.
#define doconsttimes(count_from_doconsttimes,statement_from_doconsttimes) \
{ if (0 < (count_from_doconsttimes)) { statement_from_doconsttimes; } \
// DOCONSTTIMES(count,macroname);
// ruft count mal den Macro macroname auf (count mal der Code!),
// wobei count eine constant-expression >=0, <=8 ist.
-// Dabei bekommt macroname der Reihe nach die Werte 0,...,count-1 übergeben.
+// Dabei bekommt macroname der Reihe nach die Werte 0,...,count-1 übergeben.
#define DOCONSTTIMES(count_from_DOCONSTTIMES,macroname_from_DOCONSTTIMES) \
{ if (0 < (count_from_DOCONSTTIMES)) { macroname_from_DOCONSTTIMES((0 < (count_from_DOCONSTTIMES) ? 0 : 0)); } \
if (1 < (count_from_DOCONSTTIMES)) { macroname_from_DOCONSTTIMES((1 < (count_from_DOCONSTTIMES) ? 1 : 0)); } \
// it's a shame!)
#define init1(type,lvalue) (void) new (&(lvalue)) type
-// MAYBE_INLINE normally expands to nothing.
-// Useful for including the implementation of some file inline into another.
- #define MAYBE_INLINE
- #define MAYBE_INLINE2
+#include "cl_maybe_inline.h"
#endif /* _CL_MACROS_H */