diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 17:32:43 +0000 |
commit | 6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch) | |
tree | a68f146d7fa01f0134297619fbe7e33db084e0aa /dom/bindings/RootedRefPtr.h | |
parent | Initial commit. (diff) | |
download | thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.zip |
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/bindings/RootedRefPtr.h')
-rw-r--r-- | dom/bindings/RootedRefPtr.h | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/dom/bindings/RootedRefPtr.h b/dom/bindings/RootedRefPtr.h new file mode 100644 index 0000000000..f5b2323c0f --- /dev/null +++ b/dom/bindings/RootedRefPtr.h @@ -0,0 +1,48 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this file, + * You can obtain one at http://mozilla.org/MPL/2.0/. */ + +/** + * An implementation of Rooted for RefPtr<T>. This works by assuming that T has + * a Trace() method defined on it which will trace whatever things inside the T + * instance need tracing. + * + * This implementation has one serious drawback: operator= doesn't work right + * because it's declared on Rooted directly and expects the type Rooted is + * templated over. + */ + +#ifndef mozilla_RootedRefPtr_h__ +#define mozilla_RootedRefPtr_h__ + +#include "mozilla/RefPtr.h" +#include "js/GCPolicyAPI.h" +#include "js/TypeDecls.h" + +namespace JS { +template <typename T> +struct GCPolicy<RefPtr<T>> { + static RefPtr<T> initial() { return RefPtr<T>(); } + + static void trace(JSTracer* trc, RefPtr<T>* tp, const char* name) { + if (*tp) { + (*tp)->Trace(trc); + } + } + + static bool isValid(const RefPtr<T>& v) { + return !v || GCPolicy<T>::isValid(*v.get()); + } +}; +} // namespace JS + +namespace js { +template <typename T, typename Wrapper> +struct WrappedPtrOperations<RefPtr<T>, Wrapper> { + operator T*() const { return static_cast<const Wrapper*>(this)->get(); } +}; +} // namespace js + +#endif /* mozilla_RootedRefPtr_h__ */ |