source: proiecte/HadoopJUnit/hadoop-0.20.1/src/core/org/apache/hadoop/record/compiler/CodeGenerator.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: 1.8 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.record.compiler;
20
21import java.io.IOException;
22import java.util.ArrayList;
23import java.util.HashMap;
24
25/**
26 * CodeGenerator is a Factory and a base class for Hadoop Record I/O translators.
27 * Different translators register creation methods with this factory.
28 */
29abstract class CodeGenerator {
30 
31  private static HashMap<String, CodeGenerator> generators =
32    new HashMap<String, CodeGenerator>();
33 
34  static {
35    register("c", new CGenerator());
36    register("c++", new CppGenerator());
37    register("java", new JavaGenerator());
38  }
39 
40  static void register(String lang, CodeGenerator gen) {
41    generators.put(lang, gen);
42  }
43 
44  static CodeGenerator get(String lang) {
45    return generators.get(lang);
46  }
47 
48  abstract void genCode(String file,
49                        ArrayList<JFile> inclFiles,
50                        ArrayList<JRecord> records,
51                        String destDir,
52                        ArrayList<String> options) throws IOException;
53}
Note: See TracBrowser for help on using the repository browser.