source: proiecte/HadoopJUnit/hadoop-0.20.1/src/core/org/apache/hadoop/io/WritableFactories.java @ 120

Last change on this file since 120 was 120, checked in by (none), 14 years ago

Added the mail files for the Hadoop JUNit Project

  • Property svn:executable set to *
File size: 2.2 KB
Line 
1/**
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements.  See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership.  The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License.  You may obtain a copy of the License at
9 *
10 *     http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 */
18
19package org.apache.hadoop.io;
20
21import org.apache.hadoop.conf.*;
22import org.apache.hadoop.util.ReflectionUtils;
23import java.util.HashMap;
24
25/** Factories for non-public writables.  Defining a factory permits {@link
26 * ObjectWritable} to be able to construct instances of non-public classes. */
27public class WritableFactories {
28  private static final HashMap<Class, WritableFactory> CLASS_TO_FACTORY =
29    new HashMap<Class, WritableFactory>();
30
31  private WritableFactories() {}                  // singleton
32
33  /** Define a factory for a class. */
34  public static synchronized void setFactory(Class c, WritableFactory factory) {
35    CLASS_TO_FACTORY.put(c, factory);
36  }
37
38  /** Define a factory for a class. */
39  public static synchronized WritableFactory getFactory(Class c) {
40    return CLASS_TO_FACTORY.get(c);
41  }
42
43  /** Create a new instance of a class with a defined factory. */
44  public static Writable newInstance(Class<? extends Writable> c, Configuration conf) {
45    WritableFactory factory = WritableFactories.getFactory(c);
46    if (factory != null) {
47      Writable result = factory.newInstance();
48      if (result instanceof Configurable) {
49        ((Configurable) result).setConf(conf);
50      }
51      return result;
52    } else {
53      return ReflectionUtils.newInstance(c, conf);
54    }
55  }
56 
57  /** Create a new instance of a class with a defined factory. */
58  public static Writable newInstance(Class<? extends Writable> c) {
59    return newInstance(c, null);
60  }
61
62}
63
Note: See TracBrowser for help on using the repository browser.