From 0ab5778c3ebda96e739396886a37aa221e2ef999 Mon Sep 17 00:00:00 2001 From: Daniel Ehrenberg Date: Fri, 31 May 2019 18:51:09 +0200 Subject: [PATCH] Normative: Fix state checking in async cycle case If a cycle contains async modules, then its statuses will not be set to "evaluating-async" until after the cycle is traversed. This could cause errors in setting up the async dependency graph edges. This PR uses different checks to avoid the issue. Fixes #89 --- spec.html | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/spec.html b/spec.html index b1825cf..d58c7fe 100644 --- a/spec.html +++ b/spec.html @@ -470,6 +470,7 @@

InnerModuleEvaluation( _module_, _stack_, _index_ )

1. For each String _required_ that is an element of _module_.[[RequestedModules]], do 1. Let _requiredModule_ be ! HostResolveImportedModule(_module_, _required_). 1. NOTE: Instantiate must be completed successfully prior to invoking this method, so every requested module is guaranteed to resolve successfully. + 1. Let _cycle_ be *true* if _requiredModule_.[[Status]] is `"evaluating"`, and *false* otherwise. 1. Set _index_ to ? InnerModuleEvaluation(_requiredModule_, _stack_, _index_). 1. If _requiredModule_ is a Cyclic Module Record, then 1. Assert: _requiredModule_.[[Status]] is either `"evaluating"`, `"evaluating-async"` or `"evaluated"`. @@ -478,9 +479,10 @@

InnerModuleEvaluation( _module_, _stack_, _index_ )

1. Set _module_.[[DFSAncestorIndex]] to min(_module_.[[DFSAncestorIndex]], _requiredModule_.[[DFSAncestorIndex]]). 1. Otherwise, set _requiredModule_ to GetCycleRoot(_requiredModule_). 1. If _requiredModule_.[[EvaluationError]] is not *undefined*, return _module_.[[EvaluationError]]. - 1. If _requiredModule_.[[Status]] is `"evaluating-async"`, then - 1. Set _module_.[[PendingAsyncDependencies]] to _module_.[[PendingAsyncDependencies]] + 1. - 1. Append _module_ to _requiredModule_.[[AsyncParentModules]]. + 1. If _cycle_ is *false*, + 1. If either _requiredModule_.[[Async]] is *true*, or _requiredModule_.[[PendingAsyncDependencies]] is not 0, then + 1. Set _module_.[[PendingAsyncDependencies]] to _module_.[[PendingAsyncDependencies]] + 1. + 1. Append _module_ to _requiredModule_.[[AsyncParentModules]]. 1. Perform ? _module_.ExecuteModule(). 1. If _module_.[[PendingAsyncDependencies]] is 0, then 1. Perform ! ExecuteCyclicModule(_module_).