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      
030      private String name;
031      private String fullApiFileName;
032      private String namespace;
033      private List<Class<?>> classes;
034      
035      public ApiConfiguration( String name, String fullApiFileName, String namespace, List<Class<?>> classes ) {
036        assert !StringUtils.isEmpty(name);
037        assert !StringUtils.isEmpty( fullApiFileName );
038        assert !StringUtils.isEmpty( namespace );
039        assert classes != null;
040    
041        this.name = name;
042        this.fullApiFileName = fullApiFileName;
043        this.namespace = namespace;
044        this.classes = classes;
045      }
046    
047      /* package */ String getFullApiFileName() {
048        return this.fullApiFileName;
049      }
050    
051      /* package */ String getNamespace() {
052        return this.namespace;
053      }
054    
055      /* package */ List<Class<?>> getClasses() {
056        return this.classes;
057      }
058      
059      /* package */ String getName() {
060        return this.name;
061      }
062    }