#ifndef Strong_h
#define Strong_h
-#include "Assertions.h"
+#include <wtf/Assertions.h>
#include "Handle.h"
-#include "HandleHeap.h"
+#include "HandleSet.h"
namespace JSC {
-class JSGlobalData;
-HandleSlot allocateGlobalHandle(JSGlobalData&);
+class VM;
// A strongly referenced handle that prevents the object it points to from being garbage collected.
template <typename T> class Strong : public Handle<T> {
using Handle<T>::slot;
using Handle<T>::setSlot;
+ template <typename U> friend class Strong;
public:
typedef typename Handle<T>::ExternalType ExternalType;
{
}
- Strong(JSGlobalData& globalData, ExternalType value = ExternalType())
- : Handle<T>(allocateGlobalHandle(globalData))
- {
- set(value);
- }
+ Strong(VM&, ExternalType = ExternalType());
- Strong(JSGlobalData& globalData, Handle<T> handle)
- : Handle<T>(allocateGlobalHandle(globalData))
- {
- set(handle.get());
- }
+ Strong(VM&, Handle<T>);
Strong(const Strong& other)
: Handle<T>()
{
if (!other.slot())
return;
- setSlot(HandleHeap::heapFor(other.slot())->allocate());
+ setSlot(HandleSet::heapFor(other.slot())->allocate());
set(other.get());
}
{
if (!other.slot())
return;
- setSlot(HandleHeap::heapFor(other.slot())->allocate());
+ setSlot(HandleSet::heapFor(other.slot())->allocate());
set(other.get());
}
clear();
}
+ bool operator!() const { return !slot() || !*slot(); }
+
+ // This conversion operator allows implicit conversion to bool but not to other integer types.
+ typedef JSValue (HandleBase::*UnspecifiedBoolType);
+ operator UnspecifiedBoolType*() const { return !!*this ? reinterpret_cast<UnspecifiedBoolType*>(1) : 0; }
+
void swap(Strong& other)
{
Handle<T>::swap(other);
}
- void set(JSGlobalData& globalData, ExternalType value)
- {
- if (!slot())
- setSlot(allocateGlobalHandle(globalData));
- set(value);
- }
+ ExternalType get() const { return HandleTypes<T>::getFromSlot(this->slot()); }
+
+ void set(VM&, ExternalType);
template <typename U> Strong& operator=(const Strong<U>& other)
{
return *this;
}
- set(*HandleHeap::heapFor(other.slot())->globalData(), other.get());
+ set(*HandleSet::heapFor(other.slot())->vm(), other.get());
return *this;
}
return *this;
}
- set(*HandleHeap::heapFor(other.slot())->globalData(), other.get());
+ set(*HandleSet::heapFor(other.slot())->vm(), other.get());
return *this;
}
{
if (!slot())
return;
- HandleHeap::heapFor(slot())->deallocate(slot());
+ HandleSet::heapFor(slot())->deallocate(slot());
setSlot(0);
}
{
ASSERT(slot());
JSValue value = HandleTypes<T>::toJSValue(externalType);
- HandleHeap::heapFor(slot())->writeBarrier(slot(), value);
+ HandleSet::heapFor(slot())->writeBarrier(slot(), value);
*slot() = value;
}
};
namespace WTF {
-template<typename T> struct VectorTraits<JSC::Strong<T> > : SimpleClassVectorTraits {
+template<typename T> struct VectorTraits<JSC::Strong<T>> : SimpleClassVectorTraits {
static const bool canCompareWithMemcmp = false;
};
-template<typename P> struct HashTraits<JSC::Strong<P> > : SimpleClassHashTraits<JSC::Strong<P> > { };
+template<typename P> struct HashTraits<JSC::Strong<P>> : SimpleClassHashTraits<JSC::Strong<P>> { };
}