ModExpression.js 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. "use strict";
  2. /**
  3. * An $mod pipeline expression.
  4. * @see evaluate
  5. * @class ModExpression
  6. * @extends mungedb-aggregate.pipeline.expressions.FixedArityExpressionT
  7. * @namespace mungedb-aggregate.pipeline.expressions
  8. * @module mungedb-aggregate
  9. * @constructor
  10. */
  11. var ModExpression = module.exports = function ModExpression() {
  12. if (arguments.length !== 0) throw new Error(klass.name + ": no args expected");
  13. base.call(this);
  14. }, klass = ModExpression, base = require("./FixedArityExpressionT")(ModExpression, 2), proto = klass.prototype = Object.create(base.prototype, {constructor:{value:klass}});
  15. var Value = require("../Value"),
  16. Expression = require("./Expression");
  17. proto.evaluateInternal = function evaluateInternal(vars) {
  18. var lhs = this.operands[0].evaluateInternal(vars),
  19. rhs = this.operands[1].evaluateInternal(vars);
  20. var leftType = Value.getType(lhs),
  21. rightType = Value.getType(rhs);
  22. if (typeof lhs === "number" && typeof rhs === "number") {
  23. // ensure we aren't modding by 0
  24. if(rhs === 0) throw new Error("can't $mod by 0; uassert code 16610");
  25. return lhs % rhs;
  26. } else if (lhs === undefined || lhs === null || rhs === undefined || rhs === null) {
  27. return null;
  28. } else {
  29. throw new Error("$mod only supports numeric types, not " + Value.getType(lhs) + " and " + Value.getType(rhs));
  30. }
  31. };
  32. Expression.registerExpression("$mod", base.parse);
  33. proto.getOpName = function getOpName() {
  34. return "$mod";
  35. };