summaryrefslogtreecommitdiff
path: root/js/src/ds/TraceableFifo.h
diff options
context:
space:
mode:
authorMatt A. Tobin <email@mattatobin.com>2022-06-07 20:20:19 -0500
committerMatt A. Tobin <email@mattatobin.com>2022-06-07 20:20:19 -0500
commit878ab758d5d4c1ef7badf2bc20ebc7c67dc2165b (patch)
tree3683d6df35e3618c0e7b456de7c749ca4c8c21a6 /js/src/ds/TraceableFifo.h
parenta621951327b0c19c0c24dfd9fd973f7bd13ae68f (diff)
parentcfb9884423faf741de03c5fcc72bf9ac8c6ada4d (diff)
downloadaura-central-878ab758d5d4c1ef7badf2bc20ebc7c67dc2165b.tar.gz
Merge branch 'TRUNK' into ARE-5.0
Diffstat (limited to 'js/src/ds/TraceableFifo.h')
-rw-r--r--js/src/ds/TraceableFifo.h54
1 files changed, 7 insertions, 47 deletions
diff --git a/js/src/ds/TraceableFifo.h b/js/src/ds/TraceableFifo.h
index 04f67da15..0f94b93cb 100644
--- a/js/src/ds/TraceableFifo.h
+++ b/js/src/ds/TraceableFifo.h
@@ -51,11 +51,11 @@ class TraceableFifo : public js::Fifo<T, MinInlineCapacity, AllocPolicy>
}
};
-template <typename Outer, typename T, size_t Capacity, typename AllocPolicy>
-class TraceableFifoOperations
+template <typename Wrapper, typename T, size_t Capacity, typename AllocPolicy>
+class WrappedPtrOperations<TraceableFifo<T, Capacity, AllocPolicy>, Wrapper>
{
using TF = TraceableFifo<T, Capacity, AllocPolicy>;
- const TF& fifo() const { return static_cast<const Outer*>(this)->extract(); }
+ const TF& fifo() const { return static_cast<const Wrapper*>(this)->get(); }
public:
size_t length() const { return fifo().length(); }
@@ -63,12 +63,12 @@ class TraceableFifoOperations
const T& front() const { return fifo().front(); }
};
-template <typename Outer, typename T, size_t Capacity, typename AllocPolicy>
-class MutableTraceableFifoOperations
- : public TraceableFifoOperations<Outer, T, Capacity, AllocPolicy>
+template <typename Wrapper, typename T, size_t Capacity, typename AllocPolicy>
+class MutableWrappedPtrOperations<TraceableFifo<T, Capacity, AllocPolicy>, Wrapper>
+ : public WrappedPtrOperations<TraceableFifo<T, Capacity, AllocPolicy>, Wrapper>
{
using TF = TraceableFifo<T, Capacity, AllocPolicy>;
- TF& fifo() { return static_cast<Outer*>(this)->extract(); }
+ TF& fifo() { return static_cast<Wrapper*>(this)->get(); }
public:
T& front() { return fifo().front(); }
@@ -82,46 +82,6 @@ class MutableTraceableFifoOperations
void clear() { fifo().clear(); }
};
-template <typename A, size_t B, typename C>
-class RootedBase<TraceableFifo<A,B,C>>
- : public MutableTraceableFifoOperations<JS::Rooted<TraceableFifo<A,B,C>>, A,B,C>
-{
- using TF = TraceableFifo<A,B,C>;
-
- friend class TraceableFifoOperations<JS::Rooted<TF>, A,B,C>;
- const TF& extract() const { return *static_cast<const JS::Rooted<TF>*>(this)->address(); }
-
- friend class MutableTraceableFifoOperations<JS::Rooted<TF>, A,B,C>;
- TF& extract() { return *static_cast<JS::Rooted<TF>*>(this)->address(); }
-};
-
-template <typename A, size_t B, typename C>
-class MutableHandleBase<TraceableFifo<A,B,C>>
- : public MutableTraceableFifoOperations<JS::MutableHandle<TraceableFifo<A,B,C>>, A,B,C>
-{
- using TF = TraceableFifo<A,B,C>;
-
- friend class TraceableFifoOperations<JS::MutableHandle<TF>, A,B,C>;
- const TF& extract() const {
- return *static_cast<const JS::MutableHandle<TF>*>(this)->address();
- }
-
- friend class MutableTraceableFifoOperations<JS::MutableHandle<TF>, A,B,C>;
- TF& extract() { return *static_cast<JS::MutableHandle<TF>*>(this)->address(); }
-};
-
-template <typename A, size_t B, typename C>
-class HandleBase<TraceableFifo<A,B,C>>
- : public TraceableFifoOperations<JS::Handle<TraceableFifo<A,B,C>>, A,B,C>
-{
- using TF = TraceableFifo<A,B,C>;
-
- friend class TraceableFifoOperations<JS::Handle<TF>, A,B,C>;
- const TF& extract() const {
- return *static_cast<const JS::Handle<TF>*>(this)->address();
- }
-};
-
} // namespace js
#endif // js_TraceableFifo_h