1*61c4878aSAndroid Build Coastguard Worker // Copyright 2019 The Pigweed Authors
2*61c4878aSAndroid Build Coastguard Worker //
3*61c4878aSAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); you may not
4*61c4878aSAndroid Build Coastguard Worker // use this file except in compliance with the License. You may obtain a copy of
5*61c4878aSAndroid Build Coastguard Worker // the License at
6*61c4878aSAndroid Build Coastguard Worker //
7*61c4878aSAndroid Build Coastguard Worker // https://www.apache.org/licenses/LICENSE-2.0
8*61c4878aSAndroid Build Coastguard Worker //
9*61c4878aSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*61c4878aSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11*61c4878aSAndroid Build Coastguard Worker // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12*61c4878aSAndroid Build Coastguard Worker // License for the specific language governing permissions and limitations under
13*61c4878aSAndroid Build Coastguard Worker // the License.
14*61c4878aSAndroid Build Coastguard Worker
15*61c4878aSAndroid Build Coastguard Worker #include "pw_preprocessor/concat.h"
16*61c4878aSAndroid Build Coastguard Worker
17*61c4878aSAndroid Build Coastguard Worker #include "pw_preprocessor/util.h"
18*61c4878aSAndroid Build Coastguard Worker #include "pw_unit_test/framework.h"
19*61c4878aSAndroid Build Coastguard Worker
20*61c4878aSAndroid Build Coastguard Worker namespace pw {
21*61c4878aSAndroid Build Coastguard Worker namespace {
22*61c4878aSAndroid Build Coastguard Worker
TEST(Concat,WithoutMacroExpansions)23*61c4878aSAndroid Build Coastguard Worker TEST(Concat, WithoutMacroExpansions) {
24*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT() 9000 PW_CONCAT() == 9000);
25*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(1, 2) == 12);
26*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(1, 2, 3, 4) == 1234);
27*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(1, 2, 3, 4, 5) == 12345);
28*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(1, 2, 3, 4, 5, 6) == 123456);
29*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(1, 2, 3, 4, 5, 6, 7) == 1234567);
30*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(1, 2, 3, 4, 5, 6, 7, 8) == 12345678);
31*61c4878aSAndroid Build Coastguard Worker
32*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, llu) == 0x345678llu);
33*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, llu) == 0x3456789llu);
34*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, llu) == 0x3456789Allu);
35*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, B, llu) ==
36*61c4878aSAndroid Build Coastguard Worker 0x3456789ABllu);
37*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, B, C, llu) ==
38*61c4878aSAndroid Build Coastguard Worker 0x3456789ABCllu);
39*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, llu) ==
40*61c4878aSAndroid Build Coastguard Worker 0x3456789ABCDllu);
41*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, llu) ==
42*61c4878aSAndroid Build Coastguard Worker 0x3456789ABCDEllu);
43*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F, llu) ==
44*61c4878aSAndroid Build Coastguard Worker 0x3456789ABCDEFllu);
45*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(0x, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F, F, llu) ==
46*61c4878aSAndroid Build Coastguard Worker 0x3456789ABCDEFFllu);
47*61c4878aSAndroid Build Coastguard Worker }
48*61c4878aSAndroid Build Coastguard Worker
49*61c4878aSAndroid Build Coastguard Worker // Macros which expand out to test that PW_CONCAT properly expands them.
50*61c4878aSAndroid Build Coastguard Worker #define _PW_TEST_SECTION(x) "section: " x
51*61c4878aSAndroid Build Coastguard Worker #define _PW_TEST_NUMBER 123
52*61c4878aSAndroid Build Coastguard Worker #define _PW_OUTER_MACRO(section_name) \
53*61c4878aSAndroid Build Coastguard Worker _PW_TEST_SECTION(PW_STRINGIFY(PW_CONCAT(section_name, _PW_TEST_NUMBER)))
54*61c4878aSAndroid Build Coastguard Worker
55*61c4878aSAndroid Build Coastguard Worker #define _PW_WHOSE() my
56*61c4878aSAndroid Build Coastguard Worker #define _PW_WHAT var
57*61c4878aSAndroid Build Coastguard Worker
TEST(Concat,WithMacroExpansions)58*61c4878aSAndroid Build Coastguard Worker TEST(Concat, WithMacroExpansions) {
59*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(_PW_TEST_NUMBER, 5) == 1235);
60*61c4878aSAndroid Build Coastguard Worker
61*61c4878aSAndroid Build Coastguard Worker int my_var;
62*61c4878aSAndroid Build Coastguard Worker EXPECT_EQ(&PW_CONCAT(_PW_WHOSE(), _, _PW_WHAT), &my_var);
63*61c4878aSAndroid Build Coastguard Worker
64*61c4878aSAndroid Build Coastguard Worker EXPECT_STREQ(_PW_OUTER_MACRO(what is up), "section: what is up123");
65*61c4878aSAndroid Build Coastguard Worker }
66*61c4878aSAndroid Build Coastguard Worker
67*61c4878aSAndroid Build Coastguard Worker // Test concatenation up to the maximum supported length.
TEST(Concat,MaximumConcatenationLength)68*61c4878aSAndroid Build Coastguard Worker TEST(Concat, MaximumConcatenationLength) {
69*61c4878aSAndroid Build Coastguard Worker constexpr int value31_234567890123456789012345678901 = 1337;
70*61c4878aSAndroid Build Coastguard Worker constexpr int value32_2345678901234567890123456789012 = 101010;
71*61c4878aSAndroid Build Coastguard Worker
72*61c4878aSAndroid Build Coastguard Worker // clang-format off
73*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(value31_, 2, 3, 4, 5, 6, 7, 8, 9, 0,
74*61c4878aSAndroid Build Coastguard Worker 1, 2, 3, 4, 5, 6, 7, 8, 9, 0,
75*61c4878aSAndroid Build Coastguard Worker 1, 2, 3, 4, 5, 6, 7, 8, 9, 0,
76*61c4878aSAndroid Build Coastguard Worker 1) == 1337);
77*61c4878aSAndroid Build Coastguard Worker
78*61c4878aSAndroid Build Coastguard Worker static_assert(PW_CONCAT(value32_, 2, 3, 4, 5, 6, 7, 8, 9, 0,
79*61c4878aSAndroid Build Coastguard Worker 1, 2, 3, 4, 5, 6, 7, 8, 9, 0,
80*61c4878aSAndroid Build Coastguard Worker 1, 2, 3, 4, 5, 6, 7, 8, 9, 0,
81*61c4878aSAndroid Build Coastguard Worker 1, 2) == 101010);
82*61c4878aSAndroid Build Coastguard Worker // clang-format on
83*61c4878aSAndroid Build Coastguard Worker }
84*61c4878aSAndroid Build Coastguard Worker
85*61c4878aSAndroid Build Coastguard Worker } // namespace
86*61c4878aSAndroid Build Coastguard Worker } // namespace pw
87