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;
12 import com.google.common.base.Preconditions;
15 * Base complex configuration arguments
17 public abstract class ConfigArg {
19 protected File outputBaseDir;
21 public ConfigArg(File outputBaseDir) {
22 this.outputBaseDir = outputBaseDir;
28 public File getOutputBaseDir() {
32 public abstract void check();
35 * Configuration argument for resource generator class and output directory.
37 public static final class ResourceProviderArg extends ConfigArg {
38 private String resourceProviderClass;
40 public ResourceProviderArg() {
43 public ResourceProviderArg(String resourceProviderClass,
46 this.resourceProviderClass = resourceProviderClass;
52 .checkNotNull(resourceProviderClass,
53 "resourceProviderClass for ResourceProvider cannot be null");
54 Preconditions.checkNotNull(outputBaseDir,
55 "outputBaseDir for ResourceProvider cannot be null, "
56 + resourceProviderClass);
59 public String getResourceProviderClass() {
60 return resourceProviderClass;
65 * Configuration argument for code generator class and output directory.
67 public static final class CodeGeneratorArg extends ConfigArg {
68 private String codeGeneratorClass;
70 public CodeGeneratorArg() {
73 public CodeGeneratorArg(String codeGeneratorClass, File outputBaseDir) {
75 this.codeGeneratorClass = codeGeneratorClass;
80 Preconditions.checkNotNull(codeGeneratorClass,
81 "codeGeneratorClass for CodeGenerator cannot be null");
82 Preconditions.checkNotNull(outputBaseDir,
83 "outputBaseDir for CodeGenerator cannot be null, "
84 + codeGeneratorClass);
87 public String getCodeGeneratorClass() {
88 return codeGeneratorClass;