macros.h revision cedac228d2dd51db4b79ea1e72c7f249408ee061
1effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Copyright 2014 The Chromium Authors. All rights reserved.
2effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Use of this source code is governed by a BSD-style license that can be
3effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// found in the LICENSE file.
4effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch
5effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#ifndef MOJO_PUBLIC_C_SYSTEM_MACROS_H_
6effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_PUBLIC_C_SYSTEM_MACROS_H_
7effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch
8effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#include <stddef.h>
9effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch
10effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Annotate a variable indicating it's okay if it's unused.
11effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Use like:
12effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch//   int x MOJO_ALLOW_UNUSED = ...;
13effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#if defined(__GNUC__)
14effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_ALLOW_UNUSED __attribute__((unused))
15effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#else
16effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_ALLOW_UNUSED
17effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#endif
18effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch
19effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Annotate a function indicating that the caller must examine the return value.
20effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Use like:
21effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch//   int foo() MOJO_WARN_UNUSED_RESULT;
22effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// Note that it can only be used on the prototype, and not the definition.
23effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#if defined(__GNUC__)
24effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_WARN_UNUSED_RESULT __attribute__((warn_unused_result))
25effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#else
26effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_WARN_UNUSED_RESULT
27effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#endif
28effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch
29cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Assert things at compile time. (|msg| should be a valid identifier name.)
30effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch// This macro is currently C++-only, but we want to use it in the C core.h.
31cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Use like:
32cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)//   MOJO_COMPILE_ASSERT(sizeof(Foo) == 12, Foo_has_invalid_size);
33010d83a9304c5a91596085d917d248abff47903aTorne (Richard Coles)#if __cplusplus >= 201103L
34010d83a9304c5a91596085d917d248abff47903aTorne (Richard Coles)#define MOJO_COMPILE_ASSERT(expr, msg) static_assert(expr, #msg)
35010d83a9304c5a91596085d917d248abff47903aTorne (Richard Coles)#elif defined(__cplusplus)
36effb81e5f8246d0db0270817048dc992db66e9fbBen Murdochnamespace mojo { template <bool> struct CompileAssert {}; }
37effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_COMPILE_ASSERT(expr, msg) \
38effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch    typedef ::mojo::CompileAssert<(bool(expr))> msg[bool(expr) ? 1 : -1]
39effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#else
40effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#define MOJO_COMPILE_ASSERT(expr, msg)
41effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#endif
42effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch
43cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Like the C++11 |alignof| operator.
44cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#if __cplusplus >= 201103L
45cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#define MOJO_ALIGNOF(type) alignof(type)
46cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#elif defined(__GNUC__)
47cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#define MOJO_ALIGNOF(type) __alignof__(type)
48cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#elif defined(_MSC_VER)
49cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// The use of |sizeof| is to work around a bug in MSVC 2010 (see
50cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// http://goo.gl/isH0C; supposedly fixed since then).
51cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#define MOJO_ALIGNOF(type) (sizeof(type) - sizeof(type) + __alignof(type))
52cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#else
53cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#error "Please define MOJO_ALIGNOF() for your compiler."
54cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#endif
55cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)
56cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Specify the alignment of a |struct|, etc.
57cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Use like:
58cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)//   struct MOJO_ALIGNAS(8) Foo { ... };
59cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// Unlike the C++11 |alignas()|, |alignment| must be an integer. It may not be a
60cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// type, nor can it be an expression like |MOJO_ALIGNOF(type)| (due to the
61cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)// non-C++11 MSVS version).
62cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#if __cplusplus >= 201103L
63cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#define MOJO_ALIGNAS(alignment) alignas(alignment)
64cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#elif defined(__GNUC__)
65cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#define MOJO_ALIGNAS(alignment) __attribute__((aligned(alignment)))
66cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#elif defined(_MSC_VER)
67cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#define MOJO_ALIGNAS(alignment) __declspec(align(alignment))
68cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#else
69cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#error "Please define MOJO_ALIGNAS() for your compiler."
70cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)#endif
71cedac228d2dd51db4b79ea1e72c7f249408ee061Torne (Richard Coles)
72effb81e5f8246d0db0270817048dc992db66e9fbBen Murdoch#endif  // MOJO_PUBLIC_C_SYSTEM_MACROS_H_
73