001/**
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements.  See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership.  The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License.  You may obtain a copy of the License at
009 *
010 *     http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software
013 * distributed under the License is distributed on an "AS IS" BASIS,
014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
015 * See the License for the specific language governing permissions and
016 * limitations under the License.
017 */
018
019package org.apache.hadoop.mapreduce.lib.map;
020
021import java.io.IOException;
022import java.net.URI;
023
024import org.apache.hadoop.classification.InterfaceAudience;
025import org.apache.hadoop.classification.InterfaceStability;
026import org.apache.hadoop.conf.Configuration;
027import org.apache.hadoop.conf.Configuration.IntegerRanges;
028import org.apache.hadoop.fs.Path;
029import org.apache.hadoop.io.RawComparator;
030import org.apache.hadoop.mapreduce.Counter;
031import org.apache.hadoop.mapreduce.InputFormat;
032import org.apache.hadoop.mapreduce.InputSplit;
033import org.apache.hadoop.mapreduce.JobID;
034import org.apache.hadoop.mapreduce.MapContext;
035import org.apache.hadoop.mapreduce.Mapper;
036import org.apache.hadoop.mapreduce.OutputCommitter;
037import org.apache.hadoop.mapreduce.OutputFormat;
038import org.apache.hadoop.mapreduce.Partitioner;
039import org.apache.hadoop.mapreduce.Reducer;
040import org.apache.hadoop.mapreduce.TaskAttemptID;
041import org.apache.hadoop.security.Credentials;
042
043/**
044 * A {@link Mapper} which wraps a given one to allow custom 
045 * {@link Mapper.Context} implementations.
046 */
047@InterfaceAudience.Public
048@InterfaceStability.Evolving
049public class WrappedMapper<KEYIN, VALUEIN, KEYOUT, VALUEOUT> 
050    extends Mapper<KEYIN, VALUEIN, KEYOUT, VALUEOUT> {
051  
052  /**
053   * Get a wrapped {@link Mapper.Context} for custom implementations.
054   * @param mapContext <code>MapContext</code> to be wrapped
055   * @return a wrapped <code>Mapper.Context</code> for custom implementations
056   */
057  public Mapper<KEYIN, VALUEIN, KEYOUT, VALUEOUT>.Context
058  getMapContext(MapContext<KEYIN, VALUEIN, KEYOUT, VALUEOUT> mapContext) {
059    return new Context(mapContext);
060  }
061  
062  @InterfaceStability.Evolving
063  public class Context 
064      extends Mapper<KEYIN, VALUEIN, KEYOUT, VALUEOUT>.Context {
065
066    protected MapContext<KEYIN, VALUEIN, KEYOUT, VALUEOUT> mapContext;
067
068    public Context(MapContext<KEYIN, VALUEIN, KEYOUT, VALUEOUT> mapContext) {
069      this.mapContext = mapContext;
070    }
071
072    /**
073     * Get the input split for this map.
074     */
075    public InputSplit getInputSplit() {
076      return mapContext.getInputSplit();
077    }
078
079    @Override
080    public KEYIN getCurrentKey() throws IOException, InterruptedException {
081      return mapContext.getCurrentKey();
082    }
083
084    @Override
085    public VALUEIN getCurrentValue() throws IOException, InterruptedException {
086      return mapContext.getCurrentValue();
087    }
088
089    @Override
090    public boolean nextKeyValue() throws IOException, InterruptedException {
091      return mapContext.nextKeyValue();
092    }
093
094    @Override
095    public Counter getCounter(Enum<?> counterName) {
096      return mapContext.getCounter(counterName);
097    }
098
099    @Override
100    public Counter getCounter(String groupName, String counterName) {
101      return mapContext.getCounter(groupName, counterName);
102    }
103
104    @Override
105    public OutputCommitter getOutputCommitter() {
106      return mapContext.getOutputCommitter();
107    }
108
109    @Override
110    public void write(KEYOUT key, VALUEOUT value) throws IOException,
111        InterruptedException {
112      mapContext.write(key, value);
113    }
114
115    @Override
116    public String getStatus() {
117      return mapContext.getStatus();
118    }
119
120    @Override
121    public TaskAttemptID getTaskAttemptID() {
122      return mapContext.getTaskAttemptID();
123    }
124
125    @Override
126    public void setStatus(String msg) {
127      mapContext.setStatus(msg);
128    }
129
130    @Override
131    public Path[] getArchiveClassPaths() {
132      return mapContext.getArchiveClassPaths();
133    }
134
135    @Override
136    public String[] getArchiveTimestamps() {
137      return mapContext.getArchiveTimestamps();
138    }
139
140    @Override
141    public URI[] getCacheArchives() throws IOException {
142      return mapContext.getCacheArchives();
143    }
144
145    @Override
146    public URI[] getCacheFiles() throws IOException {
147      return mapContext.getCacheArchives();
148    }
149
150    @Override
151    public Class<? extends Reducer<?, ?, ?, ?>> getCombinerClass()
152        throws ClassNotFoundException {
153      return mapContext.getCombinerClass();
154    }
155
156    @Override
157    public Configuration getConfiguration() {
158      return mapContext.getConfiguration();
159    }
160
161    @Override
162    public Path[] getFileClassPaths() {
163      return mapContext.getFileClassPaths();
164    }
165
166    @Override
167    public String[] getFileTimestamps() {
168      return mapContext.getFileTimestamps();
169    }
170
171    @Override
172    public RawComparator<?> getGroupingComparator() {
173      return mapContext.getGroupingComparator();
174    }
175
176    @Override
177    public Class<? extends InputFormat<?, ?>> getInputFormatClass()
178        throws ClassNotFoundException {
179      return mapContext.getInputFormatClass();
180    }
181
182    @Override
183    public String getJar() {
184      return mapContext.getJar();
185    }
186
187    @Override
188    public JobID getJobID() {
189      return mapContext.getJobID();
190    }
191
192    @Override
193    public String getJobName() {
194      return mapContext.getJobName();
195    }
196
197    @Override
198    public boolean getJobSetupCleanupNeeded() {
199      return mapContext.getJobSetupCleanupNeeded();
200    }
201
202    @Override
203    public boolean getTaskCleanupNeeded() {
204      return mapContext.getTaskCleanupNeeded();
205    }
206
207    @Override
208    public Path[] getLocalCacheArchives() throws IOException {
209      return mapContext.getLocalCacheArchives();
210    }
211
212    @Override
213    public Path[] getLocalCacheFiles() throws IOException {
214      return mapContext.getLocalCacheFiles();
215    }
216
217    @Override
218    public Class<?> getMapOutputKeyClass() {
219      return mapContext.getMapOutputKeyClass();
220    }
221
222    @Override
223    public Class<?> getMapOutputValueClass() {
224      return mapContext.getMapOutputValueClass();
225    }
226
227    @Override
228    public Class<? extends Mapper<?, ?, ?, ?>> getMapperClass()
229        throws ClassNotFoundException {
230      return mapContext.getMapperClass();
231    }
232
233    @Override
234    public int getMaxMapAttempts() {
235      return mapContext.getMaxMapAttempts();
236    }
237
238    @Override
239    public int getMaxReduceAttempts() {
240      return mapContext.getMaxReduceAttempts();
241    }
242
243    @Override
244    public int getNumReduceTasks() {
245      return mapContext.getNumReduceTasks();
246    }
247
248    @Override
249    public Class<? extends OutputFormat<?, ?>> getOutputFormatClass()
250        throws ClassNotFoundException {
251      return mapContext.getOutputFormatClass();
252    }
253
254    @Override
255    public Class<?> getOutputKeyClass() {
256      return mapContext.getOutputKeyClass();
257    }
258
259    @Override
260    public Class<?> getOutputValueClass() {
261      return mapContext.getOutputValueClass();
262    }
263
264    @Override
265    public Class<? extends Partitioner<?, ?>> getPartitionerClass()
266        throws ClassNotFoundException {
267      return mapContext.getPartitionerClass();
268    }
269
270    @Override
271    public Class<? extends Reducer<?, ?, ?, ?>> getReducerClass()
272        throws ClassNotFoundException {
273      return mapContext.getReducerClass();
274    }
275
276    @Override
277    public RawComparator<?> getSortComparator() {
278      return mapContext.getSortComparator();
279    }
280
281    @Override
282    public boolean getSymlink() {
283      return mapContext.getSymlink();
284    }
285
286    @Override
287    public Path getWorkingDirectory() throws IOException {
288      return mapContext.getWorkingDirectory();
289    }
290
291    @Override
292    public void progress() {
293      mapContext.progress();
294    }
295
296    @Override
297    public boolean getProfileEnabled() {
298      return mapContext.getProfileEnabled();
299    }
300
301    @Override
302    public String getProfileParams() {
303      return mapContext.getProfileParams();
304    }
305
306    @Override
307    public IntegerRanges getProfileTaskRange(boolean isMap) {
308      return mapContext.getProfileTaskRange(isMap);
309    }
310
311    @Override
312    public String getUser() {
313      return mapContext.getUser();
314    }
315
316    @Override
317    public Credentials getCredentials() {
318      return mapContext.getCredentials();
319    }
320    
321    @Override
322    public float getProgress() {
323      return mapContext.getProgress();
324    }
325  }
326}