Remove assertIsModel and isDataSource

Use `instanceof` operator instead:

  ModelCtor.prototype instanceof loopback.Model
  dataSource instanceof loopback.DataSource
This commit is contained in:
Miroslav Bajtoš 2014-06-06 10:30:03 +02:00
parent fc0fad4a9f
commit 19425b8fd9
1 changed files with 5 additions and 15 deletions

View File

@ -141,7 +141,8 @@ app.model = function (Model, config) {
configureModel(Model, config, this); configureModel(Model, config, this);
isPublic = config.public !== false; isPublic = config.public !== false;
} else { } else {
assertIsModel(Model); assert(Model.prototype instanceof loopback.Model,
'Model must be a descendant of loopback.Model');
} }
var modelName = Model.modelName; var modelName = Model.modelName;
@ -163,14 +164,6 @@ app.model = function (Model, config) {
return Model; return Model;
}; };
function assertIsModel(Model) {
assert(typeof Model === 'function',
'Model must be a function / constructor');
assert(Model.modelName, 'Model must have a "modelName" property');
assert(Model.prototype instanceof loopback.Model,
'Model must be a descendant of loopback.Model');
}
/** /**
* Get the models exported by the app. Returns only models defined using `app.model()` * Get the models exported by the app. Returns only models defined using `app.model()`
* *
@ -605,7 +598,8 @@ function dataSourcesFromConfig(config, connectorRegistry) {
} }
function configureModel(ModelCtor, config, app) { function configureModel(ModelCtor, config, app) {
assertIsModel(ModelCtor); assert(ModelCtor.prototype instanceof loopback.Model,
'Model must be a descendant of loopback.Model');
var dataSource = config.dataSource; var dataSource = config.dataSource;
@ -613,7 +607,7 @@ function configureModel(ModelCtor, config, app) {
dataSource = app.dataSources[dataSource]; dataSource = app.dataSources[dataSource];
} }
assert(isDataSource(dataSource), assert(dataSource instanceof DataSource,
ModelCtor.modelName + ' is referencing a dataSource that does not exist: "' + ModelCtor.modelName + ' is referencing a dataSource that does not exist: "' +
config.dataSource +'"'); config.dataSource +'"');
@ -692,10 +686,6 @@ function tryReadDir() {
} }
} }
function isDataSource(obj) {
return obj instanceof DataSource;
}
function tryReadConfig(cwd, fileName) { function tryReadConfig(cwd, fileName) {
try { try {
return require(path.join(cwd, fileName + '.json')); return require(path.join(cwd, fileName + '.json'));