| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2012 Google Inc. All rights reserved. | 2 * Copyright (C) 2012 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 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 65 { | 65 { |
| 66 ASSERT(host); | 66 ASSERT(host); |
| 67 | 67 |
| 68 v8::Handle<v8::Object> wrapper = V8DOMWrapper::createWrapper(creationContext
, &V8InjectedScriptHost::wrapperTypeInfo, host->toScriptWrappableBase(), isolate
); | 68 v8::Handle<v8::Object> wrapper = V8DOMWrapper::createWrapper(creationContext
, &V8InjectedScriptHost::wrapperTypeInfo, host->toScriptWrappableBase(), isolate
); |
| 69 if (UNLIKELY(wrapper.IsEmpty())) | 69 if (UNLIKELY(wrapper.IsEmpty())) |
| 70 return wrapper; | 70 return wrapper; |
| 71 | 71 |
| 72 // Create a weak reference to the v8 wrapper of InspectorBackend to deref | 72 // Create a weak reference to the v8 wrapper of InspectorBackend to deref |
| 73 // InspectorBackend when the wrapper is garbage collected. | 73 // InspectorBackend when the wrapper is garbage collected. |
| 74 InjectedScriptManager::CallbackData* callbackData = injectedScriptManager->c
reateCallbackData(injectedScriptManager); | 74 InjectedScriptManager::CallbackData* callbackData = injectedScriptManager->c
reateCallbackData(injectedScriptManager); |
| 75 #if ENABLE(OILPAN) |
| 76 callbackData->hostPtr = WrapperPersistent<InjectedScriptHost>::create(host.g
et()); |
| 77 #else |
| 75 callbackData->host = host.get(); | 78 callbackData->host = host.get(); |
| 79 #endif |
| 76 callbackData->handle.set(isolate, wrapper); | 80 callbackData->handle.set(isolate, wrapper); |
| 77 callbackData->handle.setWeak(callbackData, &InjectedScriptManager::setWeakCa
llback); | 81 callbackData->handle.setWeak(callbackData, &InjectedScriptManager::setWeakCa
llback); |
| 78 | 82 |
| 79 #if ENABLE(OILPAN) | 83 #if ENABLE(OILPAN) |
| 80 V8DOMWrapper::setNativeInfoWithPersistentHandle(wrapper, &V8InjectedScriptHo
st::wrapperTypeInfo, host->toScriptWrappableBase(), &callbackData->host); | 84 V8DOMWrapper::setNativeInfoWithPersistentHandle(wrapper, &V8InjectedScriptHo
st::wrapperTypeInfo, host->toScriptWrappableBase(), callbackData->hostPtr); |
| 81 #else | 85 #else |
| 82 V8DOMWrapper::setNativeInfo(wrapper, &V8InjectedScriptHost::wrapperTypeInfo,
host->toScriptWrappableBase()); | 86 V8DOMWrapper::setNativeInfo(wrapper, &V8InjectedScriptHost::wrapperTypeInfo,
host->toScriptWrappableBase()); |
| 83 #endif | 87 #endif |
| 84 ASSERT(V8DOMWrapper::isDOMWrapper(wrapper)); | 88 ASSERT(V8DOMWrapper::isDOMWrapper(wrapper)); |
| 85 return wrapper; | 89 return wrapper; |
| 86 } | 90 } |
| 87 | 91 |
| 88 ScriptValue InjectedScriptManager::createInjectedScript(const String& scriptSour
ce, ScriptState* inspectedScriptState, int id) | 92 ScriptValue InjectedScriptManager::createInjectedScript(const String& scriptSour
ce, ScriptState* inspectedScriptState, int id) |
| 89 { | 93 { |
| 90 v8::Isolate* isolate = inspectedScriptState->isolate(); | 94 v8::Isolate* isolate = inspectedScriptState->isolate(); |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 127 return BindingSecurity::shouldAllowAccessToFrame(scriptState->isolate(), fra
me, DoNotReportSecurityError); | 131 return BindingSecurity::shouldAllowAccessToFrame(scriptState->isolate(), fra
me, DoNotReportSecurityError); |
| 128 } | 132 } |
| 129 | 133 |
| 130 void InjectedScriptManager::setWeakCallback(const v8::WeakCallbackData<v8::Objec
t, InjectedScriptManager::CallbackData>& data) | 134 void InjectedScriptManager::setWeakCallback(const v8::WeakCallbackData<v8::Objec
t, InjectedScriptManager::CallbackData>& data) |
| 131 { | 135 { |
| 132 InjectedScriptManager::CallbackData* callbackData = data.GetParameter(); | 136 InjectedScriptManager::CallbackData* callbackData = data.GetParameter(); |
| 133 callbackData->injectedScriptManager->removeCallbackData(callbackData); | 137 callbackData->injectedScriptManager->removeCallbackData(callbackData); |
| 134 } | 138 } |
| 135 | 139 |
| 136 } // namespace blink | 140 } // namespace blink |
| OLD | NEW |