| Index: include/v8.h
|
| diff --git a/include/v8.h b/include/v8.h
|
| index 9bda3dc9faa7bfa79190c1483345d93057120349..12a0b2894dd81d6145680dce990ec48821d23792 100644
|
| --- a/include/v8.h
|
| +++ b/include/v8.h
|
| @@ -140,7 +140,6 @@ class ObjectOperationDescriptor;
|
| class RawOperationDescriptor;
|
| class CallHandlerHelper;
|
| class EscapableHandleScope;
|
| -template<typename T> class ReturnValue;
|
|
|
| namespace internal {
|
| class Arguments;
|
| @@ -413,7 +412,6 @@ template <class T> class Local : public Handle<T> {
|
| template<class F> friend class internal::CustomArguments;
|
| friend class HandleScope;
|
| friend class EscapableHandleScope;
|
| - template<class F1, class F2, class F3> friend class PersistentValueMap;
|
|
|
| V8_INLINE static Local<T> New(Isolate* isolate, T* that);
|
| };
|
| @@ -529,11 +527,7 @@ template <class T> class PersistentBase {
|
| P* parameter,
|
| typename WeakCallbackData<S, P>::Callback callback);
|
|
|
| - template<typename P>
|
| - V8_INLINE P* ClearWeak();
|
| -
|
| - // TODO(dcarney): remove this.
|
| - V8_INLINE void ClearWeak() { ClearWeak<void>(); }
|
| + V8_INLINE void ClearWeak();
|
|
|
| /**
|
| * Marks the reference to this object independent. Garbage collector is free
|
| @@ -582,7 +576,6 @@ template <class T> class PersistentBase {
|
| template<class F> friend class UniquePersistent;
|
| template<class F> friend class PersistentBase;
|
| template<class F> friend class ReturnValue;
|
| - template<class F1, class F2, class F3> friend class PersistentValueMap;
|
| friend class Object;
|
|
|
| explicit V8_INLINE PersistentBase(T* val) : val_(val) {}
|
| @@ -751,7 +744,7 @@ class UniquePersistent : public PersistentBase<T> {
|
| };
|
|
|
| public:
|
| - /**
|
| + /**
|
| * A UniquePersistent with no storage cell.
|
| */
|
| V8_INLINE UniquePersistent() : PersistentBase<T>(0) { }
|
| @@ -789,7 +782,6 @@ class UniquePersistent : public PersistentBase<T> {
|
| template<class S>
|
| V8_INLINE UniquePersistent& operator=(UniquePersistent<S> rhs) {
|
| TYPE_CHECK(T, S);
|
| - this->Reset();
|
| this->val_ = rhs.val_;
|
| rhs.val_ = 0;
|
| return *this;
|
| @@ -809,145 +801,6 @@ class UniquePersistent : public PersistentBase<T> {
|
| };
|
|
|
|
|
| -typedef uintptr_t PersistentContainerValue;
|
| -static const uintptr_t kPersistentContainerNotFound = 0;
|
| -
|
| -/**
|
| - * A map wrapper that allows using UniquePersistent as a mapped value.
|
| - * C++11 embedders don't need this class, as they can use UniquePersistent
|
| - * directly in std containers.
|
| - *
|
| - * The map relies on a backing map, whose type and accessors are described
|
| - * by the Traits class. The backing map will handle values of type
|
| - * PersistentContainerValue, with all conversion into and out of V8
|
| - * handles being transparently handled by this class.
|
| - */
|
| -template<class K, class V, class Traits>
|
| -class PersistentValueMap {
|
| - public:
|
| - V8_INLINE explicit PersistentValueMap(Isolate* isolate) : isolate_(isolate) {}
|
| -
|
| - V8_INLINE ~PersistentValueMap() { Clear(); }
|
| -
|
| - V8_INLINE Isolate* GetIsolate() { return isolate_; }
|
| -
|
| - /**
|
| - * Return size of the map.
|
| - */
|
| - V8_INLINE size_t Size() { return Traits::Size(&impl_); }
|
| -
|
| - /**
|
| - * Get value stored in map.
|
| - */
|
| - V8_INLINE Local<V> Get(const K& key) {
|
| - return Local<V>::New(isolate_, FromVal(Traits::Get(&impl_, key)));
|
| - }
|
| -
|
| - /**
|
| - * Check whether a value is contained in the map.
|
| - */
|
| - V8_INLINE bool Contains(const K& key) {
|
| - return Traits::Get(&impl_, key) != 0;
|
| - }
|
| -
|
| - /**
|
| - * Get value stored in map and set it in returnValue.
|
| - * Return true if a value was found.
|
| - */
|
| - V8_INLINE bool SetReturnValue(const K& key,
|
| - ReturnValue<Value>& returnValue);
|
| -
|
| - /**
|
| - * Call Isolate::SetReference with the given parent and the map value.
|
| - */
|
| - V8_INLINE void SetReference(const K& key,
|
| - const v8::Persistent<v8::Object>& parent) {
|
| - GetIsolate()->SetReference(
|
| - reinterpret_cast<internal::Object**>(parent.val_),
|
| - reinterpret_cast<internal::Object**>(FromVal(Traits::Get(&impl_, key))));
|
| - }
|
| -
|
| - /**
|
| - * Put value into map. Depending on Traits::kIsWeak, the value will be held
|
| - * by the map strongly or weakly.
|
| - * Returns old value as UniquePersistent.
|
| - */
|
| - UniquePersistent<V> Set(const K& key, Local<V> value) {
|
| - UniquePersistent<V> persistent(isolate_, value);
|
| - return SetUnique(key, &persistent);
|
| - }
|
| -
|
| - /**
|
| - * Put value into map, like Set(const K&, Local<V>).
|
| - */
|
| - UniquePersistent<V> Set(const K& key, UniquePersistent<V> value) {
|
| - return SetUnique(key, &value);
|
| - }
|
| -
|
| - /**
|
| - * Return value for key and remove it from the map.
|
| - */
|
| - V8_INLINE UniquePersistent<V> Remove(const K& key) {
|
| - return Release(Traits::Remove(&impl_, key)).Pass();
|
| - }
|
| -
|
| - /**
|
| - * Traverses the map repeatedly,
|
| - * in case side effects of disposal cause insertions.
|
| - **/
|
| - void Clear();
|
| -
|
| - private:
|
| - PersistentValueMap(PersistentValueMap&);
|
| - void operator=(PersistentValueMap&);
|
| -
|
| - /**
|
| - * Put the value into the map, and set the 'weak' callback when demanded
|
| - * by the Traits class.
|
| - */
|
| - UniquePersistent<V> SetUnique(const K& key, UniquePersistent<V>* persistent) {
|
| - if (Traits::kIsWeak) {
|
| - Local<V> value(Local<V>::New(isolate_, *persistent));
|
| - persistent->template SetWeak<typename Traits::WeakCallbackDataType>(
|
| - Traits::WeakCallbackParameter(&impl_, key, value), WeakCallback);
|
| - }
|
| - PersistentContainerValue old_value =
|
| - Traits::Set(&impl_, key, ClearAndLeak(persistent));
|
| - return Release(old_value).Pass();
|
| - }
|
| -
|
| - static void WeakCallback(
|
| - const WeakCallbackData<V, typename Traits::WeakCallbackDataType>& data);
|
| - V8_INLINE static V* FromVal(PersistentContainerValue v) {
|
| - return reinterpret_cast<V*>(v);
|
| - }
|
| - V8_INLINE static PersistentContainerValue ClearAndLeak(
|
| - UniquePersistent<V>* persistent) {
|
| - V* v = persistent->val_;
|
| - persistent->val_ = 0;
|
| - return reinterpret_cast<PersistentContainerValue>(v);
|
| - }
|
| -
|
| - /**
|
| - * Return a container value as UniquePersistent and make sure the weak
|
| - * callback is properly disposed of. All remove functionality should go
|
| - * through this.
|
| - */
|
| - V8_INLINE static UniquePersistent<V> Release(PersistentContainerValue v) {
|
| - UniquePersistent<V> p;
|
| - p.val_ = FromVal(v);
|
| - if (Traits::kIsWeak && !p.IsEmpty()) {
|
| - Traits::DisposeCallbackData(
|
| - p.template ClearWeak<typename Traits::WeakCallbackDataType>());
|
| - }
|
| - return p.Pass();
|
| - }
|
| -
|
| - Isolate* isolate_;
|
| - typename Traits::Impl impl_;
|
| -};
|
| -
|
| -
|
| /**
|
| * A stack-allocated class that governs a number of local handles.
|
| * After a handle scope has been created, all local handles will be
|
| @@ -2535,8 +2388,6 @@ class ReturnValue {
|
| template<class F> friend class ReturnValue;
|
| template<class F> friend class FunctionCallbackInfo;
|
| template<class F> friend class PropertyCallbackInfo;
|
| - template<class F, class G, class H> friend class PersistentValueMap;
|
| - V8_INLINE void SetInternal(internal::Object* value) { *value_ = value; }
|
| V8_INLINE internal::Object* GetDefaultValue();
|
| V8_INLINE explicit ReturnValue(internal::Object** slot);
|
| internal::Object** value_;
|
| @@ -4384,8 +4235,6 @@ class V8_EXPORT Isolate {
|
| void SetEventLogger(LogEventCallback that);
|
|
|
| private:
|
| - template<class K, class V, class Traits> friend class PersistentValueMap;
|
| -
|
| Isolate();
|
| Isolate(const Isolate&);
|
| ~Isolate();
|
| @@ -4980,7 +4829,7 @@ class V8_EXPORT V8 {
|
| static void MakeWeak(internal::Object** global_handle,
|
| void* data,
|
| WeakCallback weak_callback);
|
| - static void* ClearWeak(internal::Object** global_handle);
|
| + static void ClearWeak(internal::Object** global_handle);
|
| static void Eternalize(Isolate* isolate,
|
| Value* handle,
|
| int* index);
|
| @@ -5893,10 +5742,8 @@ void PersistentBase<T>::SetWeak(
|
|
|
|
|
| template <class T>
|
| -template<typename P>
|
| -P* PersistentBase<T>::ClearWeak() {
|
| - return reinterpret_cast<P*>(
|
| - V8::ClearWeak(reinterpret_cast<internal::Object**>(this->val_)));
|
| +void PersistentBase<T>::ClearWeak() {
|
| + V8::ClearWeak(reinterpret_cast<internal::Object**>(this->val_));
|
| }
|
|
|
|
|
| @@ -5949,44 +5796,6 @@ uint16_t PersistentBase<T>::WrapperClassId() const {
|
| }
|
|
|
|
|
| -template <class K, class V, class Traits>
|
| -bool PersistentValueMap<K, V, Traits>::SetReturnValue(const K& key,
|
| - ReturnValue<Value>& returnValue) {
|
| - PersistentContainerValue value = Traits::Get(&impl_, key);
|
| - bool hasValue = value != 0;
|
| - if (hasValue) {
|
| - returnValue.SetInternal(
|
| - *reinterpret_cast<internal::Object**>(FromVal(value)));
|
| - }
|
| - return hasValue;
|
| -}
|
| -
|
| -template <class K, class V, class Traits>
|
| -void PersistentValueMap<K, V, Traits>::Clear() {
|
| - typedef typename Traits::Iterator It;
|
| - HandleScope handle_scope(isolate_);
|
| - // TODO(dcarney): figure out if this swap and loop is necessary.
|
| - while (!Traits::Empty(&impl_)) {
|
| - typename Traits::Impl impl;
|
| - Traits::Swap(impl_, impl);
|
| - for (It i = Traits::Begin(&impl); i != Traits::End(&impl); ++i) {
|
| - Traits::Dispose(isolate_, Release(Traits::Value(i)).Pass(), &impl,
|
| - Traits::Key(i));
|
| - }
|
| - }
|
| -}
|
| -
|
| -
|
| -template <class K, class V, class Traits>
|
| -void PersistentValueMap<K, V, Traits>::WeakCallback(
|
| - const WeakCallbackData<V, typename Traits::WeakCallbackDataType>& data) {
|
| - typename Traits::Impl* impl = Traits::ImplFromWeakCallbackData(data);
|
| - K key = Traits::KeyFromWeakCallbackData(data);
|
| - PersistentContainerValue value = Traits::Remove(impl, key);
|
| - Traits::Dispose(data.GetIsolate(), Release(value).Pass(), impl, key);
|
| -}
|
| -
|
| -
|
| template<typename T>
|
| ReturnValue<T>::ReturnValue(internal::Object** slot) : value_(slot) {}
|
|
|
|
|