Brunet.Services.MapReduce.MapReduceListConcat.Reduce C# (CSharp) Method

Reduce() public method

public Reduce ( Channel q, object reduce_arg, object current_val, RpcResult child_r ) : void
q Brunet.Concurrent.Channel
reduce_arg object
current_val object
child_r Brunet.Messaging.RpcResult
return void
    public override void Reduce(Channel q, object reduce_arg, object current_val, RpcResult child_r) {
      var rest = child_r.Result as IEnumerable;
      //If we get here, the child didn't throw an exception
      var result = new ArrayList();
      AddEnum(result, current_val as IEnumerable);
      AddEnum(result, rest);
      q.Enqueue(new Pair<object, bool>(result, false));
    }
    protected static void AddEnum(IList into, IEnumerable source) {