mirror of
https://github.com/nasa/openmct.git
synced 2025-06-13 12:48:14 +00:00
[Code Style] Use prototypes in framework layer
WTD-1482
This commit is contained in:
@ -39,6 +39,27 @@ define(
|
||||
* @constructor
|
||||
*/
|
||||
function ExtensionResolver(loader, $log) {
|
||||
this.loader = loader;
|
||||
this.$log = $log;
|
||||
}
|
||||
|
||||
/**
|
||||
* Resolve the provided extension; this will give a promise
|
||||
* for the extension's implementation, if one has been
|
||||
* specified, or for the plain definition of the extension
|
||||
* otherwise. The plain definition will also be given
|
||||
* if the implementation fails to load for some reason.
|
||||
*
|
||||
* All key-value pairs from the extension definition
|
||||
* will additionally be attached to any loaded implementation.
|
||||
*
|
||||
* @param {Extension} extension the extension to resolve
|
||||
* @returns {Promise} a promise for the resolved extension
|
||||
*/
|
||||
ExtensionResolver.prototype.resolve = function (extension) {
|
||||
var loader = this.loader,
|
||||
$log = this.$log;
|
||||
|
||||
function loadImplementation(extension) {
|
||||
var implPath = extension.getImplementationPath(),
|
||||
implPromise = loader.load(implPath),
|
||||
@ -57,8 +78,8 @@ define(
|
||||
// loaded implementation.
|
||||
function attachDefinition(impl) {
|
||||
var result = (typeof impl === 'function') ?
|
||||
constructorFor(impl) :
|
||||
Object.create(impl);
|
||||
constructorFor(impl) :
|
||||
Object.create(impl);
|
||||
|
||||
// Copy over static properties
|
||||
Object.keys(impl).forEach(function (k) {
|
||||
@ -84,11 +105,11 @@ define(
|
||||
function handleError(err) {
|
||||
// Build up a log message from parts
|
||||
var message = [
|
||||
"Could not load implementation for extension ",
|
||||
extension.getLogName(),
|
||||
" due to ",
|
||||
err.message
|
||||
].join("");
|
||||
"Could not load implementation for extension ",
|
||||
extension.getLogName(),
|
||||
" due to ",
|
||||
err.message
|
||||
].join("");
|
||||
|
||||
// Log that the extension was not loaded
|
||||
$log.warn(message);
|
||||
@ -107,33 +128,16 @@ define(
|
||||
return implPromise.then(attachDefinition, handleError);
|
||||
}
|
||||
|
||||
return {
|
||||
/**
|
||||
* Resolve the provided extension; this will give a promise
|
||||
* for the extension's implementation, if one has been
|
||||
* specified, or for the plain definition of the extension
|
||||
* otherwise. The plain definition will also be given
|
||||
* if the implementation fails to load for some reason.
|
||||
*
|
||||
* All key-value pairs from the extension definition
|
||||
* will additionally be attached to any loaded implementation.
|
||||
*
|
||||
* @param {Extension} extension
|
||||
* @memberof platform/framework.ExtensionResolver#
|
||||
*/
|
||||
resolve: function (extension) {
|
||||
// Log that loading has begun
|
||||
$log.info([
|
||||
"Resolving extension ",
|
||||
extension.getLogName()
|
||||
].join(""));
|
||||
// Log that loading has begun
|
||||
$log.info([
|
||||
"Resolving extension ",
|
||||
extension.getLogName()
|
||||
].join(""));
|
||||
|
||||
return extension.hasImplementation() ?
|
||||
loadImplementation(extension) :
|
||||
Promise.resolve(extension.getDefinition());
|
||||
}
|
||||
};
|
||||
}
|
||||
return extension.hasImplementation() ?
|
||||
loadImplementation(extension) :
|
||||
Promise.resolve(extension.getDefinition());
|
||||
};
|
||||
|
||||
return ExtensionResolver;
|
||||
}
|
||||
|
Reference in New Issue
Block a user