BOOST_PP_REPEAT マクロは高速な横断的繰り返しを表す。
Usage
BOOST_PP_REPEAT(count, macro, data)
Arguments
-
count:macroを呼ぶ繰り返しの回数。 有効な値の範囲は0からBOOST_PP_LIMIT_REPEATまでである。 -
macro:macro(z, n, data)という形の 3つ組の演算。 このマクロはBOOST_PP_REPEATによって、 利用可能な次の繰り返しの深さ、現在の繰り返し回数、付属のdataに展開される。 -
data:macroに渡される付属のデータ。
Remarks
このマクロは次のシーケンスに展開される:
macro(z, 0, data) macro(z, 1, data) ... macro(z, count - 1, data)
macro に渡される z の値は利用可能な次の繰り返し次元を表す。 _Z 接尾辞をもつ他のマクロとその仲間は内部で、BOOST_PP_REPEAT を利用している - 例えば、 BOOST_PP_ENUM_PARAMS と BOOST_PP_ENUM_PARAMS_Z などである。 これらの _Z バージョンを使うことは厳密には必要ではないが、(macro に渡される) z の値をこれらのマクロに渡すことで、最も効率的に BOOST_PP_REPEAT に再入することが出来る。
この z の値を、単純に別のマクロに渡すのではなく、直接使うためには、BOOST_PP_REPEAT_z を見よ。
以前、このマクロは BOOST_PP_REPEAT の中で再帰的に使うことは出来なかった。 この制限はもう存在しない。 ライブラリは自動的に、利用可能な次の繰り返しの深さを検出できる。
See Also
Requirements
Header: <boost/preprocessor/repetition/repeat.hpp>
Sample Code
#include <boost/preprocessor/repetition/repeat.hpp>
#define DECL(z, n, text) text ## n = n;
BOOST_PP_REPEAT(5, DECL, int x)