public interface ModuleSourceProvider
| Modifier and Type | Field and Description |
|---|---|
static ModuleSource |
NOT_MODIFIED
A special return value for
loadSource(String, Scriptable, Object) and loadSource(URI, URI, Object) that signifies that the cached representation is still valid
according to the passed validator. |
| Modifier and Type | Method and Description |
|---|---|
ModuleSource |
loadSource(java.lang.String moduleId,
Scriptable paths,
java.lang.Object validator)
Returns the script source of the requested module.
|
ModuleSource |
loadSource(java.net.URI uri,
java.net.URI baseUri,
java.lang.Object validator)
Returns the script source of the requested module from the given URI.
|
static final ModuleSource NOT_MODIFIED
loadSource(String, Scriptable, Object) and loadSource(URI, URI, Object) that signifies that the cached representation is still valid
according to the passed validator.ModuleSource loadSource(java.lang.String moduleId, Scriptable paths, java.lang.Object validator) throws java.io.IOException, java.net.URISyntaxException
NOT_MODIFIED should be returned. Otherwise,
it should return a ModuleSource object with the actual source text of the module,
preferrably a validator for it, and a security domain, where applicable.moduleId - the ID of the module. An implementation must only accept an absolute ID,
starting with a term.paths - the value of the require() function's "paths" attribute. If the require()
function is sandboxed, it will be null, otherwise it will be a JavaScript Array object.
It is up to the provider implementation whether and how it wants to honor the contents of
the array.validator - a validator for an existing loaded and cached module. This will either be
null, or an object that this source provider returned earlier as part of a ModuleSource. It can be used to validate the existing cached module and avoid reloading
it.NOT_MODIFIED should be returned if the passed validator validates
the current representation of the module (the currently cached module script).java.io.IOException - if there was an I/O problem reading the scriptjava.net.URISyntaxException - if the final URI could not be constructed.java.lang.IllegalArgumentException - if the module ID is syntactically not a valid absolute
module identifier.ModuleSource loadSource(java.net.URI uri, java.net.URI baseUri, java.lang.Object validator) throws java.io.IOException, java.net.URISyntaxException
If the resource is not found, null is returned. If the caller passes a non-null validator,
and the source provider recognizes it, and the validator applies to the same resource that
the provider would use to load the source, and the validator validates the current cached
representation of the resource (using whatever semantics for validation that this source
provider implements), then NOT_MODIFIED should be returned. Otherwise, it should
return a ModuleSource object with the actual source text of the module, preferrably a
validator for it, and a security domain, where applicable.
uri - the absolute URI from which to load the module source, but without an extension
such as ".js".baseUri - the module path base URI from which uri was derived.validator - a validator for an existing loaded and cached module. This will either be
null, or an object that this source provider returned earlier as part of a ModuleSource. It can be used to validate the existing cached module and avoid reloading
it.NOT_MODIFIED should be returned if the passed validator validates
the current representation of the module (the currently cached module script).java.io.IOException - if there was an I/O problem reading the scriptjava.net.URISyntaxException - if the final URI could not be constructed