forked from boostorg/preprocessor
Use detail check for number 1 rather than empty implementation.
This commit is contained in:
@ -18,12 +18,12 @@
|
|||||||
# include <boost/preprocessor/config/config.hpp>
|
# include <boost/preprocessor/config/config.hpp>
|
||||||
# include <boost/preprocessor/control/iif.hpp>
|
# include <boost/preprocessor/control/iif.hpp>
|
||||||
# include <boost/preprocessor/facilities/identity.hpp>
|
# include <boost/preprocessor/facilities/identity.hpp>
|
||||||
# include <boost/preprocessor/facilities/is_1.hpp>
|
|
||||||
# include <boost/preprocessor/tuple/elem.hpp>
|
# include <boost/preprocessor/tuple/elem.hpp>
|
||||||
|
# include <boost/preprocessor/arithmetic/detail/is_1_number.hpp>
|
||||||
#
|
#
|
||||||
# /* BOOST_PP_DIV */
|
# /* BOOST_PP_DIV */
|
||||||
#
|
#
|
||||||
# define BOOST_PP_DIV(x, y) BOOST_PP_IIF(BOOST_PP_IS_1(y),BOOST_PP_IDENTITY_N(x,2),BOOST_PP_DIV_DO)(x,y)
|
# define BOOST_PP_DIV(x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(y),BOOST_PP_IDENTITY_N(x,2),BOOST_PP_DIV_DO)(x,y)
|
||||||
#
|
#
|
||||||
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
||||||
# define BOOST_PP_DIV_DO(x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_DIV_BASE(x, y))
|
# define BOOST_PP_DIV_DO(x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_DIV_BASE(x, y))
|
||||||
@ -34,7 +34,7 @@
|
|||||||
#
|
#
|
||||||
# /* BOOST_PP_DIV_D */
|
# /* BOOST_PP_DIV_D */
|
||||||
#
|
#
|
||||||
# define BOOST_PP_DIV_D(d, x, y) BOOST_PP_IIF(BOOST_PP_IS_1(y),BOOST_PP_IDENTITY_N(x,3),BOOST_PP_DIV_DO_D)(d,x,y)
|
# define BOOST_PP_DIV_D(d, x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(y),BOOST_PP_IDENTITY_N(x,3),BOOST_PP_DIV_DO_D)(d,x,y)
|
||||||
#
|
#
|
||||||
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
||||||
# define BOOST_PP_DIV_DO_D(d, x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_DIV_BASE_D(d, x, y))
|
# define BOOST_PP_DIV_DO_D(d, x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_DIV_BASE_D(d, x, y))
|
||||||
|
@ -18,12 +18,12 @@
|
|||||||
# include <boost/preprocessor/config/config.hpp>
|
# include <boost/preprocessor/config/config.hpp>
|
||||||
# include <boost/preprocessor/control/iif.hpp>
|
# include <boost/preprocessor/control/iif.hpp>
|
||||||
# include <boost/preprocessor/facilities/identity.hpp>
|
# include <boost/preprocessor/facilities/identity.hpp>
|
||||||
# include <boost/preprocessor/facilities/is_1.hpp>
|
|
||||||
# include <boost/preprocessor/tuple/elem.hpp>
|
# include <boost/preprocessor/tuple/elem.hpp>
|
||||||
|
# include <boost/preprocessor/arithmetic/detail/is_1_number.hpp>
|
||||||
#
|
#
|
||||||
# /* BOOST_PP_MOD */
|
# /* BOOST_PP_MOD */
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MOD(x, y) BOOST_PP_IIF(BOOST_PP_IS_1(y),BOOST_PP_IDENTITY_N(0,2),BOOST_PP_MOD_DO)(x,y)
|
# define BOOST_PP_MOD(x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(y),BOOST_PP_IDENTITY_N(0,2),BOOST_PP_MOD_DO)(x,y)
|
||||||
#
|
#
|
||||||
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
||||||
# define BOOST_PP_MOD_DO(x, y) BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_DIV_BASE(x, y))
|
# define BOOST_PP_MOD_DO(x, y) BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_DIV_BASE(x, y))
|
||||||
@ -34,7 +34,7 @@
|
|||||||
#
|
#
|
||||||
# /* BOOST_PP_MOD_D */
|
# /* BOOST_PP_MOD_D */
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MOD_D(d, x, y) BOOST_PP_IIF(BOOST_PP_IS_1(y),BOOST_PP_IDENTITY_N(0,3),BOOST_PP_MOD_DO_D)(d,x,y)
|
# define BOOST_PP_MOD_D(d, x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(y),BOOST_PP_IDENTITY_N(0,3),BOOST_PP_MOD_DO_D)(d,x,y)
|
||||||
#
|
#
|
||||||
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
||||||
# define BOOST_PP_MOD_DO_D(d, x, y) BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_DIV_BASE_D(d, x, y))
|
# define BOOST_PP_MOD_DO_D(d, x, y) BOOST_PP_TUPLE_ELEM(3, 1, BOOST_PP_DIV_BASE_D(d, x, y))
|
||||||
|
@ -20,7 +20,6 @@
|
|||||||
# include <boost/preprocessor/control/iif.hpp>
|
# include <boost/preprocessor/control/iif.hpp>
|
||||||
# include <boost/preprocessor/control/while.hpp>
|
# include <boost/preprocessor/control/while.hpp>
|
||||||
# include <boost/preprocessor/facilities/identity.hpp>
|
# include <boost/preprocessor/facilities/identity.hpp>
|
||||||
# include <boost/preprocessor/facilities/is_1.hpp>
|
|
||||||
# include <boost/preprocessor/logical/bitand.hpp>
|
# include <boost/preprocessor/logical/bitand.hpp>
|
||||||
# include <boost/preprocessor/logical/bitor.hpp>
|
# include <boost/preprocessor/logical/bitor.hpp>
|
||||||
# include <boost/preprocessor/logical/bool.hpp>
|
# include <boost/preprocessor/logical/bool.hpp>
|
||||||
@ -29,15 +28,16 @@
|
|||||||
# include <boost/preprocessor/tuple/rem.hpp>
|
# include <boost/preprocessor/tuple/rem.hpp>
|
||||||
# include <boost/preprocessor/arithmetic/detail/is_minimum_number.hpp>
|
# include <boost/preprocessor/arithmetic/detail/is_minimum_number.hpp>
|
||||||
# include <boost/preprocessor/arithmetic/detail/is_maximum_number.hpp>
|
# include <boost/preprocessor/arithmetic/detail/is_maximum_number.hpp>
|
||||||
|
# include <boost/preprocessor/arithmetic/detail/is_1_number.hpp>
|
||||||
#
|
#
|
||||||
# /* BOOST_PP_MUL */
|
# /* BOOST_PP_MUL */
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MUL(x, y) \
|
# define BOOST_PP_MUL(x, y) \
|
||||||
BOOST_PP_IIF(BOOST_PP_BITOR(BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(x),BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(y)),BOOST_PP_IDENTITY_N(0,2),BOOST_PP_MUL_CHECK_1X)(x,y)
|
BOOST_PP_IIF(BOOST_PP_BITOR(BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(x),BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(y)),BOOST_PP_IDENTITY_N(0,2),BOOST_PP_MUL_CHECK_1X)(x,y)
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MUL_CHECK_1X(x, y) BOOST_PP_IIF(BOOST_PP_IS_1(x),BOOST_PP_IDENTITY_N(y,2),BOOST_PP_MUL_CHECK_1Y)(x,y)
|
# define BOOST_PP_MUL_CHECK_1X(x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(x),BOOST_PP_IDENTITY_N(y,2),BOOST_PP_MUL_CHECK_1Y)(x,y)
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MUL_CHECK_1Y(x, y) BOOST_PP_IIF(BOOST_PP_IS_1(y),BOOST_PP_IDENTITY_N(x,2),BOOST_PP_MUL_DO)(x,y)
|
# define BOOST_PP_MUL_CHECK_1Y(x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(y),BOOST_PP_IDENTITY_N(x,2),BOOST_PP_MUL_DO)(x,y)
|
||||||
#
|
#
|
||||||
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
||||||
# define BOOST_PP_MUL_DO(x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_WHILE(BOOST_PP_MUL_P, BOOST_PP_MUL_O, (0, x, y)))
|
# define BOOST_PP_MUL_DO(x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_WHILE(BOOST_PP_MUL_P, BOOST_PP_MUL_O, (0, x, y)))
|
||||||
@ -62,9 +62,9 @@
|
|||||||
# define BOOST_PP_MUL_D(d, x, y) \
|
# define BOOST_PP_MUL_D(d, x, y) \
|
||||||
BOOST_PP_IIF(BOOST_PP_BITOR(BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(x),BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(y)),BOOST_PP_IDENTITY_N(0,3),BOOST_PP_MUL_CHECK_1X_D)(d,x,y)
|
BOOST_PP_IIF(BOOST_PP_BITOR(BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(x),BOOST_PP_DETAIL_IS_MINIMUM_NUMBER(y)),BOOST_PP_IDENTITY_N(0,3),BOOST_PP_MUL_CHECK_1X_D)(d,x,y)
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MUL_CHECK_1X_D(d, x, y) BOOST_PP_IIF(BOOST_PP_IS_1(x),BOOST_PP_IDENTITY_N(y,3),BOOST_PP_MUL_CHECK_1Y)(d,x,y)
|
# define BOOST_PP_MUL_CHECK_1X_D(d, x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(x),BOOST_PP_IDENTITY_N(y,3),BOOST_PP_MUL_CHECK_1Y)(d,x,y)
|
||||||
#
|
#
|
||||||
# define BOOST_PP_MUL_CHECK_1Y_D(d, x, y) BOOST_PP_IIF(BOOST_PP_IS_1(y),BOOST_PP_IDENTITY_N(x,3),BOOST_PP_MUL_DO_D)(d,x,y)
|
# define BOOST_PP_MUL_CHECK_1Y_D(d, x, y) BOOST_PP_IIF(BOOST_PP_DETAIL_IS_1_NUMBER(y),BOOST_PP_IDENTITY_N(x,3),BOOST_PP_MUL_DO_D)(d,x,y)
|
||||||
#
|
#
|
||||||
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
# if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
|
||||||
# define BOOST_PP_MUL_DO_D(d, x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_WHILE_ ## d(BOOST_PP_MUL_P, BOOST_PP_MUL_O, (0, x, y)))
|
# define BOOST_PP_MUL_DO_D(d, x, y) BOOST_PP_TUPLE_ELEM(3, 0, BOOST_PP_WHILE_ ## d(BOOST_PP_MUL_P, BOOST_PP_MUL_O, (0, x, y)))
|
||||||
|
@ -17,6 +17,10 @@
|
|||||||
|
|
||||||
BEGIN BOOST_PP_ADD(2, 3) == 5 END
|
BEGIN BOOST_PP_ADD(2, 3) == 5 END
|
||||||
|
|
||||||
|
BEGIN BOOST_PP_ADD(BOOST_PP_ADD(2, 2), 2) == 6 END
|
||||||
|
BEGIN BOOST_PP_ADD(2, BOOST_PP_ADD(1, 4)) == 7 END
|
||||||
|
BEGIN BOOST_PP_ADD(BOOST_PP_ADD(2, 2), BOOST_PP_ADD(2, 2)) == 8 END
|
||||||
|
|
||||||
#if BOOST_PP_LIMIT_MAG == 256
|
#if BOOST_PP_LIMIT_MAG == 256
|
||||||
|
|
||||||
BEGIN BOOST_PP_ADD(1, 256) == 256 END
|
BEGIN BOOST_PP_ADD(1, 256) == 256 END
|
||||||
@ -28,10 +32,6 @@ BEGIN BOOST_PP_ADD(255, 1) == 256 END
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
BEGIN BOOST_PP_ADD(BOOST_PP_ADD(2, 2), 2) == 6 END
|
|
||||||
BEGIN BOOST_PP_ADD(2, BOOST_PP_ADD(1, 4)) == 7 END
|
|
||||||
BEGIN BOOST_PP_ADD(BOOST_PP_ADD(2, 2), BOOST_PP_ADD(2, 2)) == 8 END
|
|
||||||
|
|
||||||
#if BOOST_PP_LIMIT_MAG == 512
|
#if BOOST_PP_LIMIT_MAG == 512
|
||||||
|
|
||||||
BEGIN BOOST_PP_ADD(374, 129) == 503 END
|
BEGIN BOOST_PP_ADD(374, 129) == 503 END
|
||||||
@ -94,16 +94,19 @@ BEGIN BOOST_PP_MUL(2, BOOST_PP_MUL(2, 2)) == 8 END
|
|||||||
BEGIN BOOST_PP_MUL(BOOST_PP_MUL(2, 2), BOOST_PP_MUL(2, 2)) == 16 END
|
BEGIN BOOST_PP_MUL(BOOST_PP_MUL(2, 2), BOOST_PP_MUL(2, 2)) == 16 END
|
||||||
|
|
||||||
BEGIN BOOST_PP_MUL(0, BOOST_PP_LIMIT_MAG) == 0 END
|
BEGIN BOOST_PP_MUL(0, BOOST_PP_LIMIT_MAG) == 0 END
|
||||||
|
BEGIN BOOST_PP_MUL(1, BOOST_PP_LIMIT_MAG) == BOOST_PP_LIMIT_MAG END
|
||||||
BEGIN BOOST_PP_MUL(2, BOOST_PP_LIMIT_MAG) == BOOST_PP_LIMIT_MAG END
|
BEGIN BOOST_PP_MUL(2, BOOST_PP_LIMIT_MAG) == BOOST_PP_LIMIT_MAG END
|
||||||
BEGIN BOOST_PP_MUL(BOOST_PP_LIMIT_MAG, 0) == 0 END
|
BEGIN BOOST_PP_MUL(BOOST_PP_LIMIT_MAG, 0) == 0 END
|
||||||
|
BEGIN BOOST_PP_MUL(BOOST_PP_LIMIT_MAG, 1) == BOOST_PP_LIMIT_MAG END
|
||||||
BEGIN BOOST_PP_MUL(BOOST_PP_LIMIT_MAG, 2) == BOOST_PP_LIMIT_MAG END
|
BEGIN BOOST_PP_MUL(BOOST_PP_LIMIT_MAG, 2) == BOOST_PP_LIMIT_MAG END
|
||||||
|
|
||||||
#if BOOST_PP_LIMIT_MAG == 256
|
#if BOOST_PP_LIMIT_MAG == 256
|
||||||
|
|
||||||
BEGIN BOOST_PP_MUL(2, 255) == 256 END
|
|
||||||
BEGIN BOOST_PP_MUL(255, 2) == 256 END
|
|
||||||
BEGIN BOOST_PP_MUL(17, 17) == 256 END
|
BEGIN BOOST_PP_MUL(17, 17) == 256 END
|
||||||
BEGIN BOOST_PP_MUL(1, 255) == 255 END
|
BEGIN BOOST_PP_MUL(1, 255) == 255 END
|
||||||
|
BEGIN BOOST_PP_MUL(2, 255) == 256 END
|
||||||
|
BEGIN BOOST_PP_MUL(255, 1) == 255 END
|
||||||
|
BEGIN BOOST_PP_MUL(255, 2) == 256 END
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user