| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 | 
							- "use strict";
 
- /**
 
-  * Constructor for PushAccumulator. Pushes items onto an array.
 
-  * @class PushAccumulator
 
-  * @namespace mungedb-aggregate.pipeline.accumulators
 
-  * @module mungedb-aggregate
 
-  * @constructor
 
-  **/
 
- var PushAccumulator = module.exports = function PushAccumulator(){
 
- 	this.values = [];
 
- 	base.call(this);
 
- }, klass = PushAccumulator, Accumulator = require("./Accumulator"), base = Accumulator, proto = klass.prototype = Object.create(base.prototype, {constructor:{value:klass}});
 
- // NOTE: Skipping the create function, using the constructor instead
 
- // MEMBER FUNCTIONS
 
- proto.getValue = function getValue(toBeMerged){
 
- 	return this.values;
 
- };
 
- proto.getOpName = function getOpName(){
 
- 	return "$push";
 
- };
 
- proto.getFactory = function getFactory(){
 
- 	return klass;	// using the ctor rather than a separate .create() method
 
- };
 
- proto.processInternal = function processInternal(input, merging) {
 
- 	if (!merging) {
 
- 		if (input !== undefined) {
 
- 			this.values.push(input);
 
- 			//_memUsageBytes += input.getApproximateSize();
 
- 		}
 
- 	}
 
- 	else {
 
- 		// If we're merging, we need to take apart the arrays we
 
- 		// receive and put their elements into the array we are collecting.
 
- 		// If we didn't, then we'd get an array of arrays, with one array
 
- 		// from each merge source.
 
- 		if (!(input instanceof Array)) throw new Error("input is not an Array during merge in PushAccumulator:35");
 
- 		this.values = this.values.concat(input);
 
- 		//for (size_t i=0; i < vec.size(); i++) {
 
- 			//_memUsageBytes += vec[i].getApproximateSize();
 
- 		//}
 
- 	}
 
- };
 
 
  |