|  | // Copyright 2020 PDFium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef FXJS_GC_GCED_TREE_NODE_MIXIN_H_ | 
|  | #define FXJS_GC_GCED_TREE_NODE_MIXIN_H_ | 
|  |  | 
|  | #include "core/fxcrt/tree_node.h" | 
|  | #include "v8/include/cppgc/garbage-collected.h" | 
|  | #include "v8/include/cppgc/member.h" | 
|  | #include "v8/include/cppgc/visitor.h" | 
|  |  | 
|  | namespace fxjs { | 
|  |  | 
|  | // For DOM/XML-ish trees, where references outside the tree are Persistent<>, | 
|  | // usable by classes that are already garbage collected themselves. | 
|  | template <typename T> | 
|  | class GCedTreeNodeMixin : public cppgc::GarbageCollectedMixin, | 
|  | public TreeNode<T, cppgc::Member<T>> { | 
|  | public: | 
|  | using TreeNode<T, cppgc::Member<T>>::RemoveChild; | 
|  |  | 
|  | virtual void Trace(cppgc::Visitor* visitor) const { | 
|  | visitor->Trace(TreeNode<T, cppgc::Member<T>>::RawParent()); | 
|  | visitor->Trace(TreeNode<T, cppgc::Member<T>>::RawFirstChild()); | 
|  | visitor->Trace(TreeNode<T, cppgc::Member<T>>::RawLastChild()); | 
|  | visitor->Trace(TreeNode<T, cppgc::Member<T>>::RawNextSibling()); | 
|  | visitor->Trace(TreeNode<T, cppgc::Member<T>>::RawPrevSibling()); | 
|  | } | 
|  |  | 
|  | protected: | 
|  | GCedTreeNodeMixin() = default; | 
|  | GCedTreeNodeMixin(const GCedTreeNodeMixin& that) = delete; | 
|  | GCedTreeNodeMixin& operator=(const GCedTreeNodeMixin& that) = delete; | 
|  | }; | 
|  |  | 
|  | }  // namespace fxjs | 
|  |  | 
|  | using fxjs::GCedTreeNodeMixin; | 
|  |  | 
|  | #endif  // FXJS_GC_GCED_TREE_NODE_MIXIN_H_ |