001/*
002  GRANITE DATA SERVICES
003  Copyright (C) 2011 GRANITE DATA SERVICES S.A.S.
004
005  This file is part of Granite Data Services.
006
007  Granite Data Services is free software; you can redistribute it and/or modify
008  it under the terms of the GNU Library General Public License as published by
009  the Free Software Foundation; either version 2 of the License, or (at your
010  option) any later version.
011
012  Granite Data Services is distributed in the hope that it will be useful, but
013  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
014  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
015  for more details.
016
017  You should have received a copy of the GNU Library General Public License
018  along with this library; if not, see <http://www.gnu.org/licenses/>.
019*/
020
021package org.granite.generator.as3;
022
023import java.io.File;
024import java.util.HashMap;
025import java.util.Map;
026
027import org.granite.generator.Input;
028import org.granite.generator.as3.reflect.JavaType;
029
030/**
031 * @author Franck WOLFF
032 */
033public class JavaAs3Input implements Input<Class<?>> {
034
035        private final Class<?> type;
036        private final File file;
037        private final Map<String, String> attributes;
038        private JavaType javaType = null;
039        
040        public JavaAs3Input(Class<?> type, File file) {
041                this(type, file, null);
042        }
043        
044        public JavaAs3Input(Class<?> type, File file, Map<String, String> attributes) {
045                this.type = type;
046                this.file = file;
047                this.attributes = (attributes != null ? attributes : new HashMap<String, String>());
048        }
049
050        @Override
051        public Class<?> getType() {
052                return type;
053        }
054
055        @Override
056        public String getDescription() {
057                return type.getName();
058        }
059
060        public File getFile() {
061                return file;
062        }
063
064        public JavaType getJavaType() {
065                return javaType;
066        }
067
068        public Map<String, String> getAttributes() {
069                return attributes;
070        }
071
072        public void setJavaType(JavaType javaType) {
073                this.javaType = javaType;
074        }
075}