Index: third_party/WebKit/Source/bindings/core/v8/custom/V8HTMLElementCustom.cpp |
diff --git a/third_party/WebKit/Source/bindings/core/v8/custom/V8HTMLElementCustom.cpp b/third_party/WebKit/Source/bindings/core/v8/custom/V8HTMLElementCustom.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..14a68a21380f984853faa3980367e9928ef04184 |
--- /dev/null |
+++ b/third_party/WebKit/Source/bindings/core/v8/custom/V8HTMLElementCustom.cpp |
@@ -0,0 +1,72 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "bindings/core/v8/V8HTMLElement.h" |
+ |
+#include "bindings/core/v8/DOMWrapperWorld.h" |
+#include "bindings/core/v8/ExceptionState.h" |
+#include "bindings/core/v8/V8Binding.h" |
+#include "bindings/core/v8/V8ThrowException.h" |
+#include "core/dom/Document.h" |
+#include "core/dom/custom/CustomElementDefinition.h" |
+#include "core/dom/custom/CustomElementsRegistry.h" |
+#include "core/frame/LocalDOMWindow.h" |
+#include "platform/RuntimeEnabledFeatures.h" |
+ |
+namespace blink { |
+ |
+void V8HTMLElement::constructorCustom( |
+ const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ DCHECK(info.IsConstructCall()); |
+ v8::Isolate* isolate = info.GetIsolate(); |
+ |
+ if (!RuntimeEnabledFeatures::customElementsV1Enabled() |
+ || !DOMWrapperWorld::current(isolate).isMainWorld()) { |
+ V8ThrowException::throwIllegalConstructorTypeError(isolate); |
+ return; |
+ } |
+ |
+ Document* document = toDocument(currentExecutionContext(isolate)); |
+ v8::Local<v8::Context> context = isolate->GetCurrentContext(); |
+ CustomElementDefinition* def = |
+ document->domWindow()->customElements()->definitionForConstructor( |
+ context, |
+ info.NewTarget()); |
+ if (!def) { |
+ V8ThrowException::throwIllegalConstructorTypeError(isolate); |
+ return; |
+ } |
+ |
+ // TODO(dominicc): Implement cases where the definition's |
+ // construction stack is not empty when parser-creation is |
+ // implemented. |
+ ExceptionState exceptionState( |
+ ExceptionState::ConstructionContext, |
+ "HTMLElement", |
+ info.Holder(), |
+ isolate); |
+ Element* element = document->createElement( |
+ def->localName(), |
+ AtomicString(), |
+ exceptionState); |
+ if (exceptionState.throwIfNeeded()) |
+ return; |
+ v8::Local<v8::Object> wrapper = element->wrap(isolate, info.Holder()); |
Yuki
2016/05/11 01:59:02
Please prefer using toV8() rather than wrap() meth
|
+ info.GetReturnValue().Set(wrapper); |
haraken
2016/05/10 09:04:22
Can we use v8SetReturnValue(info, wrapper)?
I'm a
yosin_UTC9
2016/05/10 13:10:59
I think we don't need to set return value for cons
dominicc (has gone to gerrit)
2016/05/11 02:31:49
Hmm, I actually did start with the HTMLElement con
dominicc (has gone to gerrit)
2016/05/11 02:31:49
We do in this case because we are returning a diff
yosin_UTC9
2016/05/11 03:49:55
AFIK, return value of constructor isn't used. I tr
|
+ if (wrapper.IsEmpty()) |
+ return; |
+ |
+ v8::Maybe<bool> couldSetPrototype = |
+ wrapper->SetPrototype(context, def->prototype(isolate)); |
yosin_UTC9
2016/05/10 13:10:59
Can we use new.target.constructor.prototype? If so
dominicc (has gone to gerrit)
2016/05/11 02:31:49
I was wondering about this too; I filed https://gi
yosin_UTC9
2016/05/11 03:49:55
Can we change spec to pass tagName to super? If so
|
+ if (couldSetPrototype.IsNothing()) |
+ return; |
+ if (!couldSetPrototype.FromJust()) { |
haraken
2016/05/10 09:04:22
V8BindingMacros.h provides macros to avoid develop
|
+ // TODO(dominicc): Find out when SetPrototype can fail and write a |
+ // test for this. |
haraken
2016/05/10 09:04:22
You can use v8CallOrCrash. (In practice, it will n
|
+ return; |
+ } |
+} |
+ |
+} // namespace blink |