Chromium Code Reviews| 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); |
| +} |
| + |
| +} |