Skip to content

Commit

Permalink
Merge branch 'derivedProperties' of https://github.com/mspertus/jint
Browse files Browse the repository at this point in the history
…into derivedProperties
  • Loading branch information
mspertus committed Sep 23, 2024
2 parents c3ffe05 + bf896e3 commit 8ed364e
Show file tree
Hide file tree
Showing 9 changed files with 231 additions and 124 deletions.
8 changes: 4 additions & 4 deletions Directory.Packages.props
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,17 @@
<PackageVersion Include="Acornima.Extras" Version="1.1.0" />
<PackageVersion Include="BenchmarkDotNet" Version="0.14.0" />
<PackageVersion Include="BenchmarkDotNet.TestAdapter" Version="0.13.12" />
<PackageVersion Include="FluentAssertions" Version="6.12.0" />
<PackageVersion Include="FluentAssertions" Version="6.12.1" />
<PackageVersion Include="Flurl.Http.Signed" Version="4.0.2" />
<PackageVersion Include="Jurassic" Version="3.2.7" />
<PackageVersion Include="Meziantou.Analyzer" Version="2.0.163" />
<PackageVersion Include="Microsoft.Extensions.DependencyInjection" Version="8.0.0" />
<PackageVersion Include="Microsoft.Extensions.TimeProvider.Testing" Version="8.8.0" />
<PackageVersion Include="Microsoft.NET.Test.Sdk" Version="17.11.0" />
<PackageVersion Include="Microsoft.Extensions.TimeProvider.Testing" Version="8.9.1" />
<PackageVersion Include="Microsoft.NET.Test.Sdk" Version="17.11.1" />
<PackageVersion Include="MongoDB.Bson.signed" Version="2.19.0" />
<PackageVersion Include="Newtonsoft.Json" Version="13.0.3" />
<PackageVersion Include="NiL.JS" Version="2.5.1684" />
<PackageVersion Include="NodaTime" Version="3.1.11" />
<PackageVersion Include="NodaTime" Version="3.1.12" />
<PackageVersion Include="NUnit" Version="4.2.2" />
<PackageVersion Include="NUnit3TestAdapter" Version="4.6.0" />
<PackageVersion Include="SharpZipLib" Version="1.4.2" />
Expand Down
51 changes: 0 additions & 51 deletions Jint.Tests.Test262/Test262Harness.settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@
"decorators",
"explicit-resource-management",
"iterator-helpers",
"Math.sumPrecise",
"regexp-lookbehind",
"regexp-modifiers",
"regexp-unicode-property-escapes",
Expand Down Expand Up @@ -74,29 +73,15 @@
"built-ins/Function/prototype/toString/method-computed-property-name.js",
"language/expressions/class/elements/class-name-static-initializer-anonymous.js",

// http://www.ecma-international.org/ecma-262/#sec-block-level-function-declarations-web-legacy-compatibility-semantics not implemented (block level functions)
"language/statements/let/block-local-closure-set-before-initialization.js",

// Windows line ending differences
"built-ins/String/raw/special-characters.js",

// delete/add detection not implemented for map iterator during iteration
"built-ins/Map/prototype/forEach/iterates-values-deleted-then-readded.js",
"built-ins/MapIteratorPrototype/next/iteration-mutable.js",
"built-ins/Set/prototype/forEach/iterates-values-revisits-after-delete-re-add.js",

// Line feed problems (git, windows, linux)
"language/expressions/template-literal/tv-line-terminator-sequence.js",

// 100 fraction digits is not supported due to .NET format specifier limitation
"built-ins/Number/prototype/toFixed/range.js",

// C# can't distinguish 1.797693134862315808e+308 and 1.797693134862315708145274237317e+308
"language/types/number/8.5.1.js",

// generators
"built-ins/GeneratorFunction/instance-yield-expr-in-param.js",
"built-ins/GeneratorFunction/instance-yield-expr-in-param.js",
"built-ins/GeneratorPrototype/next/return-yield-expr.js",
"built-ins/GeneratorPrototype/next/return-yield-expr.js",
"built-ins/GeneratorPrototype/return/try-catch-before-try.js",
Expand Down Expand Up @@ -199,7 +184,6 @@
"language/expressions/assignment/dstr/array-rest-nested-obj-yield-expr.js",
"language/expressions/assignment/dstr/array-rest-yield-expr.js",
"language/expressions/assignment/dstr/array-rest-yield-expr.js",
"language/expressions/assignment/dstr/obj-id-identifier-yield-ident-valid.js",
"language/expressions/assignment/dstr/obj-id-init-yield-expr.js",
"language/expressions/assignment/dstr/obj-id-init-yield-expr.js",
"language/expressions/assignment/dstr/obj-prop-elem-init-yield-expr.js",
Expand Down Expand Up @@ -923,7 +907,6 @@
"language/statements/for-of/dstr/let-ary-ptrn-elem-ary-elision-init.js",
"language/statements/for-of/dstr/let-ary-ptrn-elision.js",
"language/statements/for-of/dstr/let-ary-ptrn-elision.js",
"language/statements/for-of/dstr/obj-id-identifier-yield-ident-valid.js",
"language/statements/for-of/dstr/obj-id-init-yield-expr.js",
"language/statements/for-of/dstr/obj-id-init-yield-expr.js",
"language/statements/for-of/dstr/obj-prop-elem-init-yield-expr.js",
Expand Down Expand Up @@ -1025,8 +1008,6 @@
"language/statements/generators/yield-spread-obj.js",
"language/statements/generators/yield-star-before-newline.js",
"language/statements/generators/yield-star-before-newline.js",
"language/statements/labeled/value-yield-non-strict-escaped.js",
"language/statements/labeled/value-yield-non-strict.js",
"language/statements/let/dstr/ary-ptrn-elem-ary-elision-init.js",
"language/statements/let/dstr/ary-ptrn-elem-ary-elision-init.js",
"language/statements/let/dstr/ary-ptrn-elision.js",
Expand All @@ -1040,9 +1021,6 @@
"language/statements/variable/dstr/ary-ptrn-elision.js",
"language/statements/variable/dstr/ary-ptrn-elision.js",

// SharedArrayBuffer not implemented
"built-ins/SharedArrayBuffer/prototype/prop-desc.js",

// special casing data
"built-ins/**/special_casing*.js",

Expand Down Expand Up @@ -1188,29 +1166,12 @@
"language/eval-code/direct/meth-fn-body-cntns-arguments-var-bind-declare-arguments.js",
"language/eval-code/direct/meth-no-pre-existing-arguments-bindings-are-present-declare-arguments-and-assign.js",
"language/eval-code/direct/meth-no-pre-existing-arguments-bindings-are-present-declare-arguments.js",
"language/eval-code/direct/new.target-fn.js",
"language/eval-code/direct/super-prop-method.js",
"language/eval-code/indirect/always-non-strict.js",
"language/eval-code/indirect/non-definable-global-function.js",
"language/eval-code/indirect/non-definable-global-var.js",
"language/eval-code/indirect/realm.js",
"language/eval-code/indirect/var-env-func-init-global-new.js",
"language/eval-code/indirect/var-env-func-init-global-update-configurable.js",
"language/eval-code/indirect/var-env-func-init-multi.js",
"language/eval-code/indirect/var-env-func-non-strict.js",
"language/eval-code/indirect/var-env-global-lex-non-strict.js",
"language/eval-code/indirect/var-env-var-init-global-exstng.js",
"language/eval-code/indirect/var-env-var-init-global-new.js",
"language/eval-code/indirect/var-env-var-non-strict.js",
"language/expressions/arrow-function/dstr/ary-init-iter-get-err-array-prototype.js",
"language/expressions/arrow-function/dstr/dflt-ary-init-iter-get-err-array-prototype.js",
"language/expressions/arrow-function/eval-var-scope-syntax-err.js",
"language/expressions/arrow-function/scope-param-elem-var-close.js",
"language/expressions/arrow-function/scope-param-elem-var-open.js",
"language/expressions/arrow-function/scope-param-rest-elem-var-close.js",
"language/expressions/arrow-function/scope-param-rest-elem-var-open.js",
"language/expressions/assignment/assignment-operator-calls-putvalue-lref--rval--1.js",
"language/expressions/assignment/assignment-operator-calls-putvalue-lref--rval-.js",
"language/expressions/assignment/dstr/array-elem-put-obj-literal-prop-ref-init-active.js",
"language/expressions/assignment/dstr/array-elem-put-obj-literal-prop-ref-init.js",
"language/expressions/assignment/dstr/obj-prop-elem-target-obj-literal-prop-ref-init-active.js",
Expand All @@ -1228,10 +1189,7 @@
"language/expressions/function/scope-param-rest-elem-var-close.js",
"language/expressions/function/scope-param-rest-elem-var-open.js",
"language/expressions/object/cpn-obj-lit-computed-property-name-from-null.js",
"language/expressions/object/dstr/meth-ary-init-iter-get-err-array-prototype.js",
"language/expressions/object/dstr/meth-dflt-ary-init-iter-get-err-array-prototype.js",
"language/expressions/object/dstr/object-rest-proxy-get-not-called-on-dontenum-keys.js",
"language/expressions/object/dstr/object-rest-proxy-gopd-not-called-on-excluded-keys.js",
"language/expressions/object/method-definition/forbidden-ext/b1/meth-forbidden-ext-direct-access-prop-arguments.js",
"language/expressions/object/method-definition/forbidden-ext/b1/meth-forbidden-ext-direct-access-prop-caller.js",
"language/expressions/object/method-definition/meth-eval-var-scope-syntax-err.js",
Expand All @@ -1241,22 +1199,13 @@
"language/expressions/object/scope-meth-param-rest-elem-var-close.js",
"language/expressions/object/scope-meth-param-rest-elem-var-open.js",
"language/expressions/super/call-proto-not-ctor.js",
"language/expressions/template-literal/tv-line-continuation.js",
"language/function-code/eval-param-env-with-computed-key.js",
"language/function-code/eval-param-env-with-prop-initializer.js",
"language/literals/string/line-separator-eval.js",
"language/literals/string/line-separator.js",
"language/literals/string/paragraph-separator-eval.js",
"language/literals/string/paragraph-separator.js",
"language/statementList/eval-block-with-statment-block.js",
"language/statements/for-of/dstr/array-elem-put-obj-literal-prop-ref-init-active.js",
"language/statements/for-of/dstr/array-elem-put-obj-literal-prop-ref-init.js",
"language/statements/for-of/dstr/obj-id-init-let.js",
"language/statements/for-of/dstr/obj-prop-elem-target-obj-literal-prop-ref-init-active.js",
"language/statements/for-of/dstr/obj-prop-elem-target-obj-literal-prop-ref-init.js",
"language/statements/function/cptn-decl.js",
"language/statements/function/dstr/ary-init-iter-get-err-array-prototype.js",
"language/statements/function/dstr/dflt-ary-init-iter-get-err-array-prototype.js",
"language/statements/function/eval-var-scope-syntax-err.js",
"language/statements/function/S13_A12_T2.js",
"language/statements/function/scope-param-elem-var-close.js",
Expand Down
23 changes: 22 additions & 1 deletion Jint.Tests/Runtime/InteropTests.MemberAccess.cs
Original file line number Diff line number Diff line change
Expand Up @@ -280,4 +280,25 @@ public void CanConfigureStrictAccess()

engine.Invoking(e => e.Evaluate("obj.AgeMissing")).Should().Throw<MissingMemberException>();
}
}

public class ClassWithPropertyToHide
{
public int x { get; set; } = 2;
public int y { get; set; } = 3;
}

public class ClassThatHidesProperty : ClassWithPropertyToHide
{
public new bool x { get; set; } = true;
}

[Fact]
public void ShouldRespectExplicitHiding()
{
var engine = new Engine();

engine.SetValue("obj", new ClassThatHidesProperty());
engine.Evaluate("obj.x").AsBoolean().Should().BeTrue();
engine.Evaluate("obj.y").AsNumber().Should().Be(3);
}
}
2 changes: 1 addition & 1 deletion Jint/Native/Math/MathInstance.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1154,7 +1154,7 @@ private JsValue SumPrecise(JsValue thisObject, JsValue[] arguments)
return state;
}

return sum.FSum();
return Math.SumPrecise.Sum(sum);
}

private static double[] Coerced(JsValue[] arguments)
Expand Down
66 changes: 0 additions & 66 deletions Jint/Native/Math/MathX.cs

This file was deleted.

Loading

0 comments on commit 8ed364e

Please sign in to comment.