blob: 150790657631f053bf9ec3d6343440bfc407613a [file] [log] [blame]
// Copyright 2020 The Cobalt Authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// clang-format off
// This file has been auto-generated by bindings/code_generator_cobalt.py. DO NOT MODIFY!
// Auto-generated from template: bindings/v8c/templates/interface.cc.template
#include "cobalt/bindings/shared/idl_conditional_macros.h"
#include "cobalt/bindings/testing/v8c_anonymous_named_indexed_getter_interface.h"
#include "base/trace_event/trace_event.h"
#include "cobalt/base/polymorphic_downcast.h"
#include "cobalt/script/global_environment.h"
#include "cobalt/script/script_value.h"
#include "cobalt/script/value_handle.h"
#include "v8c_gen_type_conversion.h"
#include "cobalt/script/callback_interface_traits.h"
#include "cobalt/script/v8c/v8c_array_buffer.h"
#include "cobalt/script/v8c/v8c_array_buffer_view.h"
#include "cobalt/script/v8c/callback_function_conversion.h"
#include "cobalt/script/v8c/conversion_helpers.h"
#include "cobalt/script/v8c/entry_scope.h"
#include "cobalt/script/v8c/helpers.h"
#include "cobalt/script/v8c/native_promise.h"
#include "cobalt/script/v8c/type_traits.h"
#include "cobalt/script/v8c/v8c_typed_arrays.h"
#include "cobalt/script/v8c/v8c_data_view.h"
#include "cobalt/script/v8c/v8c_callback_function.h"
#include "cobalt/script/v8c/v8c_callback_interface_holder.h"
#include "cobalt/script/v8c/v8c_engine.h"
#include "cobalt/script/v8c/v8c_exception_state.h"
#include "cobalt/script/v8c/v8c_global_environment.h"
#include "cobalt/script/v8c/v8c_property_enumerator.h"
#include "cobalt/script/v8c/v8c_value_handle.h"
#include "cobalt/script/v8c/wrapper_private.h"
#include "cobalt/script/v8c/common_v8c_bindings_code.h"
#include "v8/include/v8.h"
namespace {
using cobalt::bindings::testing::AnonymousNamedIndexedGetterInterface;
using cobalt::bindings::testing::V8cAnonymousNamedIndexedGetterInterface;
using cobalt::script::CallbackInterfaceTraits;
using cobalt::script::GlobalEnvironment;
using cobalt::script::ScriptValue;
using cobalt::script::ValueHandle;
using cobalt::script::ValueHandle;
using cobalt::script::ValueHandleHolder;
using cobalt::script::Wrappable;
using cobalt::script::v8c::EntryScope;
using cobalt::script::v8c::EscapableEntryScope;
using cobalt::script::v8c::FromJSValue;
using cobalt::script::v8c::kConversionFlagClamped;
using cobalt::script::v8c::kConversionFlagNullable;
using cobalt::script::v8c::kConversionFlagObjectOnly;
using cobalt::script::v8c::kConversionFlagRestricted;
using cobalt::script::v8c::kConversionFlagTreatNullAsEmptyString;
using cobalt::script::v8c::kConversionFlagTreatUndefinedAsEmptyString;
using cobalt::script::v8c::kNoConversionFlags;
using cobalt::script::v8c::NewInternalString;
using cobalt::script::v8c::ToJSValue;
using cobalt::script::v8c::TypeTraits;
using cobalt::script::v8c::V8cExceptionState;
using cobalt::script::v8c::V8cGlobalEnvironment;
using cobalt::script::v8c::V8cPropertyEnumerator;
using cobalt::script::v8c::WrapperFactory;
using cobalt::script::v8c::WrapperPrivate;
} // namespace
namespace cobalt {
namespace bindings {
namespace testing {
namespace {
const int kInterfaceUniqueId = 2;
void NamedPropertyGetterCallback(
v8::Local<v8::Name> property,
const v8::PropertyCallbackInfo<v8::Value>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Object> object = info.Holder();
V8cExceptionState exception_state{isolate};
v8::Local<v8::Value> result_value;
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
std::string property_name = *v8::String::Utf8Value(isolate, property);
if (!impl->CanQueryNamedProperty(property_name)) {
return;
}
if (!exception_state.is_exception_set()) {
ToJSValue(isolate,
impl->AnonymousNamedGetter(property_name),
&result_value);
}
if (exception_state.is_exception_set()) {
return;
}
info.GetReturnValue().Set(result_value);
}
void NamedPropertyQueryCallback(
v8::Local<v8::Name> property,
const v8::PropertyCallbackInfo<v8::Integer>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Object> object = info.Holder();
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
std::string property_name = *v8::String::Utf8Value(isolate, property);
bool result = impl->CanQueryNamedProperty(property_name);
if (!result) {
return;
}
// https://heycam.github.io/webidl/#LegacyPlatformObjectGetOwnProperty
int properties = v8::None;
// 2.7. If |O| implements an interface with a named property setter, then set
// desc.[[Writable]] to true, otherwise set it to false.
// 2.8. If |O| implements an interface with the
// [LegacyUnenumerableNamedProperties] extended attribute, then set
// desc.[[Enumerable]] to false, otherwise set it to true.
info.GetReturnValue().Set(properties);
}
void NamedPropertyEnumeratorCallback(
const v8::PropertyCallbackInfo<v8::Array>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Object> object = info.Holder();
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
v8::Local<v8::Array> array = v8::Array::New(isolate);
V8cPropertyEnumerator property_enumerator(isolate, &array);
impl->EnumerateNamedProperties(&property_enumerator);
info.GetReturnValue().Set(array);
}
void NamedPropertySetterCallback(
v8::Local<v8::Name> property,
v8::Local<v8::Value> value,
const v8::PropertyCallbackInfo<v8::Value>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Object> object = info.Holder();
V8cExceptionState exception_state{isolate};
v8::Local<v8::Value> result_value;
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
std::string property_name = *v8::String::Utf8Value(isolate, property);
TypeTraits<std::string>::ConversionType native_value;
FromJSValue(isolate, value, kNoConversionFlags,
&exception_state, &native_value);
if (exception_state.is_exception_set()) {
return;
}
impl->AnonymousNamedSetter(property_name, native_value);
result_value = v8::Undefined(isolate);
if (exception_state.is_exception_set()) {
return;
}
info.GetReturnValue().Set(value);
}
void IndexedPropertyGetterCallback(
uint32_t index,
const v8::PropertyCallbackInfo<v8::Value>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Object> object = info.Holder();
V8cExceptionState exception_state{isolate};
v8::Local<v8::Value> result_value;
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
if (index >= impl->length()) {
// |index| is out of bounds, so return undefined.
return;
}
if (!exception_state.is_exception_set()) {
ToJSValue(isolate,
impl->AnonymousIndexedGetter(index),
&result_value);
}
info.GetReturnValue().Set(result_value);
}
void IndexedPropertyDescriptorCallback(
uint32_t index, const v8::PropertyCallbackInfo<v8::Value>& info) {
// TODO: Figure out under what conditions this gets called. It's not
// getting called in our tests.
NOTIMPLEMENTED();
}
void IndexedPropertyEnumeratorCallback(
const v8::PropertyCallbackInfo<v8::Array>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Context> context = isolate->GetCurrentContext();
v8::Local<v8::Object> object = info.Holder();
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
const uint32_t length = impl->length();
v8::Local<v8::Array> array = v8::Array::New(isolate, length);
for (uint32_t i = 0; i < length; ++i) {
array->Set(context, i, v8::Integer::New(isolate, i)).Check();
}
info.GetReturnValue().Set(array);
}
void IndexedPropertyDefinerCallback(
uint32_t index, const v8::PropertyDescriptor& desc,
const v8::PropertyCallbackInfo<v8::Value>& info) {
// TODO: Figure out under what conditions this gets called. It's not
// getting called in our tests.
NOTIMPLEMENTED();
}
void IndexedPropertySetterCallback(
uint32_t index,
v8::Local<v8::Value> value,
const v8::PropertyCallbackInfo<v8::Value>& info) {
v8::Isolate* isolate = info.GetIsolate();
v8::Local<v8::Object> object = info.Holder();
V8cExceptionState exception_state{isolate};
v8::Local<v8::Value> result_value;
AnonymousNamedIndexedGetterInterface* impl =
script::v8c::shared_bindings::get_impl_from_object<
AnonymousNamedIndexedGetterInterface>(object);
if (!impl) {
return;
}
if (index >= impl->length()) {
return;
}
TypeTraits<uint32_t>::ConversionType native_value;
FromJSValue(isolate, value, kNoConversionFlags,
&exception_state, &native_value);
if (exception_state.is_exception_set()) {
return;
}
impl->AnonymousIndexedSetter(index, native_value);
result_value = v8::Undefined(isolate);
if (exception_state.is_exception_set()) {
return;
}
info.GetReturnValue().Set(value);
}
void DummyConstructor(const v8::FunctionCallbackInfo<v8::Value>& info) {
V8cExceptionState exception(info.GetIsolate());
exception.SetSimpleException(
script::kTypeError, "AnonymousNamedIndexedGetterInterface is not constructible.");
}
void lengthAttributeGetter(
const v8::FunctionCallbackInfo<v8::Value>& info) {
script::v8c::shared_bindings::AttributeGetterImpl<AnonymousNamedIndexedGetterInterface,
V8cAnonymousNamedIndexedGetterInterface>(
info,
false,
false,
[](v8::Isolate* isolate, AnonymousNamedIndexedGetterInterface* impl,
cobalt::script::ExceptionState& exception_state,
v8::Local<v8::Value>& result_value) {
ToJSValue(isolate,
impl->length(),
&result_value);
});
}
void InitializeTemplate(v8::Isolate* isolate) {
// https://heycam.github.io/webidl/#interface-object
// 3.6.1. Interface object
//
// The interface object for a given interface is a built-in function object.
// It has properties that correspond to the constants and static operations
// defined on that interface, as described in sections 3.6.6 Constants and
// 3.6.8 Operations.
//
// If the interface is declared with a [Constructor] extended attribute,
// then the interface object can be called as a constructor to create an
// object that implements that interface. Calling that interface as a
// function will throw an exception.
//
// Interface objects whose interfaces are not declared with a [Constructor]
// extended attribute will throw when called, both as a function and as a
// constructor.
//
// An interface object for a non-callback interface has an associated object
// called the interface prototype object. This object has properties that
// correspond to the regular attributes and regular operations defined on
// the interface, and is described in more detail in 3.6.3 Interface
// prototype object.
v8::Local<v8::FunctionTemplate> function_template =
v8::FunctionTemplate::New(
isolate,
DummyConstructor,
v8::Local<v8::Value>(),
v8::Local<v8::Signature>(),
0);
function_template->SetClassName(NewInternalString(isolate, "AnonymousNamedIndexedGetterInterface"));
function_template->ReadOnlyPrototype();
v8::Local<v8::ObjectTemplate> prototype_template = function_template->PrototypeTemplate();
v8::Local<v8::ObjectTemplate> instance_template = function_template->InstanceTemplate();
instance_template->SetInternalFieldCount(WrapperPrivate::kInternalFieldCount);
V8cGlobalEnvironment* global_environment = V8cGlobalEnvironment::GetFromIsolate(isolate);
global_environment->AddInterfaceData(kInterfaceUniqueId, function_template);
// https://heycam.github.io/webidl/#es-constants
// 3.6.6. Constants
//
// For each exposed constant defined on an interface A, there must be a
// corresponding property. The property has the following characteristics:
// https://heycam.github.io/webidl/#es-attributes
// 3.6.7. Attributes
//
// For each exposed attribute of the interface there must exist a
// corresponding property. The characteristics of this property are as
// follows:
{
script::v8c::shared_bindings::set_property_for_nonconstructor_attribute(
isolate,
// The property has attributes { [[Get]]: G, [[Set]]: S, [[Enumerable]]:
// true, [[Configurable]]: configurable }, where: configurable is false if
// the attribute was declared with the [Unforgeable] extended attribute and
// true otherwise;
true,
false,
false,
false,
function_template,
instance_template,
prototype_template,
"length"
,lengthAttributeGetter
);
}
// https://heycam.github.io/webidl/#es-operations
// 3.6.8. Operations
//
// For each unique identifier of an exposed operation defined on the
// interface, there must exist a corresponding property, unless the effective
// overload set for that identifier and operation and with an argument count
// of 0 has no entries.
//
// The characteristics of this property are as follows:
// https://heycam.github.io/webidl/#es-stringifier
// 3.6.8.2. Stringifiers
prototype_template->Set(
v8::Symbol::GetToStringTag(isolate),
NewInternalString(isolate, "AnonymousNamedIndexedGetterInterface"),
static_cast<v8::PropertyAttribute>(v8::ReadOnly | v8::DontEnum));
{
v8::NamedPropertyHandlerConfiguration named_property_handler_configuration = {
NamedPropertyGetterCallback,
NamedPropertySetterCallback,
NamedPropertyQueryCallback,
nullptr,
NamedPropertyEnumeratorCallback,
v8::Local<v8::Value>(),
static_cast<v8::PropertyHandlerFlags>(int(v8::PropertyHandlerFlags::kNonMasking) | int(v8::PropertyHandlerFlags::kOnlyInterceptStrings))
};
instance_template->SetHandler(named_property_handler_configuration);
}
{
v8::IndexedPropertyHandlerConfiguration indexed_property_handler_configuration = {
IndexedPropertyGetterCallback,
IndexedPropertySetterCallback,
IndexedPropertyDescriptorCallback,
nullptr,
IndexedPropertyEnumeratorCallback,
IndexedPropertyDefinerCallback
};
instance_template->SetHandler(indexed_property_handler_configuration);
}
}
} // namespace
v8::Local<v8::Object> V8cAnonymousNamedIndexedGetterInterface::CreateWrapper(
v8::Isolate* isolate, const scoped_refptr<Wrappable>& wrappable) {
EscapableEntryScope entry_scope(isolate);
v8::Local<v8::Context> context = isolate->GetCurrentContext();
V8cGlobalEnvironment* global_environment = V8cGlobalEnvironment::GetFromIsolate(isolate);
if (!global_environment->HasInterfaceData(kInterfaceUniqueId)) {
InitializeTemplate(isolate);
}
v8::Local<v8::FunctionTemplate> function_template = global_environment->GetInterfaceData(kInterfaceUniqueId);
DCHECK(function_template->InstanceTemplate()->InternalFieldCount() == WrapperPrivate::kInternalFieldCount);
v8::Local<v8::Object> object = function_template->InstanceTemplate()->NewInstance(context).ToLocalChecked();
DCHECK(object->InternalFieldCount() == WrapperPrivate::kInternalFieldCount);
// This |WrapperPrivate|'s lifetime will be managed by V8.
new WrapperPrivate(isolate, wrappable, object);
return entry_scope.Escape(object);
}
v8::Local<v8::FunctionTemplate> V8cAnonymousNamedIndexedGetterInterface::GetTemplate(v8::Isolate* isolate) {
V8cGlobalEnvironment* global_environment = V8cGlobalEnvironment::GetFromIsolate(isolate);
if (!global_environment->HasInterfaceData(kInterfaceUniqueId)) {
InitializeTemplate(isolate);
}
return global_environment->GetInterfaceData(kInterfaceUniqueId);
}
} // namespace testing
} // namespace bindings
} // namespace cobalt