Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(278)

Unified Diff: include/v8.h

Issue 197173002: Revert "Implement PersistentValueMap, a map that stores UniquePersistent values." (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | src/api.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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) {}
« no previous file with comments | « no previous file | src/api.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698