Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2010 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 Loading... | |
| 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 #ifndef ScriptWrappable_h | 31 #ifndef ScriptWrappable_h |
| 32 #define ScriptWrappable_h | 32 #define ScriptWrappable_h |
| 33 | 33 |
| 34 #include "bindings/core/v8/WrapperTypeInfo.h" | 34 #include "bindings/core/v8/WrapperTypeInfo.h" |
| 35 #include "core/dom/ScriptForbiddenScope.h" | |
| 35 #include "platform/heap/Handle.h" | 36 #include "platform/heap/Handle.h" |
| 36 #include <v8.h> | 37 #include <v8.h> |
| 37 | 38 |
| 38 // Helper to call webCoreInitializeScriptWrappableForInterface in the global nam espace. | 39 // Helper to call webCoreInitializeScriptWrappableForInterface in the global nam espace. |
| 39 template <class C> inline void initializeScriptWrappableHelper(C* object) | 40 template <class C> inline void initializeScriptWrappableHelper(C* object) |
| 40 { | 41 { |
| 41 void webCoreInitializeScriptWrappableForInterface(C*); | 42 void webCoreInitializeScriptWrappableForInterface(C*); |
| 42 webCoreInitializeScriptWrappableForInterface(object); | 43 webCoreInitializeScriptWrappableForInterface(object); |
| 43 } | 44 } |
| 44 | 45 |
| (...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 245 setTypeInfo(toWrapperTypeInfo(wrapper)); | 246 setTypeInfo(toWrapperTypeInfo(wrapper)); |
| 246 } | 247 } |
| 247 | 248 |
| 248 // If zero, then this contains nothing, otherwise: | 249 // If zero, then this contains nothing, otherwise: |
| 249 // If the bottom bit it set, then this contains a pointer to a wrapper obj ect in the remainging bits. | 250 // If the bottom bit it set, then this contains a pointer to a wrapper obj ect in the remainging bits. |
| 250 // If the bottom bit is clear, then this contains a pointer to the wrapper type info in the remaining bits. | 251 // If the bottom bit is clear, then this contains a pointer to the wrapper type info in the remaining bits. |
| 251 uintptr_t m_wrapperOrTypeInfo; | 252 uintptr_t m_wrapperOrTypeInfo; |
| 252 | 253 |
| 253 static void setWeakCallback(const v8::WeakCallbackData<v8::Object, ScriptWra ppable>& data) | 254 static void setWeakCallback(const v8::WeakCallbackData<v8::Object, ScriptWra ppable>& data) |
| 254 { | 255 { |
| 256 ScriptForbiddenScope forbiddenScope; | |
|
jochen (gone - plz use gerrit)
2014/07/02 11:21:54
why here?
haraken
2014/07/02 11:23:13
Because this calls releaseObject() for DOM wrapper
| |
| 255 v8::Persistent<v8::Object> persistent; | 257 v8::Persistent<v8::Object> persistent; |
| 256 data.GetParameter()->getPersistent(&persistent); | 258 data.GetParameter()->getPersistent(&persistent); |
| 257 ASSERT(persistent == data.GetValue()); | 259 ASSERT(persistent == data.GetValue()); |
| 258 data.GetParameter()->disposeWrapper(data.GetValue()); | 260 data.GetParameter()->disposeWrapper(data.GetValue()); |
| 259 | 261 |
| 260 // FIXME: I noticed that 50%~ of minor GC cycle times can be consumed | 262 // FIXME: I noticed that 50%~ of minor GC cycle times can be consumed |
| 261 // inside data.GetParameter()->deref(), which causes Node destructions. We should | 263 // inside data.GetParameter()->deref(), which causes Node destructions. We should |
| 262 // make Node destructions incremental. | 264 // make Node destructions incremental. |
| 263 releaseObject(data.GetValue()); | 265 releaseObject(data.GetValue()); |
| 264 } | 266 } |
| 265 }; | 267 }; |
| 266 | 268 |
| 267 } // namespace WebCore | 269 } // namespace WebCore |
| 268 | 270 |
| 269 #endif // ScriptWrappable_h | 271 #endif // ScriptWrappable_h |
| OLD | NEW |