// |reftest| shell-option(--enable-explicit-resource-management) skip-if(!(this.hasOwnProperty('getBuildConfiguration')&&getBuildConfiguration('explicit-resource-management'))||!xulRuntime.shell) -- explicit-resource-management is not enabled unconditionally, requires shell-options // Copyright (C) 2023 Ron Buckton. All rights reserved. // This code is governed by the BSD license found in the LICENSE file. /*--- esid: sec-runtime-semantics-evaluatefunctionbody description: Initialized value is disposed at end of FunctionBody info: | FunctionBody : FunctionStatementList ... 3. Let result be Completion(Evaluation of FunctionStatementList). 4. Let env be the running execution context's LexicalEnvironment. 5. Return ? DisposeResources(env.[[DisposeCapability]], result). DisposeResources ( disposeCapability, completion ) 1. For each resource of disposeCapability.[[DisposableResourceStack]], in reverse list order, do a. Let result be Dispose(resource.[[ResourceValue]], resource.[[Hint]], resource.[[DisposeMethod]]). b. If result.[[Type]] is throw, then i. If completion.[[Type]] is throw, then 1. Set result to result.[[Value]]. 2. Let suppressed be completion.[[Value]]. 3. Let error be a newly created SuppressedError object. 4. Perform ! CreateNonEnumerableDataPropertyOrThrow(error, "error", result). 5. Perform ! CreateNonEnumerableDataPropertyOrThrow(error, "suppressed", suppressed). 6. Set completion to ThrowCompletion(error). ii. Else, 1. Set completion to result. 2. Return completion. Dispose ( V, hint, method ) 1. If method is undefined, let result be undefined. 2. Else, let result be ? Call(method, V). 3. If hint is async-dispose, then a. ... 4. Return undefined. features: [explicit-resource-management] ---*/ var resource = { disposed: false, [Symbol.dispose]() { this.disposed = true; } }; function f() { using _ = resource; } f(); assert.sameValue(resource.disposed, true, 'Expected resource to have been disposed'); reportCompare(0, 0);