Ora ho due campi per ogni campo nella mia classe metamodello, ad esempio:
public static final String _registrationDate="registrationDate";
public static volatile SingularAttribute<User, Date> registrationDate;
per ottenere questo lavoro ho riutilizzato il codice da JPAMetaModelEntityProcessor (sfortunatamente non c'era problema con semplicemente estendendo questa classe). ho aggiunto questo metodo:
private void addFieldsNamesAsStrings(MetaEntity entity) {
if (entity instanceof AnnotationMetaEntity) {
AnnotationMetaEntity aentity = (AnnotationMetaEntity) entity;
List<MetaAttribute> newMembers = new ArrayList<MetaAttribute>();
for (final MetaAttribute ma : entity.getMembers()) {
MetaAttribute nma = new AnnotationMetaAttribute(aentity, null,
null) {
public String getDeclarationString() {
return new StringBuilder()
.append("public static final String ")
.append(getPropertyName()).append("=\""+ma.getPropertyName()+"\";")
.toString();
}
@Override
public String getPropertyName() {
return "_"+ma.getPropertyName();
}
@Override
public String getMetaType() {
return null;
}
};
newMembers.add(nma);
aentity.mergeInMembers(newMembers);
}
}
}
che ho invocato prima di ogni occorrenza di
ClassWriter.writeFile(entity, context);
corrispondente configurazione di Maven:
<plugin>
<groupId>org.bsc.maven</groupId>
<artifactId>maven-processor-plugin</artifactId>
<executions>
<execution>
<id>process</id>
<goals>
<goal>process</goal>
</goals>
<phase>generate-sources</phase>
<configuration>
<processors>
<processor>
com.company.MyProcessor
</processor>
</processors>
<outputDirectory>target/modelgen/src/main/java</outputDirectory>
</configuration>
</execution>
</executions>
</plugin>
Penso che questa sia attualmente la soluzione più semplice attualmente disponibile. – vinga