2 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.controller.yang2sources.plugin;
13 import org.apache.maven.project.MavenProject;
15 import com.google.common.base.Preconditions;
16 import com.google.common.collect.Maps;
19 * Base complex configuration arguments
21 public abstract class ConfigArg {
23 private final File outputBaseDir;
25 public ConfigArg(String outputBaseDir) {
26 this.outputBaseDir = new File(outputBaseDir);
29 public File getOutputBaseDir(MavenProject project) {
30 if (outputBaseDir.isAbsolute()) {
33 return new File(project.getBasedir(), outputBaseDir.getPath());
37 public abstract void check();
40 * Configuration argument for code generator class and output directory.
42 public static final class CodeGeneratorArg extends ConfigArg {
43 private static final String CODE_GEN_DEFAULT_DIR = "target"
44 + File.separator + "generated-sources";
45 private String codeGeneratorClass;
47 private Map<String, String> additionalConfiguration = Maps.newHashMap();
49 public CodeGeneratorArg() {
50 super(CODE_GEN_DEFAULT_DIR);
53 public CodeGeneratorArg(String codeGeneratorClass) {
54 this(codeGeneratorClass, CODE_GEN_DEFAULT_DIR);
57 public CodeGeneratorArg(String codeGeneratorClass, String outputBaseDir) {
59 this.codeGeneratorClass = codeGeneratorClass;
64 Preconditions.checkNotNull(codeGeneratorClass,
65 "codeGeneratorClass for CodeGenerator cannot be null");
68 public String getCodeGeneratorClass() {
69 return codeGeneratorClass;
72 public Map<String, String> getAdditionalConfiguration() {
73 return additionalConfiguration;