| 1 | # /* ************************************************************************** |
|---|
| 2 | # * * |
|---|
| 3 | # * (C) Copyright Paul Mensonides 2002. |
|---|
| 4 | # * Distributed under the Boost Software License, Version 1.0. (See |
|---|
| 5 | # * accompanying file LICENSE_1_0.txt or copy at |
|---|
| 6 | # * http://www.boost.org/LICENSE_1_0.txt) |
|---|
| 7 | # * * |
|---|
| 8 | # ************************************************************************** */ |
|---|
| 9 | # |
|---|
| 10 | # /* See http://www.boost.org for most recent version. */ |
|---|
| 11 | # |
|---|
| 12 | # include <boost/preprocessor/arithmetic/add.hpp> |
|---|
| 13 | # include <boost/preprocessor/arithmetic/sub.hpp> |
|---|
| 14 | # include <boost/preprocessor/comparison/less.hpp> |
|---|
| 15 | # include <boost/preprocessor/seq.hpp> |
|---|
| 16 | # include <boost/preprocessor/tuple/elem.hpp> |
|---|
| 17 | # include <libs/preprocessor/test/test.h> |
|---|
| 18 | |
|---|
| 19 | # define SEQ (4)(1)(5)(2) |
|---|
| 20 | |
|---|
| 21 | # define REVERSAL(s, x, y) BOOST_PP_SUB(y, x) |
|---|
| 22 | # define SUB_S(s, x, y) BOOST_PP_SUB(x, y) |
|---|
| 23 | # define ADD_S(s, x, y) BOOST_PP_ADD(x, y) |
|---|
| 24 | |
|---|
| 25 | BEGIN BOOST_PP_SEQ_FOLD_LEFT(SUB_S, 22, SEQ) == 10 END |
|---|
| 26 | BEGIN BOOST_PP_SEQ_FOLD_RIGHT(ADD_S, 0, SEQ) == 12 END |
|---|
| 27 | BEGIN BOOST_PP_SEQ_FOLD_RIGHT(REVERSAL, 0, SEQ) == 4 END |
|---|
| 28 | |
|---|
| 29 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REVERSE(SEQ)) == 2514 END |
|---|
| 30 | |
|---|
| 31 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REST_N(2, SEQ)) == 52 END |
|---|
| 32 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_FIRST_N(2, SEQ)) == 41 END |
|---|
| 33 | |
|---|
| 34 | BEGIN BOOST_PP_SEQ_ELEM(2, SEQ) == 5 END |
|---|
| 35 | BEGIN BOOST_PP_SEQ_SIZE(SEQ) == 4 END |
|---|
| 36 | |
|---|
| 37 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_TRANSFORM(ADD_S, 2, SEQ)) == 6374 END |
|---|
| 38 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_TAIL(SEQ) SEQ) == 1524152 END |
|---|
| 39 | |
|---|
| 40 | # define F1(r, state, x) + x + state |
|---|
| 41 | BEGIN BOOST_PP_SEQ_FOR_EACH(F1, 1, SEQ) == 16 END |
|---|
| 42 | |
|---|
| 43 | BEGIN BOOST_PP_TUPLE_ELEM(4, 3, BOOST_PP_SEQ_TO_TUPLE(SEQ)) == 2 END |
|---|
| 44 | |
|---|
| 45 | # define LESS_S(s, x, y) BOOST_PP_LESS(x, y) |
|---|
| 46 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_FILTER(LESS_S, 3, SEQ)) == 45 END |
|---|
| 47 | |
|---|
| 48 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_INSERT(SEQ, 0, 3)) == 34152 END |
|---|
| 49 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_INSERT(SEQ, 2, 3)) == 41352 END |
|---|
| 50 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_INSERT(SEQ, 4, 3)) == 41523 END |
|---|
| 51 | |
|---|
| 52 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_POP_BACK(SEQ)) == 415 END |
|---|
| 53 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_POP_FRONT(SEQ)) == 152 END |
|---|
| 54 | |
|---|
| 55 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_PUSH_FRONT(SEQ, 3)) == 34152 END |
|---|
| 56 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_PUSH_BACK(SEQ, 3)) == 41523 END |
|---|
| 57 | |
|---|
| 58 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REMOVE(SEQ, 0)) == 152 END |
|---|
| 59 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REMOVE(SEQ, 2)) == 412 END |
|---|
| 60 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REMOVE(SEQ, 3)) == 415 END |
|---|
| 61 | |
|---|
| 62 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REPLACE(SEQ, 0, 3)) == 3152 END |
|---|
| 63 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REPLACE(SEQ, 1, 3)) == 4352 END |
|---|
| 64 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_REPLACE(SEQ, 3, 3)) == 4153 END |
|---|
| 65 | |
|---|
| 66 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_SUBSEQ(SEQ, 0, 4)) == 4152 END |
|---|
| 67 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_SUBSEQ(SEQ, 0, 2)) == 41 END |
|---|
| 68 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_SUBSEQ(SEQ, 1, 2)) == 15 END |
|---|
| 69 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_SUBSEQ(SEQ, 2, 2)) == 52 END |
|---|
| 70 | |
|---|
| 71 | # define F2(r, x) + BOOST_PP_SEQ_ELEM(0, x) + 2 - BOOST_PP_SEQ_ELEM(1, x) |
|---|
| 72 | |
|---|
| 73 | #define ADD_NIL(x) x(nil) |
|---|
| 74 | |
|---|
| 75 | BEGIN BOOST_PP_SEQ_FOR_EACH_PRODUCT(F2, ((1)(0)) ((2)(3))) == 0 END |
|---|
| 76 | |
|---|
| 77 | # define L1 (0)(x) |
|---|
| 78 | # define L2 (a)(1)(b)(2) |
|---|
| 79 | # define L3 (c)(3)(d) |
|---|
| 80 | |
|---|
| 81 | # define LL (L1)(L2)(L3) |
|---|
| 82 | |
|---|
| 83 | #define SEQ_APPEND(s, state, elem) state elem |
|---|
| 84 | BEGIN BOOST_PP_SEQ_CAT(BOOST_PP_SEQ_TAIL(BOOST_PP_SEQ_FOLD_LEFT(SEQ_APPEND, (~), LL))) == 0x0a1b2c3d END |
|---|
| 85 | BEGIN BOOST_PP_SEQ_SIZE(BOOST_PP_SEQ_TAIL(BOOST_PP_SEQ_FOLD_LEFT(SEQ_APPEND, (~), LL))) == 9 END |
|---|