123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- using System;
- using System.Linq;
- using Jint.Native;
- using Jint.Native.Object;
- using Jint.Runtime.Descriptors;
- namespace Jint.Runtime.Environments
- {
- /// <summary>
- /// Represents an object environment record
- /// http://www.ecma-international.org/ecma-262/5.1/#sec-10.2.1.2
- /// </summary>
- public sealed class ObjectEnvironmentRecord : EnvironmentRecord
- {
- private readonly ObjectInstance _bindingObject;
- private readonly bool _provideThis;
- public ObjectEnvironmentRecord(Engine engine, ObjectInstance bindingObject, bool provideThis) : base(engine)
- {
- _bindingObject = bindingObject;
- _provideThis = provideThis;
- }
- public override bool HasBinding(in Key name)
- {
- return _bindingObject.HasProperty(name);
- }
- internal override bool TryGetBinding(
- in Key name,
- bool strict,
- out Binding binding,
- out JsValue value)
- {
- // we unwrap by name
- binding = default;
- if (!_bindingObject.HasProperty(name))
- {
- value = default;
- return false;
- }
- var desc = _bindingObject.GetProperty(name);
- value = ObjectInstance.UnwrapJsValue(desc, this);
- return true;
- }
- /// <summary>
- /// http://www.ecma-international.org/ecma-262/5.1/#sec-10.2.1.2.2
- /// </summary>
- public override void CreateMutableBinding(in Key name, JsValue value, bool configurable = true)
- {
- var propertyDescriptor = configurable
- ? new PropertyDescriptor(value, PropertyFlag.ConfigurableEnumerableWritable)
- : new PropertyDescriptor(value, PropertyFlag.NonConfigurable);
- _bindingObject.DefinePropertyOrThrow(name, propertyDescriptor);
- }
- public override void SetMutableBinding(in Key name, JsValue value, bool strict)
- {
- if (!_bindingObject.Set(name, value) && strict)
- {
- ExceptionHelper.ThrowTypeError(_engine);
- }
- }
- public override JsValue GetBindingValue(in Key name, bool strict)
- {
- var desc = _bindingObject.GetProperty(name);
- if (strict && desc == PropertyDescriptor.Undefined)
- {
- ExceptionHelper.ThrowReferenceError(_engine, name);
- }
- return ObjectInstance.UnwrapJsValue(desc, this);
- }
- public override bool DeleteBinding(in Key name)
- {
- return _bindingObject.Delete(name);
- }
- public override JsValue ImplicitThisValue()
- {
- if (_provideThis)
- {
- return _bindingObject;
- }
- return Undefined;
- }
- public override Key[] GetAllBindingNames()
- {
- if (!ReferenceEquals(_bindingObject, null))
- {
- return _bindingObject.GetOwnProperties().Select( x=> x.Key).ToArray();
- }
- return ArrayExt.Empty<Key>();
- }
- public override bool Equals(JsValue other)
- {
- return ReferenceEquals(_bindingObject, other);
- }
- internal override void FunctionWasCalled()
- {
- }
- }
- }
|