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

Side by Side Diff: Source/bindings/v8/custom/V8MessageEventCustom.cpp

Issue 17063016: Remove leak of objects between isolated worlds on custom events. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Minor rebase nits. Created 7 years, 5 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2009 Google Inc. All rights reserved. 2 * Copyright (C) 2009 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 14 matching lines...) Expand all
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */ 29 */
30 30
31 #include "config.h" 31 #include "config.h"
32 #include "V8MessageEvent.h" 32 #include "V8MessageEvent.h"
33 33
34 #include "bindings/v8/SerializedScriptValue.h" 34 #include "bindings/v8/SerializedScriptValue.h"
35 #include "bindings/v8/V8HiddenPropertyName.h"
35 #include "bindings/v8/custom/V8ArrayBufferCustom.h" 36 #include "bindings/v8/custom/V8ArrayBufferCustom.h"
36 #include "core/dom/MessageEvent.h" 37 #include "core/dom/MessageEvent.h"
37 38
38 #include "V8Blob.h" 39 #include "V8Blob.h"
39 #include "V8MessagePort.h" 40 #include "V8MessagePort.h"
40 #include "V8Window.h" 41 #include "V8Window.h"
41 #include "bindings/v8/V8Binding.h" 42 #include "bindings/v8/V8Binding.h"
42 43
43 namespace WebCore { 44 namespace WebCore {
44 45
45 void V8MessageEvent::dataAttrGetterCustom(v8::Local<v8::String> name, const v8:: PropertyCallbackInfo<v8::Value>& info) 46 void V8MessageEvent::dataAttrGetterCustom(v8::Local<v8::String> name, const v8:: PropertyCallbackInfo<v8::Value>& info)
46 { 47 {
47 MessageEvent* event = V8MessageEvent::toNative(info.Holder()); 48 MessageEvent* event = V8MessageEvent::toNative(info.Holder());
48 49
49 v8::Handle<v8::Value> result; 50 v8::Handle<v8::Value> result;
50 switch (event->dataType()) { 51 switch (event->dataType()) {
51 case MessageEvent::DataTypeScriptValue: { 52 case MessageEvent::DataTypeScriptValue: {
52 ScriptValue scriptValue = event->dataAsScriptValue(); 53 result = info.Holder()->GetHiddenValue(V8HiddenPropertyName::data());
53 if (scriptValue.hasNoValue()) 54 if (result.IsEmpty())
54 result = v8::Null(info.GetIsolate()); 55 result = v8::Null(info.GetIsolate());
55 else
56 result = scriptValue.v8Value();
57 break; 56 break;
58 } 57 }
59 58
60 case MessageEvent::DataTypeSerializedScriptValue: 59 case MessageEvent::DataTypeSerializedScriptValue:
61 if (RefPtr<SerializedScriptValue> serializedValue = event->dataAsSeriali zedScriptValue()) { 60 if (RefPtr<SerializedScriptValue> serializedValue = event->dataAsSeriali zedScriptValue()) {
62 MessagePortArray ports = event->ports(); 61 MessagePortArray ports = event->ports();
63 result = serializedValue->deserialize(info.GetIsolate(), &ports); 62 result = serializedValue->deserialize(info.GetIsolate(), &ports);
64 } else { 63 } else {
65 result = v8::Null(info.GetIsolate()); 64 result = v8::Null(info.GetIsolate());
66 } 65 }
(...skipping 17 matching lines...) Expand all
84 // Overwrite the data attribute so it returns the cached result in future in vocations. 83 // Overwrite the data attribute so it returns the cached result in future in vocations.
85 // This custom handler (dataAccessGetter) will not be called again. 84 // This custom handler (dataAccessGetter) will not be called again.
86 v8::PropertyAttribute dataAttr = static_cast<v8::PropertyAttribute>(v8::Dont Delete | v8::ReadOnly); 85 v8::PropertyAttribute dataAttr = static_cast<v8::PropertyAttribute>(v8::Dont Delete | v8::ReadOnly);
87 info.Holder()->ForceSet(name, result, dataAttr); 86 info.Holder()->ForceSet(name, result, dataAttr);
88 v8SetReturnValue(info, result); 87 v8SetReturnValue(info, result);
89 } 88 }
90 89
91 void V8MessageEvent::initMessageEventMethodCustom(const v8::FunctionCallbackInfo <v8::Value>& args) 90 void V8MessageEvent::initMessageEventMethodCustom(const v8::FunctionCallbackInfo <v8::Value>& args)
92 { 91 {
93 MessageEvent* event = V8MessageEvent::toNative(args.Holder()); 92 MessageEvent* event = V8MessageEvent::toNative(args.Holder());
94 String typeArg = toWebCoreString(args[0]); 93 V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, typeArg, args[0]);
95 bool canBubbleArg = args[1]->BooleanValue(); 94 V8TRYCATCH_VOID(bool, canBubbleArg, args[1]->BooleanValue());
96 bool cancelableArg = args[2]->BooleanValue(); 95 V8TRYCATCH_VOID(bool, cancelableArg, args[2]->BooleanValue());
97 ScriptValue dataArg = ScriptValue(args[3]); 96 v8::Handle<v8::Value> dataArg = args[3];
98 String originArg = toWebCoreString(args[4]); 97 V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, originArg, args[4]) ;
99 String lastEventIdArg = toWebCoreString(args[5]); 98 V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, lastEventIdArg, arg s[5]);
100 99
101 DOMWindow* sourceArg = 0; 100 DOMWindow* sourceArg = 0;
102 if (args[6]->IsObject()) { 101 if (args[6]->IsObject()) {
103 v8::Handle<v8::Object> wrapper = v8::Handle<v8::Object>::Cast(args[6]); 102 v8::Handle<v8::Object> wrapper = v8::Handle<v8::Object>::Cast(args[6]);
104 v8::Handle<v8::Object> window = wrapper->FindInstanceInPrototypeChain(V8 Window::GetTemplate(args.GetIsolate(), worldTypeInMainThread(args.GetIsolate())) ); 103 v8::Handle<v8::Object> window = wrapper->FindInstanceInPrototypeChain(V8 Window::GetTemplate(args.GetIsolate(), worldTypeInMainThread(args.GetIsolate())) );
105 if (!window.IsEmpty()) 104 if (!window.IsEmpty())
106 sourceArg = V8Window::toNative(window); 105 sourceArg = V8Window::toNative(window);
107 } 106 }
108 OwnPtr<MessagePortArray> portArray; 107 OwnPtr<MessagePortArray> portArray;
109 108
110 if (!isUndefinedOrNull(args[7])) { 109 if (!isUndefinedOrNull(args[7])) {
111 portArray = adoptPtr(new MessagePortArray); 110 portArray = adoptPtr(new MessagePortArray);
112 if (!getMessagePortArray(args[7], *portArray, args.GetIsolate())) 111 if (!getMessagePortArray(args[7], *portArray, args.GetIsolate()))
113 return; 112 return;
114 } 113 }
115 event->initMessageEvent(typeArg, canBubbleArg, cancelableArg, dataArg, origi nArg, lastEventIdArg, sourceArg, portArray.release()); 114 args.Holder()->SetHiddenValue(V8HiddenPropertyName::data(), dataArg);
115 event->initMessageEvent(typeArg, canBubbleArg, cancelableArg, originArg, las tEventIdArg, sourceArg, portArray.release());
116 } 116 }
117 117
118 void V8MessageEvent::webkitInitMessageEventMethodCustom(const v8::FunctionCallba ckInfo<v8::Value>& args) 118 void V8MessageEvent::webkitInitMessageEventMethodCustom(const v8::FunctionCallba ckInfo<v8::Value>& args)
119 { 119 {
120 initMessageEventMethodCustom(args); 120 initMessageEventMethodCustom(args);
121 } 121 }
122 122
123 123
124 } // namespace WebCore 124 } // namespace WebCore
OLDNEW
« no previous file with comments | « Source/bindings/v8/custom/V8CustomEventCustom.cpp ('k') | Source/bindings/v8/custom/V8PopStateEventCustom.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698