Description[api] Make ObjectTemplate::SetNativeDataProperty() work even if the ObjectTemplate does not have a constructor.
Previously ObjectTemplate::New() logic relied on the fact that all the accessor properties are already installed in the initial map of the function object of the constructor FunctionTemplate.
When the FunctionTemplate were instantiated the accessors of the instance templates from the whole inheritance chain were accumulated and added to the initial map.
ObjectTemplate::SetSetAccessor() used to explicitly ensure that the ObjectTemplate has a constructor and therefore an initial map to add all accessors to.
The new approach is to add all the accessors and data properties to the object exactly when the ObjectTemplate is instantiated. In order to keep it fast we now cache the object boilerplates in the Isolate::template_instantiations_cache (the former function_cache), so the object creation turns to be a deep copying of the boilerplate object.
BUG=chromium:579009
LOG=Y
Committed: https://crrev.com/6a118774244d087b5979e9291d628a994f21d59d
Cr-Commit-Position: refs/heads/master@{#33674}
Committed: https://crrev.com/da213b6e37d5509637490d5a54a1950fab795734
Cr-Commit-Position: refs/heads/master@{#33798}
Patch Set 1 : #
Total comments: 10
Patch Set 2 : Addressing comments #
Total comments: 1
Patch Set 3 : Addressing comments #Patch Set 4 : Fixing browser tests for relanding #Patch Set 5 : Removed asserts preventing JSReceiver properties in ObjectTemplate #
Messages
Total messages: 55 (31 generated)
|