merged rmcouchdb

This commit is contained in:
Max Thayer 2013-09-08 22:11:23 -04:00
commit 36abc1ad4e
2 changed files with 37 additions and 27 deletions

View File

@ -70,8 +70,7 @@ possible to write in your configuration file:
}); });
Note, however, that if you call 'rmcouchdb' without a sub-argument, in Note that if you call `rmcouchdb` without a sub-argument, it will not delete any databases.
keeping with grunt's standards, it will drop *all* of your databases!
## Demo ## Demo

View File

@ -67,21 +67,26 @@ module.exports = function(grunt) {
db = genDB(this.data.db); db = genDB(this.data.db);
try { try {
nano = require('nano')(db.url); nano = require('nano')(db.url);
nano.db.destroy(db.name, function(err) { if (db.name) {
if (err) { nano.db.destroy(db.name, function(err) {
if (err.status_code && err.status_code === 404) { if (err) {
if (_this.data.options && _this.data.options.okay_if_missing) { if (err.status_code && err.status_code === 404) {
grunt.log.writeln("Database " + dbname + " not present... skipping."); if (_this.data.options && _this.data.options.okay_if_missing) {
return done(null, null) ; grunt.log.writeln("Database " + db.name + " not present... skipping.");
return done(null, null) ;
} else {
grunt.warn("Database " + db.name + " does not exist.");
}
} else { } else {
grunt.warn("Database " + dbname + " does not exist."); grunt.warn(err);
} }
} else {
grunt.warn(err);
} }
} return done(err, null);
return done(err, null); });
}); } else {
grunt.log.writeln("No database specified... skipping.");
return done(null, null);
}
} catch (e) { } catch (e) {
grunt.warn(e); grunt.warn(e);
done(e, null); done(e, null);
@ -96,20 +101,26 @@ module.exports = function(grunt) {
parts = urls.parse(this.data.db); parts = urls.parse(this.data.db);
db = genDB(this.data.db); db = genDB(this.data.db);
try { try {
nano = require('nano')(db.url); if (db.name) {
nano.db.create(db.name, function(err) { nano = require('nano')(db.url);
if (_this.data.options && _this.data.options.okay_if_exists) { nano.db.create(db.name, function(err) {
if (err){ if (_this.data.options && _this.data.options.okay_if_exists) {
grunt.log.writeln("Database " + dbname + " exists, skipping"); if (err){
grunt.log.writeln("Database " + db.name + " exists, skipping");
}
return done(null, null);
} else {
if (err){
grunt.warn(err);
}
return done(err, null);
} }
return done(null, null); });
} else { } else {
if (err){ var err_msg = "No database specified to create!";
grunt.warn(err); grunt.warn(err_msg);
} return done(new Error(err_msg), null);
return done(err, null); }
}
});
} catch (e) { } catch (e) {
grunt.warn(e); grunt.warn(e);
done(e, null); done(e, null);