Chromium Code Reviews| 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 | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * | 7 * |
| 8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. 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 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
| (...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 88 } | 88 } |
| 89 | 89 |
| 90 void InstallAttributeInternal( | 90 void InstallAttributeInternal( |
| 91 v8::Isolate* isolate, | 91 v8::Isolate* isolate, |
| 92 v8::Local<v8::Object> instance, | 92 v8::Local<v8::Object> instance, |
| 93 v8::Local<v8::Object> prototype, | 93 v8::Local<v8::Object> prototype, |
| 94 const V8DOMConfiguration::AttributeConfiguration& attribute, | 94 const V8DOMConfiguration::AttributeConfiguration& attribute, |
| 95 const DOMWrapperWorld& world) { | 95 const DOMWrapperWorld& world) { |
| 96 if (!WorldConfigurationApplies(attribute, world)) | 96 if (!WorldConfigurationApplies(attribute, world)) |
| 97 return; | 97 return; |
| 98 | |
| 98 v8::Local<v8::Name> name = V8AtomicString(isolate, attribute.name); | 99 v8::Local<v8::Name> name = V8AtomicString(isolate, attribute.name); |
| 100 v8::AccessorNameGetterCallback getter = attribute.getter; | |
| 101 v8::AccessorNameSetterCallback setter = attribute.setter; | |
| 102 v8::Local<v8::Value> data = | |
| 103 v8::External::New(isolate, const_cast<WrapperTypeInfo*>(attribute.data)); | |
| 99 | 104 |
| 100 // This method is only being used for installing interfaces which are | 105 v8::Local<v8::Context> context = isolate->GetCurrentContext(); |
| 101 // enabled through origin trials. Assert here that it is being called with | |
| 102 // an attribute configuration for a constructor. | |
| 103 // TODO(iclelland): Relax this constraint and allow arbitrary data-type | |
| 104 // properties to be added here. | |
| 105 DCHECK_EQ(&V8ConstructorAttributeGetter, attribute.getter); | |
|
haraken
2017/04/13 08:06:09
Can we keep this assert?
This assert is important
peria
2017/04/13 09:51:21
done
| |
| 106 | |
| 107 V8PerContextData* per_context_data = | |
| 108 V8PerContextData::From(isolate->GetCurrentContext()); | |
| 109 v8::Local<v8::Function> data = | |
| 110 per_context_data->ConstructorForType(attribute.data); | |
| 111 | |
| 112 DCHECK(attribute.property_location_configuration); | 106 DCHECK(attribute.property_location_configuration); |
| 113 if (attribute.property_location_configuration & | 107 if (attribute.property_location_configuration & |
| 114 V8DOMConfiguration::kOnInstance) | 108 V8DOMConfiguration::kOnInstance) { |
| 115 instance | 109 DCHECK(instance |
|
bashi
2017/04/13 08:08:36
Why do we need DCHECK()? ToChecked() should crash
peria
2017/04/13 09:51:21
Hmm, I thought returning false can be independent
| |
| 116 ->DefineOwnProperty( | 110 ->SetAccessor( |
| 117 isolate->GetCurrentContext(), name, data, | 111 context, name, getter, setter, data, v8::DEFAULT, |
| 118 static_cast<v8::PropertyAttribute>(attribute.attribute)) | 112 static_cast<v8::PropertyAttribute>(attribute.attribute)) |
| 119 .ToChecked(); | 113 .ToChecked()); |
| 114 } | |
| 120 if (attribute.property_location_configuration & | 115 if (attribute.property_location_configuration & |
| 121 V8DOMConfiguration::kOnPrototype) | 116 V8DOMConfiguration::kOnPrototype) { |
| 122 prototype | 117 DCHECK(prototype |
| 123 ->DefineOwnProperty( | 118 ->SetAccessor( |
| 124 isolate->GetCurrentContext(), name, data, | 119 context, name, getter, setter, data, v8::DEFAULT, |
| 125 static_cast<v8::PropertyAttribute>(attribute.attribute)) | 120 static_cast<v8::PropertyAttribute>(attribute.attribute)) |
| 126 .ToChecked(); | 121 .ToChecked()); |
| 122 } | |
| 127 if (attribute.property_location_configuration & | 123 if (attribute.property_location_configuration & |
| 128 V8DOMConfiguration::kOnInterface) | 124 V8DOMConfiguration::kOnInterface) |
| 129 NOTREACHED(); | 125 NOTREACHED(); |
| 130 } | 126 } |
| 131 | 127 |
| 132 void InstallLazyDataAttributeInternal( | 128 void InstallLazyDataAttributeInternal( |
| 133 v8::Isolate* isolate, | 129 v8::Isolate* isolate, |
| 134 v8::Local<v8::ObjectTemplate> instance_template, | 130 v8::Local<v8::ObjectTemplate> instance_template, |
| 135 v8::Local<v8::ObjectTemplate> prototype_template, | 131 v8::Local<v8::ObjectTemplate> prototype_template, |
| 136 const V8DOMConfiguration::AttributeConfiguration& attribute, | 132 const V8DOMConfiguration::AttributeConfiguration& attribute, |
| (...skipping 565 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 702 v8::Isolate* isolate, | 698 v8::Isolate* isolate, |
| 703 v8::Local<v8::ObjectTemplate> object_template, | 699 v8::Local<v8::ObjectTemplate> object_template, |
| 704 const char* class_string) { | 700 const char* class_string) { |
| 705 object_template->Set( | 701 object_template->Set( |
| 706 v8::Symbol::GetToStringTag(isolate), | 702 v8::Symbol::GetToStringTag(isolate), |
| 707 V8AtomicString(isolate, class_string), | 703 V8AtomicString(isolate, class_string), |
| 708 static_cast<v8::PropertyAttribute>(v8::ReadOnly | v8::DontEnum)); | 704 static_cast<v8::PropertyAttribute>(v8::ReadOnly | v8::DontEnum)); |
| 709 } | 705 } |
| 710 | 706 |
| 711 } // namespace blink | 707 } // namespace blink |
| OLD | NEW |