All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.androidannotations.internal.generation.SourceCodeWriter Maven / Gradle / Ivy

There is a newer version: 4.8.0
Show newest version
/**
 * Copyright (C) 2010-2016 eBusiness Information, Excilys Group
 * Copyright (C) 2016-2020 the AndroidAnnotations project
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
 * use this file except in compliance with the License. You may obtain a copy of
 * the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed To in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 * License for the specific language governing permissions and limitations under
 * the License.
 */
package org.androidannotations.internal.generation;

import java.io.IOException;
import java.io.OutputStream;
import java.nio.charset.Charset;

import javax.annotation.processing.Filer;
import javax.annotation.processing.FilerException;
import javax.lang.model.element.Element;
import javax.tools.JavaFileObject;

import org.androidannotations.internal.process.OriginatingElements;
import org.androidannotations.logger.Logger;
import org.androidannotations.logger.LoggerFactory;

import com.helger.jcodemodel.AbstractCodeWriter;
import com.helger.jcodemodel.JPackage;

public class SourceCodeWriter extends AbstractCodeWriter {

	private static final VoidOutputStream VOID_OUTPUT_STREAM = new VoidOutputStream();
	private static final Logger LOGGER = LoggerFactory.getLogger(SourceCodeWriter.class);
	private final Filer filer;
	private OriginatingElements originatingElements;

	private static class VoidOutputStream extends OutputStream {
		@Override
		public void write(int arg0) throws IOException {
			// Do nothing
		}
	}

	public SourceCodeWriter(Filer filer, OriginatingElements originatingElements, Charset charset) {
		super(charset, getDefaultNewLine());
		this.filer = filer;
		this.originatingElements = originatingElements;
	}

	@Override
	public OutputStream openBinary(JPackage pkg, String fileName) throws IOException {
		String qualifiedClassName = toQualifiedClassName(pkg, fileName);
		LOGGER.debug("Generating class: {}", qualifiedClassName);

		Element[] classOriginatingElements = originatingElements.getClassOriginatingElements(qualifiedClassName);

		try {
			JavaFileObject sourceFile;

			if (classOriginatingElements.length == 0) {
				LOGGER.info("Generating class with no originating element: {}", qualifiedClassName);
			}

			sourceFile = filer.createSourceFile(qualifiedClassName, classOriginatingElements);

			return sourceFile.openOutputStream();
		} catch (FilerException e) {
			LOGGER.error("Could not generate source file for {} due to error: {}", qualifiedClassName, e.getMessage());
			/*
			 * This exception is expected, when some files are created twice. We cannot
			 * delete existing files, unless using a dirty hack. Files a created twice when
			 * the same file is created from different annotation rounds. Happens when
			 * renaming classes, and for Background executor. It also probably means I
			 * didn't fully understand how annotation processing works. If anyone can point
			 * me out...
			 */
			return VOID_OUTPUT_STREAM;
		}
	}

	private String toQualifiedClassName(JPackage pkg, String fileName) {
		int suffixPosition = fileName.lastIndexOf('.');
		String className = fileName.substring(0, suffixPosition);

		String qualifiedClassName = pkg.name() + "." + className;
		return qualifiedClassName;
	}

	@Override
	public void close() throws IOException {
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy