Back to Arangodb

BOOST_MPL_ASSERT

3rdParty/boost/1.78.0/libs/mpl/doc/src/refmanual/ASSERT.rst

3.12.9.12.2 KB
Original Source

.. Macros/Asserts//BOOST_MPL_ASSERT

BOOST_MPL_ASSERT

Synopsis

.. parsed-literal::

#define BOOST_MPL_ASSERT( pred ) \\
    |unspecified-token-seq| \\
/\*\*/

Description

Generates a compilation error when the predicate pred holds false.

.. parsed-literal::

#include <boost/mpl/assert.hpp>

Parameters

+---------------+-----------------------------------+-------------------------------+ | Parameter | Requirement | Description | +===============+===================================+===============================+ | pred | Boolean nullary |Metafunction| | A predicate to be asserted. | +---------------+-----------------------------------+-------------------------------+

Expression semantics

For any boolean nullary |Metafunction| pred:

.. parsed-literal::

BOOST_MPL_ASSERT(( pred ));

:Return type: None.

:Semantics: Generates a compilation error if pred::type::value != true, otherwise has no effect. Note that double parentheses are required even if no commas appear in the condition.

When possible within the compiler's diagnostic capabilities,
the error message will include the predicate's full type name, and have a 
general form of:

.. parsed-literal::

   |...| \*\*\*\*\*\*\*\*\*\*\*\* pred::\*\*\*\*\*\*\*\*\*\*\*\* |...|

Example

::

template< typename T, typename U > struct my
{
    // ...
    BOOST_MPL_ASSERT(( is_same< T,U > ));
};

my<void*,char*> test;

// In instantiation of `my<void, char*>':
//   instantiated from here
// conversion from `
//   mpl_::failed************boost::is_same<void, char*>::************' to 
//   non-scalar type `mpl_::assert<false>' requested

See also

|Asserts|, |BOOST_MPL_ASSERT_NOT|, |BOOST_MPL_ASSERT_MSG|, |BOOST_MPL_ASSERT_RELATION|

.. copyright:: Copyright 2001-2009 Aleksey Gurtovoy and David Abrahams Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)