v8
3.11.10(node0.8.26)
V8 is Google's open source JavaScript engine
|
#include <v8.h>
Static Public Member Functions | |
static Local< ObjectTemplate > | New () |
Friends | |
class | FunctionTemplate |
An ObjectTemplate is used to create objects at runtime.
Properties added to an ObjectTemplate are added to each object created from the ObjectTemplate.
int InternalFieldCount | ( | ) |
Gets the number of internal fields for objects generated from this template.
Definition at line 1422 of file api.cc.
References Smi::cast(), Utils::OpenHandle(), and Smi::value().
void MarkAsUndetectable | ( | ) |
Mark object instances of the template as undetectable.
In many ways, undetectable objects behave as though they are not there. They behave like 'undefined' in conditionals and when printed. However, properties can be accessed and called as on normal objects.
Definition at line 1334 of file api.cc.
References FunctionTemplateInfo::cast(), ENTER_V8, and Utils::OpenHandle().
|
static |
Creates an ObjectTemplate.
Definition at line 1246 of file api.cc.
Referenced by CreateGlobalTemplate(), CreateShellContext(), FunctionTemplate::InstanceTemplate(), Context::New(), FunctionTemplate::PrototypeTemplate(), RunMain(), TEST(), and THREADED_TEST().
Local< v8::Object > NewInstance | ( | ) |
Creates a new instance of this template.
Definition at line 4536 of file api.cc.
References ENTER_V8, EXCEPTION_BAILOUT_CHECK, EXCEPTION_PREAMBLE, Execution::InstantiateObject(), LOG_API, ON_BAILOUT, Utils::OpenHandle(), and Utils::ToLocal().
Referenced by TEST(), and THREADED_TEST().
void SetAccessCheckCallbacks | ( | NamedSecurityCallback | named_handler, |
IndexedSecurityCallback | indexed_handler, | ||
Handle< Value > | data = Handle<Value>() , |
||
bool | turned_on_by_default = true |
||
) |
Sets access check callbacks on the object template.
When accessing properties on instances of this object template, the access check callback will be called to determine whether or not to allow cross-context access to the properties. The last parameter specifies whether access checks are turned on by default on instances. If access checks are off by default, they can be turned on on individual instances by calling Object::TurnOnAccessCheck().
Definition at line 1347 of file api.cc.
References v8::internal::ACCESS_CHECK_INFO_TYPE, Handle< T >::cast(), FunctionTemplateInfo::cast(), ENTER_V8, Isolate::factory(), Handle< T >::IsEmpty(), Factory::NewStruct(), Utils::OpenHandle(), SET_FIELD_WRAPPED, and v8::Undefined().
Referenced by TEST(), and THREADED_TEST().
void SetAccessor | ( | v8::Handle< String > | name, |
AccessorGetter | getter, | ||
AccessorSetter | setter = 0 , |
||
v8::Handle< Value > | data = Handle<Value>() , |
||
AccessControl | settings = DEFAULT , |
||
PropertyAttribute | attribute = None , |
||
v8::Handle< AccessorSignature > | signature = Handle<AccessorSignature>() |
||
) |
Sets an accessor on the object template.
Whenever the property with the given name is accessed on objects created from this ObjectTemplate the getter and setter callbacks are called instead of getting and setting the property directly on the JavaScript object.
name | The name of the property for which an accessor is added. |
getter | The callback to invoke when getting the property. |
setter | The callback to invoke when setting the property. |
data | A piece of data that will be passed to the getter and setter callbacks whenever they are invoked. |
settings | Access control settings for the accessor. This is a bit field consisting of one of more of DEFAULT = 0, ALL_CAN_READ = 1, or ALL_CAN_WRITE = 2. The default is to not allow cross-context access. ALL_CAN_READ means that all cross-context reads are allowed. ALL_CAN_WRITE means that all cross-context writes are allowed. The combination ALL_CAN_READ | ALL_CAN_WRITE can be used to allow all cross-context access. |
attribute | The attributes of the property for which an accessor is added. |
signature | The signature describes valid receivers for the accessor and is used to perform implicit instance checks against them. If the receiver is incompatible (i.e. is not an instance of the constructor as defined by FunctionTemplate::HasInstance()), an implicit TypeError is thrown and no callback is invoked. |
Definition at line 1284 of file api.cc.
References FunctionTemplateInfo::cast(), ENTER_V8, Utils::OpenHandle(), and Utils::ToLocal().
Referenced by TEST(), and THREADED_TEST().
void SetCallAsFunctionHandler | ( | InvocationCallback | callback, |
Handle< Value > | data = Handle<Value>() |
||
) |
Sets the callback to be used when calling instances created from this template as a function. If no callback is set, instances behave like normal JavaScript objects that cannot be called as a function.
Definition at line 1405 of file api.cc.
References FunctionTemplateInfo::cast(), ENTER_V8, Utils::OpenHandle(), and Utils::ToLocal().
void SetIndexedPropertyHandler | ( | IndexedPropertyGetter | getter, |
IndexedPropertySetter | setter = 0 , |
||
IndexedPropertyQuery | query = 0 , |
||
IndexedPropertyDeleter | deleter = 0 , |
||
IndexedPropertyEnumerator | enumerator = 0 , |
||
Handle< Value > | data = Handle<Value>() |
||
) |
Sets an indexed property handler on the object template.
Whenever an indexed property is accessed on objects created from this object template, the provided callback is invoked instead of accessing the property directly on the JavaScript object.
getter | The callback to invoke when getting a property. |
setter | The callback to invoke when setting a property. |
query | The callback to invoke to check if an object has a property. |
deleter | The callback to invoke when deleting a property. |
enumerator | The callback to invoke to enumerate all the indexed properties of an object. |
data | A piece of data that will be passed to the callbacks whenever they are invoked. |
Definition at line 1379 of file api.cc.
References FunctionTemplateInfo::cast(), ENTER_V8, Utils::OpenHandle(), and Utils::ToLocal().
Referenced by THREADED_TEST().
void SetInternalFieldCount | ( | int | value | ) |
Sets the number of internal fields for objects generated from this template.
Definition at line 1431 of file api.cc.
References ENTER_V8, Smi::FromInt(), Smi::IsValid(), and Utils::OpenHandle().
Referenced by TEST(), and THREADED_TEST().
void SetNamedPropertyHandler | ( | NamedPropertyGetter | getter, |
NamedPropertySetter | setter = 0 , |
||
NamedPropertyQuery | query = 0 , |
||
NamedPropertyDeleter | deleter = 0 , |
||
NamedPropertyEnumerator | enumerator = 0 , |
||
Handle< Value > | data = Handle<Value>() |
||
) |
Sets a named property handler on the object template.
Whenever a named property is accessed on objects created from this object template, the provided callback is invoked instead of accessing the property directly on the JavaScript object.
getter | The callback to invoke when getting a property. |
setter | The callback to invoke when setting a property. |
query | The callback to invoke to check if a property is present, and if present, get its attributes. |
deleter | The callback to invoke when deleting a property. |
enumerator | The callback to invoke to enumerate all the named properties of an object. |
data | A piece of data that will be passed to the callbacks whenever they are invoked. |
Definition at line 1309 of file api.cc.
References FunctionTemplateInfo::cast(), ENTER_V8, Utils::OpenHandle(), and Utils::ToLocal().
Referenced by TEST(), and THREADED_TEST().
|
friend |