Index: tools/clang/blink_gc_plugin/tests/finalize_after_dispatch.cpp |
diff --git a/tools/clang/blink_gc_plugin/tests/finalize_after_dispatch.cpp b/tools/clang/blink_gc_plugin/tests/finalize_after_dispatch.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..aeb4f6bd3dd2ee53d7ddff08b517aebb057b8edc |
--- /dev/null |
+++ b/tools/clang/blink_gc_plugin/tests/finalize_after_dispatch.cpp |
@@ -0,0 +1,51 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "finalize_after_dispatch.h" |
+ |
+namespace WebCore { |
+ |
+static B* toB(A* a) { return static_cast<B*>(a); } |
+ |
+void A::trace(Visitor* visitor) |
+{ |
+ switch (m_type) { |
+ case TB: toB(this)->traceAfterDispatch(visitor); |
Mads Ager (chromium)
2014/03/18 09:19:32
I think you want some breaks here so that you do n
zerny-chromium
2014/03/18 10:03:41
Yes. I should avoid writing bad/invalid code in te
|
+ case TC: static_cast<C*>(this)->traceAfterDispatch(visitor); |
+ case TD: static_cast<D*>(this)->traceAfterDispatch(visitor); |
+ } |
+} |
+ |
+void A::traceAfterDispatch(Visitor* visitor) |
+{ |
+} |
+ |
+void A::finalize() |
+{ |
+ switch (m_type) { |
+ case TB: toB(this)->~B(); |
Mads Ager (chromium)
2014/03/18 09:19:32
break!
zerny-chromium
2014/03/18 10:03:41
Done.
|
+ case TC: static_cast<C*>(this)->~C(); |
+ case TD: ; // Missing static_cast<D*>(this)->~D(); |
+ } |
+} |
+ |
+void B::traceAfterDispatch(Visitor* visitor) |
+{ |
+ visitor->trace(m_a); |
+ A::trace(visitor); |
+} |
+ |
+void C::traceAfterDispatch(Visitor* visitor) |
+{ |
+ visitor->trace(m_a); |
+ A::trace(visitor); |
+} |
+ |
+void D::traceAfterDispatch(Visitor* visitor) |
+{ |
+ visitor->trace(m_a); |
+ Abstract::trace(visitor); |
+} |
+ |
+} |