This is a proposal for the inclusion of an additional primordial variable to all ECMAScript contexts.
- There MUST be a primordial function
Module(text, fileName, lineNo)
text
MUST be parsed the body of a strict-mode FunctionModule
MAY throw aSyntaxError
fileName
is an optional name for the text, for debuggerslineNo
defaults to 1, is coerced toNumber
internally, and represents the line number corresponding to the beginning of the text within the file indicated byfileName
Module
MAY be called as a constructor or as a function. Its behavior must be identical in either case.Module
returns aFunction
(for illustration:module(scope)
)scope
is internally coerced to anObject
- when module is called
- the function described in
text
is run in a lexical scope that contains- the primordials (Non normatively, these include
Array
andObject
but not legacy, embedding-specific values likewindow
; a citation to a comprehensive list in the specification is needed here) - preceding the primordials, a variable corresponding to each owned property of
scope
- such that any free variable in
text
that is neither mentioned in thescope
object or is a primordial throws aReferenceError
at the point it is used.
- the primordials (Non normatively, these include
- the module returns the value returned by the function
- the function described in
- the
Module
instance MUST own arequirements
propertyrequirements
are anArray
requirements
must contain the string corresponding to each occurrence of the free variablerequire
that exists intext
in whichrequire
is called as a function with theString
as its argument
- the
Module
instance MUST own thefileName
property corresponding to thefileName
given to theModule
constructor. - the
Module
instance MUST own thelineNo
property corresponding to thelineNo
given to theModule
constructor.
Ihab, in response to (4), yes, it would be too narrow a constraint for require calls to be limited to some pattern in the header of the code; it would add too much complexity for us meager developers who have the right to assume require calls will work just about anywhere. I trust that there are enough short-circuits implied by the requirements search that it would not significantly affect performance to collect a list of strings in an existing visit of the token stream. The search need not be performed unless the parse is run in conjunction with a Module constructor. The entire search can be aborted in a lexical context in which require is no longer a free variable. And so on.