aboutsummaryrefslogtreecommitdiff
path: root/third_party/hadoop-0.20.0/c++/Linux-amd64-64/include/hadoop/TemplateFactory.hh
blob: 22e10ae56fb03117cd8de803106199037cf60a9a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/**
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
#ifndef HADOOP_PIPES_TEMPLATE_FACTORY_HH
#define HADOOP_PIPES_TEMPLATE_FACTORY_HH

namespace HadoopPipes {

  template <class mapper, class reducer>
  class TemplateFactory2: public Factory {
  public:
    Mapper* createMapper(MapContext& context) const {
      return new mapper(context);
    }
    Reducer* createReducer(ReduceContext& context) const {
      return new reducer(context);
    }
  };

  template <class mapper, class reducer, class partitioner>
  class TemplateFactory3: public TemplateFactory2<mapper,reducer> {
  public:
    Partitioner* createPartitioner(MapContext& context) const {
      return new partitioner(context);
    }
  };

  template <class mapper, class reducer>
  class TemplateFactory3<mapper, reducer, void>
      : public TemplateFactory2<mapper,reducer> {
  };

  template <class mapper, class reducer, class partitioner, class combiner>
  class TemplateFactory4
   : public TemplateFactory3<mapper,reducer,partitioner>{
  public:
    Reducer* createCombiner(MapContext& context) const {
      return new combiner(context);
    }
  };

  template <class mapper, class reducer, class partitioner>
  class TemplateFactory4<mapper,reducer,partitioner,void>
   : public TemplateFactory3<mapper,reducer,partitioner>{
  };

  template <class mapper, class reducer, class partitioner, 
            class combiner, class recordReader>
  class TemplateFactory5
   : public TemplateFactory4<mapper,reducer,partitioner,combiner>{
  public:
    RecordReader* createRecordReader(MapContext& context) const {
      return new recordReader(context);
    }
  };

  template <class mapper, class reducer, class partitioner,class combiner>
  class TemplateFactory5<mapper,reducer,partitioner,combiner,void>
   : public TemplateFactory4<mapper,reducer,partitioner,combiner>{
  };

  template <class mapper, class reducer, class partitioner=void, 
            class combiner=void, class recordReader=void, 
            class recordWriter=void> 
  class TemplateFactory
   : public TemplateFactory5<mapper,reducer,partitioner,combiner,recordReader>{
  public:
    RecordWriter* createRecordWriter(ReduceContext& context) const {
      return new recordWriter(context);
    }
  };

  template <class mapper, class reducer, class partitioner, 
            class combiner, class recordReader>
  class TemplateFactory<mapper, reducer, partitioner, combiner, recordReader, 
                        void>
   : public TemplateFactory5<mapper,reducer,partitioner,combiner,recordReader>{
  };

}

#endif