1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
| # /* **************************************************************************
| # * *
| # * (C) Copyright Paul Mensonides 2002.
| # * 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)
| # * *
| # ************************************************************************** */
| #
| # /* See http://www.boost.org for most recent version. */
| #
| # ifndef BOOST_PREPROCESSOR_ARRAY_REPLACE_HPP
| # define BOOST_PREPROCESSOR_ARRAY_REPLACE_HPP
| #
| # include <boost/preprocessor/config/config.hpp>
| #
| # if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_STRICT()
| #
| # include <boost/preprocessor/arithmetic/inc.hpp>
| # include <boost/preprocessor/array/elem.hpp>
| # include <boost/preprocessor/array/push_back.hpp>
| # include <boost/preprocessor/comparison/not_equal.hpp>
| # include <boost/preprocessor/config/config.hpp>
| # include <boost/preprocessor/control/deduce_d.hpp>
| # include <boost/preprocessor/control/iif.hpp>
| # include <boost/preprocessor/control/while.hpp>
| # include <boost/preprocessor/tuple/elem.hpp>
| #
| # /* BOOST_PP_ARRAY_REPLACE */
| #
| # define BOOST_PP_ARRAY_REPLACE(array, i, elem) BOOST_PP_ARRAY_REPLACE_I(BOOST_PP_DEDUCE_D(), array, i, elem)
| # define BOOST_PP_ARRAY_REPLACE_I(d, array, i, elem) BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem)
| #
| # /* BOOST_PP_ARRAY_REPLACE_D */
| #
| # if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
| # define BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem) BOOST_PP_TUPLE_ELEM(5, 3, BOOST_PP_WHILE_ ## d(BOOST_PP_ARRAY_REPLACE_P, BOOST_PP_ARRAY_REPLACE_O, (0, i, elem, (0, ()), array)))
| # else
| # define BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem) BOOST_PP_ARRAY_REPLACE_D_I(d, array, i, elem)
| # define BOOST_PP_ARRAY_REPLACE_D_I(d, array, i, elem) BOOST_PP_TUPLE_ELEM(5, 3, BOOST_PP_WHILE_ ## d(BOOST_PP_ARRAY_REPLACE_P, BOOST_PP_ARRAY_REPLACE_O, (0, i, elem, (0, ()), array)))
| # endif
| #
| # define BOOST_PP_ARRAY_REPLACE_P(d, state) BOOST_PP_NOT_EQUAL(BOOST_PP_TUPLE_ELEM(5, 0, state), BOOST_PP_ARRAY_SIZE(BOOST_PP_TUPLE_ELEM(5, 4, state)))
| #
| # if BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_STRICT()
| # define BOOST_PP_ARRAY_REPLACE_O(d, state) BOOST_PP_ARRAY_REPLACE_O_I state
| # else
| # define BOOST_PP_ARRAY_REPLACE_O(d, state) BOOST_PP_ARRAY_REPLACE_O_I(BOOST_PP_TUPLE_ELEM(5, 0, state), BOOST_PP_TUPLE_ELEM(5, 1, state), BOOST_PP_TUPLE_ELEM(5, 2, state), BOOST_PP_TUPLE_ELEM(5, 3, state), BOOST_PP_TUPLE_ELEM(5, 4, state))
| # endif
| #
| # define BOOST_PP_ARRAY_REPLACE_O_I(n, i, elem, res, arr) (BOOST_PP_INC(n), i, elem, BOOST_PP_ARRAY_PUSH_BACK(res, BOOST_PP_IIF(BOOST_PP_NOT_EQUAL(n, i), BOOST_PP_ARRAY_ELEM(n, arr), elem)), arr)
| #
| # else
| #
| # include <boost/preprocessor/arithmetic/inc.hpp>
| # include <boost/preprocessor/array/elem.hpp>
| # include <boost/preprocessor/array/push_back.hpp>
| # include <boost/preprocessor/comparison/not_equal.hpp>
| # include <boost/preprocessor/control/deduce_d.hpp>
| # include <boost/preprocessor/control/iif.hpp>
| # include <boost/preprocessor/control/while.hpp>
| # if BOOST_PP_LIMIT_TUPLE == 256
| # include <boost/preprocessor/logical/not.hpp>
| # endif
| # include <boost/preprocessor/tuple/elem.hpp>
| #
| # /* BOOST_PP_ARRAY_REPLACE */
| #
| # define BOOST_PP_ARRAY_REPLACE(array, i, elem) BOOST_PP_ARRAY_REPLACE_I(BOOST_PP_DEDUCE_D(), array, i, elem)
| # define BOOST_PP_ARRAY_REPLACE_I(d, array, i, elem) BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem)
| #
| # /* BOOST_PP_ARRAY_REPLACE_D */
| #
| # if ~BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_EDG()
| # if BOOST_PP_LIMIT_TUPLE == 256
| # define BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem) BOOST_PP_ARRAY_REPLACE_ZERO_D(d, array, i, elem, BOOST_PP_NOT(i))
| # else
| # define BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem) BOOST_PP_TUPLE_ELEM(5, 3, BOOST_PP_WHILE_ ## d(BOOST_PP_ARRAY_REPLACE_P, BOOST_PP_ARRAY_REPLACE_O, (0, i, elem, (0, ()), array)))
| # endif
| # else
| # define BOOST_PP_ARRAY_REPLACE_D(d, array, i, elem) BOOST_PP_ARRAY_REPLACE_D_I(d, array, i, elem)
| # if BOOST_PP_LIMIT_TUPLE == 256
| # define BOOST_PP_ARRAY_REPLACE_D_I(d, array, i, elem) BOOST_PP_ARRAY_REPLACE_ZERO_D(d, array, i, elem, BOOST_PP_NOT(i))
| # else
| # define BOOST_PP_ARRAY_REPLACE_D_I(d, array, i, elem) BOOST_PP_TUPLE_ELEM(5, 3, BOOST_PP_WHILE_ ## d(BOOST_PP_ARRAY_REPLACE_P, BOOST_PP_ARRAY_REPLACE_O, (0, i, elem, (0, ()), array)))
| # endif
| # endif
| #
| # if BOOST_PP_LIMIT_TUPLE == 256
| # define BOOST_PP_ARRAY_REPLACE_ZERO_D(d, array, i, elem, zero) \
| BOOST_PP_TUPLE_ELEM(5, 3, BOOST_PP_WHILE_ ## d(BOOST_PP_ARRAY_REPLACE_P, BOOST_PP_ARRAY_REPLACE_O, \
| (1, i, elem, BOOST_PP_IIF(zero,(1, (elem)),(1, (BOOST_PP_ARRAY_ELEM(0,array)))), array)))
| # endif
| #
| # define BOOST_PP_ARRAY_REPLACE_P(d, state) BOOST_PP_NOT_EQUAL(BOOST_PP_TUPLE_ELEM(5, 0, state), BOOST_PP_ARRAY_SIZE(BOOST_PP_TUPLE_ELEM(5, 4, state)))
| #
| # if BOOST_PP_CONFIG_FLAGS() & BOOST_PP_CONFIG_STRICT()
| # define BOOST_PP_ARRAY_REPLACE_O(d, state) BOOST_PP_ARRAY_REPLACE_O_I state
| # else
| # define BOOST_PP_ARRAY_REPLACE_O(d, state) BOOST_PP_ARRAY_REPLACE_O_I(BOOST_PP_TUPLE_ELEM(5, 0, state), BOOST_PP_TUPLE_ELEM(5, 1, state), BOOST_PP_TUPLE_ELEM(5, 2, state), BOOST_PP_TUPLE_ELEM(5, 3, state), BOOST_PP_TUPLE_ELEM(5, 4, state))
| # endif
| #
| # define BOOST_PP_ARRAY_REPLACE_O_I(n, i, elem, res, arr) (BOOST_PP_INC(n), i, elem, BOOST_PP_ARRAY_PUSH_BACK(res, BOOST_PP_IIF(BOOST_PP_NOT_EQUAL(n, i), BOOST_PP_ARRAY_ELEM(n, arr), elem)), arr)
| #
| # endif
| #
| # endif
|
|