knex/lib/helpers.js
2014-02-21 17:16:11 -05:00

137 lines
3.5 KiB
JavaScript

// Helpers
// -------
// Just some common functions needed in multiple places within the library.
var _ = require('lodash');
var Raw = require('./raw');
var Helpers = module.exports = {
// Pick off the attributes from only the current layer of the object.
skim: function(data) {
return _.map(data, function(obj) {
return _.pick(obj, _.keys(obj));
});
},
// The function name says it all.
capitalize: function(word) {
return word.charAt(0).toUpperCase() + word.slice(1);
},
// Sorts an object based on the names.
sortObject: function(obj) {
return _.sortBy(_.pairs(obj), function(a) {
return a[0];
});
},
// The `format` function is borrowed from the Node.js `utils` module,
// since we want to be able to have this functionality on the
// frontend as well.
format: function(f) {
var i;
if (!_.isString(f)) {
var objects = [];
for (i = 0; i < arguments.length; i++) {
objects.push(inspect(arguments[i]));
}
return objects.join(' ');
}
i = 1;
var args = arguments;
var len = args.length;
var str = String(f).replace(formatRegExp, function(x) {
if (x === '%%') return '%';
if (i >= len) return x;
switch (x) {
case '%s': return String(args[i++]);
case '%d': return Number(args[i++]);
case '%j':
try {
return JSON.stringify(args[i++]);
} catch (_) {
return '[Circular]';
}
break;
default:
return x;
}
});
for (var x = args[i]; i < len; x = args[++i]) {
if (_.isNull(x) || !_.isObject(x)) {
str += ' ' + x;
} else {
str += ' ' + inspect(x);
}
}
return str;
},
// Create a non-leaking copy of "arguments".
args: function() {
var args = new Array(arguments.length);
for (var i = 0; i < args.length; i++) {
args[i] = arguments[i];
}
return args;
},
// Check if the first argument is an array, otherwise
// uses all arguments as an array.
normalizeArr: function() {
var args = Helpers.args.apply(null, arguments);
if (_.isArray(args[0])) {
return args[0];
}
return args;
},
// Used to deprecate functionality.
deprecate: function(msg) {
if (typeof console !== "undefined" && console !== null &&
typeof console.warn === "function") {
console.warn("Knex: " + msg);
}
},
// Used to wrap the statements which have schema bindings,
// and then put them on the correct query builder statement.
bindings: function(fn) {
return function() {
var binding = this.binding;
var currentlyBound = this.binding = [];
var statement = fn.apply(this, arguments);
if (statement) {
statement.bindings = currentlyBound;
this.statements.push(statement);
}
this.binding = binding;
return this;
};
},
// Used to ensure there's only one of a specific statement
// in the current query chain.
single: function(fn) {
return function() {
var binding = this.binding;
var currentlyBound = this.binding = [];
var newStatement = fn.apply(this, arguments);
if (newStatement) {
this.statements = _.filter(this.statements, function(statement) {
return (statement.type !== newStatement.type);
});
newStatement.bindings = currentlyBound;
this.statements.push(newStatement);
}
this.binding = binding;
return this;
};
}
};
// Regex used in the `Helpers.format` function.
var formatRegExp = /%[sdj%]/g;