1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #define DEFINE_TYPE_CASTS(thisType, argumentType, argumentName, predicate) \
6 inline thisType* to##thisType(argumentType* argumentName) { \
7 if (!predicate) \
8 asm("int 3"); \
9 return static_cast<thisType*>(argumentName); \
10 } \
11 inline long long toInt(argumentType* argumentName) { \
12 return reinterpret_cast<long long>(argumentName); \
13 }
14
15 #define LIKELY(x) x
16
17 namespace blink {
18
19 struct Base {};
20 struct Derived : public Base {};
21
22 DEFINE_TYPE_CASTS(Derived, Base, theObject, true);
23
F()24 void F() {
25 Base* basePtr = new Derived;
26 Derived* derivedPtr = toDerived(basePtr);
27 long long asInt = toInt(basePtr);
28 // 'derivedPtr' should be renamed: it's a reference to a declaration defined
29 // outside a macro invocation.
30 if (LIKELY(derivedPtr)) {
31 delete derivedPtr;
32 }
33 }
34
35 #define CALL_METHOD_FROM_MACRO() \
36 void callMethodFromMacro() { method(); } \
37 void pmethod() override {}
38
39 struct WithMacroP {
pmethodblink::WithMacroP40 virtual void pmethod() {}
41 };
42
43 struct WithMacro : public WithMacroP {
methodblink::WithMacro44 void method() {}
45 CALL_METHOD_FROM_MACRO();
46 };
47
48 #define DEFINE_WITH_TOKEN_CONCATENATION2(arg1, arg2) \
49 void arg1##arg2() {}
50 // We definitely don't want to rewrite |arg1| on the previous line into
51 // either |Arg1| or |Frg1| or |Brg1| or |Foo| or |Baz|.
52
53 // We might or might not want to rewrite |foo|->|Foo| and |baz|->|Baz| below.
54 // The test below just spells out the current behavior of the tool (which one
55 // can argue is accidental).
DEFINE_WITH_TOKEN_CONCATENATION2(foo,Bar1)56 DEFINE_WITH_TOKEN_CONCATENATION2(foo, Bar1)
57 DEFINE_WITH_TOKEN_CONCATENATION2(baz, Bar2)
58
59 void tokenConcatenationTest2() {
60 // We might or might not want to rewrite |foo|->|Foo| and |baz|->|Baz| below.
61 // The test below just spells out the current behavior of the tool (which one
62 // can argue is accidental).
63 fooBar1();
64 bazBar2();
65 }
66
67 class FieldsMacro {
68 public:
69 // We shouldn't rewrite |m_fooBar| -> |foo_bar_|, because we cannot rewrite
70 // |m_##name| -> |???|.
FieldsMacro()71 FieldsMacro() : m_fooBar(123), m_barBaz(456) {}
72
73 #define DECLARE_FIELD(name, Name) \
74 private: \
75 int m_##name; \
76 \
77 public: \
78 int name() { return m_##name; } \
79 void set##Name(int name) { m_##name = name; }
80
81 DECLARE_FIELD(fooBar, FooBar)
82 DECLARE_FIELD(barBaz, BarBaz)
83 };
84
fieldsMacroTest()85 int fieldsMacroTest() {
86 FieldsMacro fm;
87 fm.setFooBar(789);
88 return fm.fooBar() + fm.barBaz();
89 }
90
91 } // namespace blink
92