001 /* 002 * Copyright © 2008, 2009 Pedro Agulló Soliveres. 003 * 004 * This file is part of DirectJNgine. 005 * 006 * DirectJNgine is free software: you can redistribute it and/or modify 007 * it under the terms of the GNU General Public License as published by 008 * the Free Software Foundation, either version 3 of the License. 009 * 010 * DirectJNgine is distributed in the hope that it will be useful, 011 * but WITHOUT ANY WARRANTY; without even the implied warranty of 012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 013 * GNU General Public License for more details. 014 * 015 * You should have received a copy of the GNU General Public License 016 * along with DirectJNgine. If not, see <http://www.gnu.org/licenses/>. 017 * 018 * This software uses the ExtJs library (http://extjs.com), which is 019 * distributed under the GPL v3 license (see http://extjs.com/license). 020 */ 021 022 package com.softwarementors.extjs.djn.config; 023 024 import java.util.List; 025 026 import com.softwarementors.extjs.djn.StringUtils; 027 028 public class ApiConfiguration { 029 public static class Parameters { 030 public static final String API_FILE = "apiFile"; 031 public static final String NAMESPACE = "namespace"; 032 public static final String CLASSES = "classes"; 033 } 034 035 private String name; 036 private String fullApiFileName; 037 private String namespace; 038 private List<Class<?>> classes; 039 040 public ApiConfiguration( String name, String fullApiFileName, String namespace, List<Class<?>> classes ) { 041 assert !StringUtils.isEmpty(name); 042 assert !StringUtils.isEmpty( fullApiFileName ); 043 assert !StringUtils.isEmpty( namespace ); 044 assert classes != null; 045 046 this.name = name; 047 this.fullApiFileName = fullApiFileName; 048 this.namespace = namespace; 049 this.classes = classes; 050 } 051 052 /* package */ String getFullApiFileName() { 053 return this.fullApiFileName; 054 } 055 056 /* package */ String getNamespace() { 057 return this.namespace; 058 } 059 060 /* package */ List<Class<?>> getClasses() { 061 return this.classes; 062 } 063 064 /* package */ String getName() { 065 return this.name; 066 } 067 }