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

Side by Side Diff: gin/wrappable.cc

Issue 105423003: gin::Wrappable shouldn't inherit from base::RefCounted (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix win Created 7 years 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « gin/wrappable.h ('k') | gin/wrappable_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "gin/wrappable.h" 5 #include "gin/wrappable.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "gin/per_isolate_data.h" 8 #include "gin/per_isolate_data.h"
9 9
10 namespace gin { 10 namespace gin {
11 11
12 Wrappable::Wrappable() { 12 Wrappable::Wrappable() {
13 } 13 }
14 14
15 Wrappable::~Wrappable() { 15 Wrappable::~Wrappable() {
16 wrapper_.Reset(); 16 wrapper_.Reset();
17 } 17 }
18 18
19 v8::Handle<v8::Object> Wrappable::GetWrapper(v8::Isolate* isolate) { 19 v8::Handle<v8::Object> Wrappable::GetWrapper(v8::Isolate* isolate) {
20 v8::Handle<v8::Value> wrapper = ConvertToV8(isolate, this); 20 v8::Handle<v8::Value> wrapper = ConvertToV8(isolate, this);
21 DCHECK(wrapper->IsObject()); 21 DCHECK(wrapper->IsObject());
22 return v8::Handle<v8::Object>::Cast(wrapper); 22 return v8::Handle<v8::Object>::Cast(wrapper);
23 } 23 }
24 24
25 void Wrappable::WeakCallback( 25 void Wrappable::WeakCallback(
26 const v8::WeakCallbackData<v8::Object, Wrappable>& data) { 26 const v8::WeakCallbackData<v8::Object, Wrappable>& data) {
27 Wrappable* wrappable = data.GetParameter(); 27 Wrappable* wrappable = data.GetParameter();
28 wrappable->wrapper_.Reset(); 28 wrappable->wrapper_.Reset();
29 wrappable->Release(); // Balanced in Wrappable::ConfigureWrapper. 29 delete wrappable;
30 } 30 }
31 31
32 v8::Handle<v8::Object> Wrappable::CreateWrapper(v8::Isolate* isolate) { 32 v8::Handle<v8::Object> Wrappable::CreateWrapper(v8::Isolate* isolate) {
33 WrapperInfo* info = GetWrapperInfo(); 33 WrapperInfo* info = GetWrapperInfo();
34 PerIsolateData* data = PerIsolateData::From(isolate); 34 PerIsolateData* data = PerIsolateData::From(isolate);
35 v8::Local<v8::ObjectTemplate> templ = data->GetObjectTemplate(info); 35 v8::Local<v8::ObjectTemplate> templ = data->GetObjectTemplate(info);
36 CHECK(!templ.IsEmpty()); // Don't forget to register an object template. 36 CHECK(!templ.IsEmpty()); // Don't forget to register an object template.
37 CHECK(templ->InternalFieldCount() == kNumberOfInternalFields); 37 CHECK(templ->InternalFieldCount() == kNumberOfInternalFields);
38 v8::Handle<v8::Object> wrapper = templ->NewInstance(); 38 v8::Handle<v8::Object> wrapper = templ->NewInstance();
39 wrapper->SetAlignedPointerInInternalField(kWrapperInfoIndex, info); 39 wrapper->SetAlignedPointerInInternalField(kWrapperInfoIndex, info);
40 wrapper->SetAlignedPointerInInternalField(kEncodedValueIndex, this); 40 wrapper->SetAlignedPointerInInternalField(kEncodedValueIndex, this);
41 wrapper_.Reset(isolate, wrapper); 41 wrapper_.Reset(isolate, wrapper);
42 AddRef(); // Balanced in Wrappable::WeakCallback.
43 wrapper_.SetWeak(this, WeakCallback); 42 wrapper_.SetWeak(this, WeakCallback);
44 return wrapper; 43 return wrapper;
45 } 44 }
46 45
47 v8::Handle<v8::Value> Converter<Wrappable*>::ToV8(v8::Isolate* isolate, 46 v8::Handle<v8::Value> Converter<Wrappable*>::ToV8(v8::Isolate* isolate,
48 Wrappable* val) { 47 Wrappable* val) {
49 if (val->wrapper_.IsEmpty()) 48 if (val->wrapper_.IsEmpty())
50 return val->CreateWrapper(isolate); 49 return val->CreateWrapper(isolate);
51 return v8::Local<v8::Object>::New(isolate, val->wrapper_); 50 return v8::Local<v8::Object>::New(isolate, val->wrapper_);
52 } 51 }
53 52
54 bool Converter<Wrappable*>::FromV8(v8::Isolate* isolate, 53 bool Converter<Wrappable*>::FromV8(v8::Isolate* isolate,
55 v8::Handle<v8::Value> val, Wrappable** out) { 54 v8::Handle<v8::Value> val, Wrappable** out) {
56 if (!val->IsObject()) 55 if (!val->IsObject())
57 return false; 56 return false;
58 v8::Handle<v8::Object> obj = v8::Handle<v8::Object>::Cast(val); 57 v8::Handle<v8::Object> obj = v8::Handle<v8::Object>::Cast(val);
59 WrapperInfo* info = WrapperInfo::From(obj); 58 WrapperInfo* info = WrapperInfo::From(obj);
60 if (!info) 59 if (!info)
61 return false; 60 return false;
62 void* pointer = obj->GetAlignedPointerFromInternalField(kEncodedValueIndex); 61 void* pointer = obj->GetAlignedPointerFromInternalField(kEncodedValueIndex);
63 Wrappable* wrappable = static_cast<Wrappable*>(pointer); 62 Wrappable* wrappable = static_cast<Wrappable*>(pointer);
64 CHECK(wrappable->GetWrapperInfo() == info); // Security check for cast above. 63 CHECK(wrappable->GetWrapperInfo() == info); // Security check for cast above.
65 *out = wrappable; 64 *out = wrappable;
66 return true; 65 return true;
67 } 66 }
68 67
69 } // namespace gin 68 } // namespace gin
OLDNEW
« no previous file with comments | « gin/wrappable.h ('k') | gin/wrappable_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698