org.neo4j.kernel.impl.annotations.AnnotationProcessor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-kernel Show documentation
Show all versions of neo4j-kernel Show documentation
Neo4j kernel is a lightweight, embedded Java database designed to
store data structured as graphs rather than tables. For more
information, see http://neo4j.org.
/**
* Copyright (c) 2002-2013 "Neo Technology,"
* Network Engine for Objects in Lund AB [http://neotechnology.com]
*
* This file is part of Neo4j.
*
* Neo4j is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
package org.neo4j.kernel.impl.annotations;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import java.lang.annotation.Annotation;
import java.net.URI;
import java.util.Collections;
import java.util.Map;
import java.util.Set;
import java.util.regex.Pattern;
import javax.annotation.processing.AbstractProcessor;
import javax.annotation.processing.ProcessingEnvironment;
import javax.annotation.processing.RoundEnvironment;
import javax.lang.model.element.AnnotationMirror;
import javax.lang.model.element.AnnotationValue;
import javax.lang.model.element.Element;
import javax.lang.model.element.ExecutableElement;
import javax.lang.model.element.TypeElement;
import javax.tools.Diagnostic.Kind;
import javax.tools.FileObject;
import javax.tools.StandardLocation;
public abstract class AnnotationProcessor extends AbstractProcessor
{
private CompilationManipulator manipulator = null;
@Override
public synchronized void init( @SuppressWarnings( "hiding" ) ProcessingEnvironment processingEnv )
{
super.init( processingEnv );
manipulator = CompilationManipulator.load( this, processingEnv );
if ( manipulator == null )
processingEnv.getMessager().printMessage( Kind.NOTE,
"Cannot write values to this compiler: " + processingEnv.getClass().getName() );
}
@Override
public boolean process( Set extends TypeElement> annotations, RoundEnvironment roundEnv )
{
for ( TypeElement type : annotations )
{
for ( Element annotated : roundEnv.getElementsAnnotatedWith( type ) )
{
for ( AnnotationMirror mirror : annotated.getAnnotationMirrors() )
{
if ( mirror.getAnnotationType().asElement().equals( type ) )
{
try
{
process( type, annotated, mirror, processingEnv.getElementUtils()
.getElementValuesWithDefaults( mirror ) );
}
catch ( Exception e )
{
e.printStackTrace();
processingEnv.getMessager().printMessage( Kind.ERROR, "Internal error: " + e.toString(),
annotated, mirror );
}
}
}
}
}
return false;
}
protected final void warn( Element element, String message )
{
processingEnv.getMessager().printMessage( Kind.WARNING, message, element );
}
protected final void warn( Element element, AnnotationMirror annotation, String message )
{
processingEnv.getMessager().printMessage( Kind.WARNING, message, element, annotation );
}
protected final void error( Element element, String message )
{
processingEnv.getMessager().printMessage( Kind.ERROR, message, element );
}
protected final void error( Element element, AnnotationMirror annotation, String message )
{
processingEnv.getMessager().printMessage( Kind.ERROR, message, element, annotation );
}
protected final boolean updateAnnotationValue( Element annotated, AnnotationMirror annotation, String key,
String value )
{
return manipulator != null && manipulator.updateAnnotationValue( annotated, annotation, key, value );
}
protected final boolean addAnnotation( Element target, Class extends Annotation> annotation, Object value )
{
return addAnnotation( target, annotation, Collections.singletonMap( "value", value ) );
}
protected final boolean addAnnotation( Element target, Class extends Annotation> annotation, String key,
Object value )
{
return addAnnotation( target, annotation, Collections.singletonMap( key, value ) );
}
protected final boolean addAnnotation( Element target, Class extends Annotation> annotation )
{
return addAnnotation( target, annotation, Collections.emptyMap() );
}
protected final boolean addAnnotation( Element target, Class extends Annotation> annotation,
Map parameters )
{
return manipulator != null && manipulator.addAnnotation( target, nameOf( annotation ), parameters );
}
private static String nameOf( Class extends Annotation> annotation )
{
return annotation.getName().replace( '$', '.' );
}
protected abstract void process( TypeElement annotationType, Element annotated, AnnotationMirror annotation,
Map extends ExecutableElement, ? extends AnnotationValue> values ) throws IOException;
private static Pattern nl = Pattern.compile( "\n" );
void addTo( String line, String... path ) throws IOException
{
FileObject fo = processingEnv.getFiler().getResource( StandardLocation.CLASS_OUTPUT, "", path( path ) );
URI uri = fo.toUri();
File file;
try
{
file = new File( uri );
}
catch ( Exception e )
{
file = new File( uri.toString() );
}
if ( file.exists() )
{
for ( String previous : nl.split( fo.getCharContent( true ), 0 ) )
{
if ( line.equals( previous ) ) return;
}
}
else
{
file.getParentFile().mkdirs();
}
new FileWriter( file, true ).append( line ).append( "\n" ).close();
}
Writer append( String... path ) throws IOException
{
FileObject file = processingEnv.getFiler().getResource( StandardLocation.CLASS_OUTPUT, "", path( path ) );
URI uri = file.toUri();
return new FileWriter( new File( uri.toString() ), true );
}
private String path( String[] path )
{
StringBuilder filename = new StringBuilder();
String sep = "";
for ( String part : path )
{
filename.append( sep ).append( part );
sep = "/";
}
return filename.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy