OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2013 Google Inc. All rights reserved. | 2 * Copyright (C) 2013 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 | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 21 matching lines...) Expand all Loading... |
32 #include "bindings/v8/V8Binding.h" | 32 #include "bindings/v8/V8Binding.h" |
33 #include "bindings/v8/V8HiddenValue.h" | 33 #include "bindings/v8/V8HiddenValue.h" |
34 #include "core/dom/ExecutionContext.h" | 34 #include "core/dom/ExecutionContext.h" |
35 #include "wtf/Assertions.h" | 35 #include "wtf/Assertions.h" |
36 | 36 |
37 namespace WebCore { | 37 namespace WebCore { |
38 | 38 |
39 V8MutationCallback::V8MutationCallback(v8::Handle<v8::Function> callback, Execut
ionContext* context, v8::Handle<v8::Object> owner, v8::Isolate* isolate) | 39 V8MutationCallback::V8MutationCallback(v8::Handle<v8::Function> callback, Execut
ionContext* context, v8::Handle<v8::Object> owner, v8::Isolate* isolate) |
40 : ActiveDOMCallback(context) | 40 : ActiveDOMCallback(context) |
41 , m_callback(isolate, callback) | 41 , m_callback(isolate, callback) |
42 , m_world(DOMWrapperWorld::current(isolate)) | 42 , m_scriptState(NewScriptState::current(isolate)) |
43 , m_isolate(isolate) | |
44 { | 43 { |
45 V8HiddenValue::setHiddenValue(m_isolate, owner, V8HiddenValue::callback(m_is
olate), callback); | 44 V8HiddenValue::setHiddenValue(isolate, owner, V8HiddenValue::callback(isolat
e), callback); |
46 m_callback.setWeak(this, &setWeakCallback); | 45 m_callback.setWeak(this, &setWeakCallback); |
47 } | 46 } |
48 | 47 |
49 void V8MutationCallback::call(const Vector<RefPtr<MutationRecord> >& mutations,
MutationObserver* observer) | 48 void V8MutationCallback::call(const Vector<RefPtr<MutationRecord> >& mutations,
MutationObserver* observer) |
50 { | 49 { |
51 if (!canInvokeCallback()) | 50 if (!canInvokeCallback()) |
52 return; | 51 return; |
53 | 52 |
54 v8::HandleScope handleScope(m_isolate); | 53 v8::Isolate* isolate = m_scriptState->isolate(); |
| 54 v8::HandleScope handleScope(isolate); |
55 | 55 |
56 v8::Handle<v8::Context> v8Context = toV8Context(executionContext(), *m_world
); | 56 v8::Handle<v8::Context> v8Context = m_scriptState->context(); |
57 if (v8Context.IsEmpty()) | 57 if (v8Context.IsEmpty()) |
58 return; | 58 return; |
59 | 59 |
60 v8::Context::Scope scope(v8Context); | 60 v8::Context::Scope scope(v8Context); |
61 | 61 |
62 v8::Handle<v8::Function> callback = m_callback.newLocal(m_isolate); | 62 v8::Handle<v8::Function> callback = m_callback.newLocal(isolate); |
63 if (callback.IsEmpty()) | 63 if (callback.IsEmpty()) |
64 return; | 64 return; |
65 | 65 |
66 v8::Handle<v8::Value> observerHandle = toV8(observer, v8::Handle<v8::Object>
(), m_isolate); | 66 v8::Handle<v8::Value> observerHandle = toV8(observer, v8::Handle<v8::Object>
(), isolate); |
67 if (observerHandle.IsEmpty()) { | 67 if (observerHandle.IsEmpty()) { |
68 if (!isScriptControllerTerminating()) | 68 if (!isScriptControllerTerminating()) |
69 CRASH(); | 69 CRASH(); |
70 return; | 70 return; |
71 } | 71 } |
72 | 72 |
73 if (!observerHandle->IsObject()) | 73 if (!observerHandle->IsObject()) |
74 return; | 74 return; |
75 | 75 |
76 v8::Handle<v8::Object> thisObject = v8::Handle<v8::Object>::Cast(observerHan
dle); | 76 v8::Handle<v8::Object> thisObject = v8::Handle<v8::Object>::Cast(observerHan
dle); |
77 v8::Handle<v8::Value> argv[] = { v8Array(mutations, m_isolate), observerHand
le }; | 77 v8::Handle<v8::Value> argv[] = { v8Array(mutations, isolate), observerHandle
}; |
78 | 78 |
79 v8::TryCatch exceptionCatcher; | 79 v8::TryCatch exceptionCatcher; |
80 exceptionCatcher.SetVerbose(true); | 80 exceptionCatcher.SetVerbose(true); |
81 ScriptController::callFunction(executionContext(), callback, thisObject, 2,
argv, m_isolate); | 81 ScriptController::callFunction(executionContext(), callback, thisObject, 2,
argv, isolate); |
82 } | 82 } |
83 | 83 |
84 void V8MutationCallback::setWeakCallback(const v8::WeakCallbackData<v8::Function
, V8MutationCallback>& data) | 84 void V8MutationCallback::setWeakCallback(const v8::WeakCallbackData<v8::Function
, V8MutationCallback>& data) |
85 { | 85 { |
86 data.GetParameter()->m_callback.clear(); | 86 data.GetParameter()->m_callback.clear(); |
87 } | 87 } |
88 | 88 |
89 } // namespace WebCore | 89 } // namespace WebCore |
OLD | NEW |