1 // Copyright 2015 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 #include "gen/thing.h"
6 
7 namespace v8 {
8 
9 class InterfaceOutsideOfBlink {
10  public:
11   virtual void nonBlinkVirtual() = 0;
12 };
13 
14 }  // namespace v8
15 
16 namespace blink {
17 
18 class InsideOfBlink : public v8::InterfaceOutsideOfBlink {
19  public:
20   // This function overrides something outside of blink so don't rename it.
nonBlinkVirtual()21   void nonBlinkVirtual() override {}
22   // This function is in blink so rename it.
BlinkVirtual()23   virtual void BlinkVirtual() {}
24 };
25 
26 class MyIterator {};
27 using my_iterator = char*;
28 
29 class Task {
30  public:
31   // Already style-compliant methods shouldn't change.
OutputDebugString()32   void OutputDebugString() {}
33 
34   // Tests that the declarations for methods are updated.
35   void DoTheWork();
36   // Overload to test using declarations that introduce multiple shadow
37   // declarations.
38   void DoTheWork(int);
39   virtual void ReallyDoTheWork() = 0;
40 
41   // Note: this is purposely copyable and assignable, to make sure the Clang
42   // tool doesn't try to emit replacements for things that aren't explicitly
43   // written.
44 
45   // Overloaded operators should not be rewritten.
operator ++()46   Task& operator++() { return *this; }
47 
48   // Conversion functions should not be rewritten.
operator int() const49   explicit operator int() const { return 42; }
50 
51   // These are special functions that we don't rename so that range-based
52   // for loops and STL things work.
begin()53   MyIterator begin() { return {}; }
end()54   my_iterator end() { return {}; }
rbegin()55   my_iterator rbegin() { return {}; }
rend()56   MyIterator rend() { return {}; }
57   // The trace() method is used by Oilpan, but we plan to tweak the Oilpan's
58   // clang plugin, so that it recognizes the new method name.
Trace()59   void Trace() {}
60   // These are used by std::unique_lock and std::lock_guard.
lock()61   void lock() {}
unlock()62   void unlock() {}
try_lock()63   void try_lock() {}
64 };
65 
66 class Other {
67   // Static begin/end/trace don't count, and should be renamed.
Begin()68   static MyIterator Begin() { return {}; }
End()69   static my_iterator End() { return {}; }
Trace()70   static void Trace() {}
Lock()71   static void Lock() {}
72 };
73 
74 // Test that the actual method definition is also updated.
DoTheWork()75 void Task::DoTheWork() {
76   ReallyDoTheWork();
77 }
78 
79 template <typename T>
80 class Testable {
81  public:
82   typedef T Testable::*UnspecifiedBoolType;
83   // This method has a reference to a member in a "member context" and a
84   // "non-member context" to verify both are rewritten.
operator UnspecifiedBoolType()85   operator UnspecifiedBoolType() { return ptr_ ? &Testable::ptr_ : 0; }
86 
87  private:
88   int ptr_;
89 };
90 
91 namespace subname {
92 
93 class SubnameParent {
SubnameMethod()94   virtual void SubnameMethod() {}
95 };
96 
97 }  // namespace subname
98 
99 class SubnameChild : public subname::SubnameParent {
100   // This subclasses from blink::subname::SubnameParent and should be renamed.
SubnameMethod()101   void SubnameMethod() override {}
102 };
103 
104 class GenChild : public blink::GenClass {
105   // This subclasses from the blink namespace but in the gen directory so it
106   // should not be renamed.
genMethod()107   void genMethod() override {}
108 };
109 
110 }  // namespace blink
111 
112 // Test that overrides from outside the Blink namespace are also updated.
113 class BovineTask : public blink::Task {
114  public:
115   using Task::DoTheWork;
116   void ReallyDoTheWork() override;
117 };
118 
119 class SuperBovineTask : public BovineTask {
120  public:
121   using BovineTask::ReallyDoTheWork;
122 };
123 
ReallyDoTheWork()124 void BovineTask::ReallyDoTheWork() {
125   DoTheWork();
126   // Calls via an overridden method should also be updated.
127   ReallyDoTheWork();
128 }
129 
130 // Finally, test that method pointers are also updated.
F()131 void F() {
132   void (blink::Task::*p1)() = &blink::Task::DoTheWork;
133   void (blink::Task::*p2)() = &BovineTask::DoTheWork;
134   void (blink::Task::*p3)() = &blink::Task::ReallyDoTheWork;
135   void (BovineTask::*p4)() = &BovineTask::ReallyDoTheWork;
136 }
137 
G()138 bool G() {
139   // Use the Testable class to rewrite the method.
140   blink::Testable<int> tt;
141   return tt;
142 }
143 
144 class SubclassOfInsideOfBlink : public blink::InsideOfBlink {
145  public:
146   // This function overrides something outside of blink so don't rename it.
nonBlinkVirtual()147   void nonBlinkVirtual() override {}
148   // This function overrides something in blink so rename it.
BlinkVirtual()149   void BlinkVirtual() override {}
150 };
151 
152 class TestSubclassInsideOfBlink : public SubclassOfInsideOfBlink {
153  public:
154  public:
155   // This function overrides something outside of blink so don't rename it.
nonBlinkVirtual()156   void nonBlinkVirtual() override {}
157   // This function overrides something in blink so rename it.
BlinkVirtual()158   void BlinkVirtual() override {}
159 };
160 
161 namespace blink {
162 
163 struct StructInBlink {
164   // Structs in blink should rename their methods to capitals.
Functionblink::StructInBlink165   bool Function() { return true; }
166 };
167 
168 class BitVector {
169  public:
170   class OutOfLineBits {};
171   enum Foo { kBlah };
172   struct Bar {};
173   class Baz {};
174   class FooBar {};
175 
176   // Should be renamed to GetReadyState, because of
177   // ShouldPrefixFunctionName heuristic.
GetReadyState()178   int GetReadyState() { return 123; }
179 
180   template <typename T>
181   class MyRefPtr {};
182 
183   // Naive renaming will break the build, by leaving return type the same
184   // as the method name - to avoid this "Get" prefix needs to be prepended
185   // as suggested in https://crbug.com/582312#c17.
GetOutOfLineBits() const186   const OutOfLineBits* GetOutOfLineBits() const { return nullptr; }
GetFoo()187   Foo GetFoo() { return kBlah; }
GetBar() const188   const Bar& GetBar() const { return bar_; }
GetBaz()189   MyRefPtr<Baz> GetBaz() { return MyRefPtr<Baz>(); }
GetFooBar()190   const MyRefPtr<FooBar>& GetFooBar() { return foobar_; }
191 
192  private:
193   Bar bar_;
194   MyRefPtr<FooBar> foobar_;
195 };
196 
197 namespace get_prefix_vs_inheritance {
198 
199 // Regression test for https://crbug.com/673031:
200 // 1. |frame| accessor/method should be renamed in the same way for
201 //    WebFrameImplBase and WebLocalFrameImpl.
202 // 2. Need to rename |frame| to |GetFrame| (not to |Frame|) to avoid
203 //    a conflict with the Frame type.
204 
205 class FrameFoo {};
206 class LocalFrame : public FrameFoo {};
207 
208 class WebFrameImplBase {
209  public:
210   // Using |frameFoo| to test inheritance, and NOT just the presence on the
211   // ShouldPrefixFunctionName list.
212   virtual FrameFoo* GetFrameFoo() const = 0;
213 };
214 
215 class WebLocalFrameImpl : public WebFrameImplBase {
216  public:
GetFrameFoo() const217   LocalFrame* GetFrameFoo() const override { return nullptr; }
218 };
219 
220 // This is also a regression test for https://crbug.com/673031.  We should NOT
221 // rewrite in a non-virtual case, because walking the inheritance chain of the
222 // return type depends too much on unrelated context (i.e. walking the
223 // inheritance chain might not be possible if the return type is
224 // forward-declared).
225 class LayoutObjectFoo {};
226 class LayoutBoxModelObject : public LayoutObjectFoo {};
227 class PaintLayerStackingNode {
228  public:
229   // |layoutObjectFoo| should NOT be renamed to |GetLayoutObjectFoo| (just to
230   // |LayoutObjectFoo|) - see the big comment above.  We use layoutObject*Foo*
231   // to test inheritance-related behavior and avoid testing whether method name
232   // is covered via ShouldPrefixFunctionName.
LayoutObjectFoo()233   LayoutBoxModelObject* LayoutObjectFoo() { return nullptr; }
234 };
235 
236 }  // namespace get_prefix_vs_inheritance
237 
238 namespace blacklisting_of_method_and_function_names {
239 
240 class Foo {
241   // Expecting |swap| method to be renamed to |Swap| - we blacklist renaming of
242   // |swap| *function*, because it needs to have the same casing as std::swap,
243   // so that ADL can kick-in and pull it from another namespace depending on the
244   // bargument.  We have a choice to rename or not rename |swap| *methods* - we
245   // chose to rename to be consistent (i.e. we rename |clear| -> |Clear|) and
246   // because Google C++ Styke Guide uses "Swap" in examples.
Swap()247   void Swap() {}
Swap(Foo & x,Foo & y)248   static void Swap(Foo& x, Foo& y) {}
249 
250   // We don't rename |begin|, so that <algorithms> and other templates that
251   // expect |begin|, |end|, etc. continue to work.  This is only necessary
252   // for instance methods - renaming static methods and funcitons is okay.
begin()253   void begin() {}
Begin(int x)254   static void Begin(int x) {}
255 
256   // https://crbug.com672902: std-like names should not be rewritten.
emplace_back(int x)257   void emplace_back(int x) {}
insert(int x)258   void insert(int x) {}
push_back(int x)259   void push_back(int x) {}
back()260   int* back() { return nullptr; }
front()261   int* front() { return nullptr; }
erase()262   void erase() {}
empty()263   bool empty() { return true; }
264 };
265 
Begin(int x)266 void Begin(int x) {}
swap(Foo & x,Foo & y)267 void swap(Foo& x, Foo& y) {}
268 
269 }  // blacklisting_of_method_and_function_names
270 
271 }  // namespace blink
272 
273 namespace WTF {
274 
275 struct StructInWTF {
276   // Structs in WTF should rename their methods to capitals.
FunctionWTF::StructInWTF277   bool Function() { return true; }
278 };
279 
280 }  // namespace WTF
281 
F2()282 void F2() {
283   blink::StructInBlink b;
284   b.Function();
285   WTF::StructInWTF w;
286   w.Function();
287 }
288 
289 namespace blink {
290 
291 class ClassDeclaredInsideBlink {
292  public:
293   static void MethodDefinedOutsideBlink();
294 };
295 
296 namespace internal {
297 
298 class InternalClass {
299  public:
300   static void Method();
301 };
302 
303 }  // namespace internal
304 
305 // Tests for --method-blocklist cmdline parameter.
306 class IdlTestClass {
307  public:
NotBlocklistedMethod()308   static int NotBlocklistedMethod() { return 123; }
NotBlocklistedMethod(int x)309   int NotBlocklistedMethod(int x) { return 123; }
310 
idlStaticMethod()311   static int idlStaticMethod() { return 123; }
idlInstanceMethod()312   int idlInstanceMethod() { return 123; }
313 
314   template <typename T>
idlTemplateMethod(T x)315   int idlTemplateMethod(T x) {
316     return 123;
317   }
318 };
319 
320 template <typename T>
321 class IdlTemplateClass {
322  public:
idlInstanceMethod(T x)323   int idlInstanceMethod(T x) { return 123; }
324 };
325 
326 }  // namespace blink
327 
328 // https://crbug.com/640688 - need to rewrite method name below.
MethodDefinedOutsideBlink()329 void blink::ClassDeclaredInsideBlink::MethodDefinedOutsideBlink() {}
Method()330 void blink::internal::InternalClass::Method() {}
331