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    }