118 lines
4.1 KiB
C++
118 lines
4.1 KiB
C++
|
|
||
|
// (C) Copyright Edward Diener 2011-2015
|
||
|
// Use, modification and distribution are subject to 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).
|
||
|
|
||
|
#if !defined(BOOST_VMD_IS_IDENTIFIER_HPP)
|
||
|
#define BOOST_VMD_IS_IDENTIFIER_HPP
|
||
|
|
||
|
#include <boost/vmd/detail/setup.hpp>
|
||
|
|
||
|
#if BOOST_PP_VARIADICS
|
||
|
|
||
|
#include <boost/vmd/detail/is_identifier.hpp>
|
||
|
|
||
|
/*
|
||
|
|
||
|
The succeeding comments in this file are in doxygen format.
|
||
|
|
||
|
*/
|
||
|
|
||
|
/** \file
|
||
|
*/
|
||
|
|
||
|
/** \def BOOST_VMD_IS_IDENTIFIER(...)
|
||
|
|
||
|
\brief Tests whether a parameter is an identifier.
|
||
|
|
||
|
... = variadic parameters
|
||
|
|
||
|
The first variadic parameter is required and it is the input to test.
|
||
|
|
||
|
Further variadic parameters are optional and are identifiers to match.
|
||
|
The data may take one of two forms; it is either one or more single identifiers
|
||
|
or a single Boost PP tuple of identifiers.
|
||
|
|
||
|
returns = 1 if the parameter is an identifier, otherwise 0.
|
||
|
|
||
|
If the parameter is not an identifier,
|
||
|
or if optional identifiers are specified and the identifier
|
||
|
does not match any of the optional identifiers, the macro returns 0.
|
||
|
|
||
|
Identifiers are registered in VMD with:
|
||
|
|
||
|
#define BOOST_VMD_REG_XXX (XXX) where XXX is a v-identifier.
|
||
|
|
||
|
The identifier must be registered to be found.
|
||
|
|
||
|
Identifiers are pre-detected in VMD with:
|
||
|
|
||
|
#define BOOST_VMD_DETECT_XXX_XXX where XXX is an identifier.
|
||
|
|
||
|
If you specify optional identifiers and have not specified the detection
|
||
|
of an optional identifier, that optional identifier will never match the input.
|
||
|
|
||
|
If the input is not a VMD data type this macro could lead to
|
||
|
a preprocessor error. This is because the macro
|
||
|
uses preprocessor concatenation to determine if the input
|
||
|
is an identifier once it is determined that the input does not
|
||
|
start with parenthesis. If the data being concatenated would
|
||
|
lead to an invalid preprocessor token the compiler can issue
|
||
|
a preprocessor error.
|
||
|
|
||
|
*/
|
||
|
|
||
|
#define BOOST_VMD_IS_IDENTIFIER(...) \
|
||
|
BOOST_VMD_DETAIL_IS_IDENTIFIER(__VA_ARGS__) \
|
||
|
/**/
|
||
|
|
||
|
/** \def BOOST_VMD_IS_IDENTIFIER_D(d,...)
|
||
|
|
||
|
\brief Tests whether a parameter is an identifier. Re-entrant version.
|
||
|
|
||
|
d = The next available BOOST_PP_WHILE iteration.
|
||
|
... = variadic parameters
|
||
|
|
||
|
The first variadic parameter is required and it is the input to test.
|
||
|
|
||
|
Further variadic parameters are optional and are identifiers to match.
|
||
|
The data may take one of two forms; it is either one or more single identifiers
|
||
|
or a single Boost PP tuple of identifiers.
|
||
|
|
||
|
returns = 1 if the parameter is an identifier, otherwise 0.
|
||
|
|
||
|
If the parameter is not an identifier,
|
||
|
or if optional identifiers are specified and the identifier
|
||
|
does not match any of the optional identifiers, the macro returns 0.
|
||
|
|
||
|
Identifiers are registered in VMD with:
|
||
|
|
||
|
#define BOOST_VMD_REG_XXX (XXX) where XXX is a v-identifier.
|
||
|
|
||
|
The identifier must be registered to be found.
|
||
|
|
||
|
Identifiers are pre-detected in VMD with:
|
||
|
|
||
|
#define BOOST_VMD_DETECT_XXX_XXX where XXX is an identifier.
|
||
|
|
||
|
If you specify optional identifiers and have not specified the detection
|
||
|
of an optional identifier, that optional identifier will never match the input.
|
||
|
|
||
|
If the input is not a VMD data type this macro could lead to
|
||
|
a preprocessor error. This is because the macro
|
||
|
uses preprocessor concatenation to determine if the input
|
||
|
is an identifier once it is determined that the input does not
|
||
|
start with parenthesis. If the data being concatenated would
|
||
|
lead to an invalid preprocessor token the compiler can issue
|
||
|
a preprocessor error.
|
||
|
|
||
|
*/
|
||
|
|
||
|
#define BOOST_VMD_IS_IDENTIFIER_D(d,...) \
|
||
|
BOOST_VMD_DETAIL_IS_IDENTIFIER_D(d,__VA_ARGS__) \
|
||
|
/**/
|
||
|
|
||
|
#endif /* BOOST_PP_VARIADICS */
|
||
|
#endif /* BOOST_VMD_IS_IDENTIFIER_HPP */
|