Skip to content

Commit

Permalink
HHH-17504 - Ongoing JPA 32 work HHH-17350 - Work on hibernate-models,…
Browse files Browse the repository at this point in the history
… XSD and JAXB HHH-16114 - Improve boot metamodel binding HHH-15996 - Develop an abstraction for Annotation in annotation processing HHH-16012 - Develop an abstraction for domain model Class refs HHH-15997 - Support for dynamic models in orm.xml HHH-15698 - Support for entity-name in mapping.xsd
  • Loading branch information
dreab8 authored and sebersole committed Mar 28, 2024
1 parent b3bad2b commit 97c86f0
Show file tree
Hide file tree
Showing 4 changed files with 161 additions and 46 deletions.
Expand Up @@ -219,6 +219,16 @@ public static MutableAnnotationUsage<JoinColumn> applyJoinColumn(
return createJoinColumnAnnotation( jaxbJoinColumn, memberDetails, JoinColumn.class, xmlDocumentContext );
}

public static MutableAnnotationUsage<JoinColumn> applyJoinColumn(
JaxbJoinColumnImpl jaxbJoinColumn,
XmlDocumentContext xmlDocumentContext) {
if ( jaxbJoinColumn == null ) {
return null;
}

return createJoinColumnAnnotation( jaxbJoinColumn, JoinColumn.class, xmlDocumentContext );
}

public static <A extends Annotation> MutableAnnotationUsage<A> createJoinColumnAnnotation(
JaxbColumnJoined jaxbJoinColumn,
MutableMemberDetails memberDetails,
Expand All @@ -245,6 +255,31 @@ public static <A extends Annotation> MutableAnnotationUsage<A> createJoinColumnA
return joinColumnAnn;
}

public static <A extends Annotation> MutableAnnotationUsage<A> createJoinColumnAnnotation(
JaxbColumnJoined jaxbJoinColumn,
Class<A> annotationType,
XmlDocumentContext xmlDocumentContext) {
final MutableAnnotationUsage<A> joinColumnAnn = XmlProcessingHelper.getOrMakeAnnotation( annotationType, xmlDocumentContext );
final AnnotationDescriptor<A> joinColumnDescriptor = xmlDocumentContext
.getModelBuildingContext()
.getAnnotationDescriptorRegistry()
.getDescriptor( annotationType );

ColumnProcessing.applyColumnDetails( jaxbJoinColumn, joinColumnAnn, xmlDocumentContext );

applyOr( jaxbJoinColumn, JaxbColumnJoined::getReferencedColumnName, "referencedColumnName", joinColumnAnn, joinColumnDescriptor );

final JaxbForeignKeyImpl jaxbForeignKey = jaxbJoinColumn.getForeignKey();
if ( jaxbForeignKey != null ) {
joinColumnAnn.setAttributeValue(
"foreignKey",
createForeignKeyAnnotation( jaxbForeignKey, xmlDocumentContext )
);
}

return joinColumnAnn;
}

public static void applyJoinColumns(
List<JaxbJoinColumnImpl> jaxbJoinColumns,
MutableMemberDetails memberDetails,
Expand Down Expand Up @@ -280,6 +315,19 @@ public static List<AnnotationUsage<JoinColumn>> createJoinColumns(
return joinColumns;
}

public static List<AnnotationUsage<JoinColumn>> createJoinColumns(
List<JaxbJoinColumnImpl> jaxbJoinColumns,
XmlDocumentContext xmlDocumentContext) {
if ( CollectionHelper.isEmpty( jaxbJoinColumns ) ) {
return Collections.emptyList();
}
final List<AnnotationUsage<JoinColumn>> joinColumns = new ArrayList<>( jaxbJoinColumns.size() );
jaxbJoinColumns.forEach( jaxbJoinColumn -> {
joinColumns.add( applyJoinColumn( jaxbJoinColumn, xmlDocumentContext ) );
} );
return joinColumns;
}

public static <T,N> void applyOr(
N jaxbNode,
Function<N,T> jaxbValueAccess,
Expand Down Expand Up @@ -429,6 +477,23 @@ public static MutableAnnotationUsage<ForeignKey> createForeignKeyAnnotation(
return foreignKeyAnn;
}

public static MutableAnnotationUsage<ForeignKey> createForeignKeyAnnotation(
JaxbForeignKeyImpl jaxbForeignKey,
XmlDocumentContext xmlDocumentContext) {
final MutableAnnotationUsage<ForeignKey> foreignKeyAnn = XmlProcessingHelper.getOrMakeAnnotation( ForeignKey.class, xmlDocumentContext );
final AnnotationDescriptor<ForeignKey> foreignKeyDescriptor = xmlDocumentContext
.getModelBuildingContext()
.getAnnotationDescriptorRegistry()
.getDescriptor( ForeignKey.class );

applyOr( jaxbForeignKey, JaxbForeignKeyImpl::getName, "name", foreignKeyAnn, foreignKeyDescriptor );
applyOr( jaxbForeignKey, JaxbForeignKeyImpl::getConstraintMode, "value", foreignKeyAnn, foreignKeyDescriptor );
applyOr( jaxbForeignKey, JaxbForeignKeyImpl::getForeignKeyDefinition, "foreignKeyDefinition", foreignKeyAnn, foreignKeyDescriptor );
applyOr( jaxbForeignKey, JaxbForeignKeyImpl::getOptions, "options", foreignKeyAnn, foreignKeyDescriptor );

return foreignKeyAnn;
}

public static void applyMapKeyColumn(
JaxbMapKeyColumnImpl jaxbMapKeyColumn,
MutableMemberDetails memberDetails,
Expand Down Expand Up @@ -622,6 +687,26 @@ public static <A extends Annotation> void applyCheckConstraints(
}
}

public static <A extends Annotation> void applyCheckConstraints(
JaxbCheckable jaxbCheckable,
MutableAnnotationUsage<A> annotationUsage,
XmlDocumentContext xmlDocumentContext) {
if ( CollectionHelper.isNotEmpty( jaxbCheckable.getCheckConstraints() ) ) {
final List<AnnotationUsage<CheckConstraint>> checks = new ArrayList<>( jaxbCheckable.getCheckConstraints().size() );
final AnnotationDescriptor<CheckConstraint> checkConstraintDescriptor = xmlDocumentContext.getModelBuildingContext()
.getAnnotationDescriptorRegistry()
.getDescriptor( CheckConstraint.class );
for ( JaxbCheckConstraintImpl jaxbCheck : jaxbCheckable.getCheckConstraints() ) {
final MutableAnnotationUsage<CheckConstraint> checkAnn = XmlProcessingHelper.getOrMakeAnnotation( CheckConstraint.class, xmlDocumentContext );
applyOr( jaxbCheck, JaxbCheckConstraintImpl::getName, "name", checkAnn, checkConstraintDescriptor );
applyOr( jaxbCheck, JaxbCheckConstraintImpl::getConstraint, "constraint", checkAnn, checkConstraintDescriptor );
applyOr( jaxbCheck, JaxbCheckConstraintImpl::getOptions, "options", checkAnn, checkConstraintDescriptor );
checks.add( checkAnn );
}
annotationUsage.setAttributeValue( "check", checks );
}
}

public static void applyTargetClass(
String name,
MutableMemberDetails memberDetails,
Expand Down
Expand Up @@ -125,6 +125,13 @@ public static <A extends Annotation> MutableAnnotationUsage<A> getOrMakeAnnotati
return makeAnnotation( annotationType, target, xmlDocumentContext );
}

public static <A extends Annotation> MutableAnnotationUsage<A> getOrMakeAnnotation(
Class<A> annotationType,
XmlDocumentContext xmlDocumentContext) {

return makeAnnotation( annotationType, xmlDocumentContext );
}

/**
* Make a nested AnnotationUsage. The usage is created with the given target,
* but it is not added to the target's annotations.
Expand All @@ -141,6 +148,16 @@ public static <A extends Annotation> MutableAnnotationUsage<A> makeNestedAnnotat
);
}

public static <A extends Annotation> MutableAnnotationUsage<A> makeNestedAnnotation(
Class<A> annotationType,
XmlDocumentContext xmlDocumentContext) {
return new DynamicAnnotationUsage<>(
xmlDocumentContext.getModelBuildingContext()
.getAnnotationDescriptorRegistry()
.getDescriptor( annotationType )
);
}

/**
* Make an AnnotationUsage.
* Used when applying XML in complete mode or when {@linkplain #getOrMakeAnnotation}
Expand All @@ -155,6 +172,13 @@ public static <A extends Annotation> MutableAnnotationUsage<A> makeAnnotation(
return created;
}

public static <A extends Annotation> MutableAnnotationUsage<A> makeAnnotation(
Class<A> annotationType,
XmlDocumentContext xmlDocumentContext) {
final MutableAnnotationUsage<A> created = makeNestedAnnotation( annotationType, xmlDocumentContext );
return created;
}

/**
* Find an existing annotation by name, or create one.
* Used when applying XML in override mode.
Expand Down
Expand Up @@ -48,15 +48,13 @@ public static MutableMemberDetails processElementCollectionAttribute(
xmlDocumentContext
);
XmlProcessingHelper.setIf( jaxbElementCollection.getFetch(), "fetch", elementCollectionAnn );
if ( StringHelper.isNotEmpty( jaxbElementCollection.getTargetClass() ) ) {
elementCollectionAnn.setAttributeValue(
"targetClass",
XmlAnnotationHelper.resolveJavaType(
jaxbElementCollection.getTargetClass(),
xmlDocumentContext.getModelBuildingContext()
)
);
}
elementCollectionAnn.setAttributeValue(
"targetClass",
XmlAnnotationHelper.resolveJavaType(
jaxbElementCollection.getTargetClass(),
xmlDocumentContext.getModelBuildingContext()
)
);

CommonAttributeProcessing.applyAttributeBasics( jaxbElementCollection, memberDetails, elementCollectionAnn, accessType, xmlDocumentContext );

Expand All @@ -73,11 +71,6 @@ public static MutableMemberDetails processElementCollectionAttribute(
XmlAnnotationHelper.applyTemporal( jaxbElementCollection.getTemporal(), memberDetails, xmlDocumentContext );
XmlAnnotationHelper.applyBasicTypeComposition( jaxbElementCollection, memberDetails, xmlDocumentContext );

if ( StringHelper.isNotEmpty( jaxbElementCollection.getTargetClass() ) ) {
final MutableAnnotationUsage<Target> targetAnn = XmlProcessingHelper.getOrMakeAnnotation( Target.class, memberDetails, xmlDocumentContext );
targetAnn.setAttributeValue( "value", jaxbElementCollection.getTargetClass() );
}

jaxbElementCollection.getConverts().forEach( (jaxbConvert) -> {
XmlAnnotationHelper.applyConvert( jaxbConvert, memberDetails, xmlDocumentContext );
} );
Expand Down Expand Up @@ -110,12 +103,12 @@ public static void applyCollectionTable(
XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getSchema, "schema", collectionTableAnn, collectionTableDescriptor );
XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getOptions, "options", collectionTableAnn, collectionTableDescriptor );

collectionTableAnn.setAttributeValue( "joinColumns", XmlAnnotationHelper.createJoinColumns( jaxbCollectionTable.getJoinColumns(), memberDetails, xmlDocumentContext ) );
collectionTableAnn.setAttributeValue( "joinColumns", XmlAnnotationHelper.createJoinColumns( jaxbCollectionTable.getJoinColumns(), xmlDocumentContext ) );

if ( jaxbCollectionTable.getForeignKeys() != null ) {
collectionTableAnn.setAttributeValue(
"foreignKey",
XmlAnnotationHelper.createForeignKeyAnnotation( jaxbCollectionTable.getForeignKeys(), memberDetails, xmlDocumentContext )
XmlAnnotationHelper.createForeignKeyAnnotation( jaxbCollectionTable.getForeignKeys(), xmlDocumentContext )
);
}

Expand Down
Expand Up @@ -38,37 +38,57 @@ public static <A extends Annotation> void applyColumnDetails(
return;
}

applyColumnBasics( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnNullness( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnMutability( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnDefinition( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnUniqueness( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnComment( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnBasics( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnNullness( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnMutability( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnDefinition( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnUniqueness( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnComment( jaxbColumn, columnAnn, xmlDocumentContext );
XmlAnnotationHelper.applyCheckConstraints( jaxbColumn, target, columnAnn, xmlDocumentContext );

if ( jaxbColumn instanceof JaxbColumnSizable sizable ) {
applyColumnSizing( sizable, target, columnAnn, xmlDocumentContext );
applyColumnSizing( sizable, columnAnn, xmlDocumentContext );
}

}

public static <A extends Annotation> void applyColumnDetails(
JaxbColumnCommon jaxbColumn,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( jaxbColumn == null ) {
return;
}

applyColumnBasics( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnNullness( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnMutability( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnDefinition( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnUniqueness( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnComment( jaxbColumn, columnAnn, xmlDocumentContext );
XmlAnnotationHelper.applyCheckConstraints( jaxbColumn, columnAnn, xmlDocumentContext );

if ( jaxbColumn instanceof JaxbColumnSizable sizable ) {
applyColumnSizing( sizable, columnAnn, xmlDocumentContext );
}
}

public static <A extends Annotation> void applyColumnDetails(
JaxbColumnStandard jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( jaxbColumn == null ) {
return;
}

applyColumnBasics( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnNullness( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnMutability( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnDefinition( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnSizing( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnUniqueness( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnComment( jaxbColumn, target, columnAnn, xmlDocumentContext );
XmlAnnotationHelper.applyCheckConstraints( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnBasics( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnNullness( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnMutability( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnDefinition( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnSizing( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnUniqueness( jaxbColumn, columnAnn, xmlDocumentContext );
applyColumnComment( jaxbColumn, columnAnn, xmlDocumentContext );
XmlAnnotationHelper.applyCheckConstraints( jaxbColumn, columnAnn, xmlDocumentContext );
}

public static <A extends Annotation> void applyColumnDetails(
Expand All @@ -80,30 +100,30 @@ public static <A extends Annotation> void applyColumnDetails(
return;
}

applyColumnBasics( jaxbColumn, target, columnAnn, xmlDocumentContext );
applyColumnBasics( jaxbColumn, columnAnn, xmlDocumentContext );

if ( jaxbColumn instanceof JaxbColumnNullable nullable ) {
applyColumnNullness( nullable, target, columnAnn, xmlDocumentContext );
applyColumnNullness( nullable, columnAnn, xmlDocumentContext );
}

if ( jaxbColumn instanceof JaxbColumnMutable mutable ) {
applyColumnMutability( mutable, target, columnAnn, xmlDocumentContext );
applyColumnMutability( mutable, columnAnn, xmlDocumentContext );
}

if ( jaxbColumn instanceof JaxbColumnDefinable definable ) {
applyColumnDefinition( definable, target, columnAnn, xmlDocumentContext );
applyColumnDefinition( definable, columnAnn, xmlDocumentContext );
}

if ( jaxbColumn instanceof JaxbColumnSizable sizable ) {
applyColumnSizing( sizable, target, columnAnn, xmlDocumentContext );
applyColumnSizing( sizable, columnAnn, xmlDocumentContext );
}

if ( jaxbColumn instanceof JaxbColumnUniqueable uniqueable ) {
applyColumnUniqueness( uniqueable, target, columnAnn, xmlDocumentContext );
applyColumnUniqueness( uniqueable, columnAnn, xmlDocumentContext );
}

if ( jaxbColumn instanceof JaxbCommentable commentable ) {
applyColumnComment( commentable, target, columnAnn, xmlDocumentContext );
applyColumnComment( commentable, columnAnn, xmlDocumentContext );
}

if ( jaxbColumn instanceof JaxbCheckable checkable ) {
Expand All @@ -113,7 +133,6 @@ public static <A extends Annotation> void applyColumnDetails(

private static <A extends Annotation> void applyColumnBasics(
JaxbColumn jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( StringHelper.isNotEmpty( jaxbColumn.getName() ) ) {
Expand All @@ -127,7 +146,6 @@ private static <A extends Annotation> void applyColumnBasics(

private static <A extends Annotation> void applyColumnNullness(
JaxbColumnNullable jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( jaxbColumn.isNullable() != null ) {
Expand All @@ -137,7 +155,6 @@ private static <A extends Annotation> void applyColumnNullness(

private static <A extends Annotation> void applyColumnMutability(
JaxbColumnMutable jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( jaxbColumn.isInsertable() != null ) {
Expand All @@ -151,7 +168,6 @@ private static <A extends Annotation> void applyColumnMutability(

private static <A extends Annotation> void applyColumnSizing(
JaxbColumnSizable jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {

Expand All @@ -170,7 +186,6 @@ private static <A extends Annotation> void applyColumnSizing(

private static <A extends Annotation> void applyColumnUniqueness(
JaxbColumnUniqueable jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( jaxbColumn.isUnique() != null ) {
Expand All @@ -180,7 +195,6 @@ private static <A extends Annotation> void applyColumnUniqueness(

private static <A extends Annotation> void applyColumnDefinition(
JaxbColumnDefinable jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( StringHelper.isNotEmpty( jaxbColumn.getColumnDefinition() ) ) {
Expand All @@ -194,7 +208,6 @@ private static <A extends Annotation> void applyColumnDefinition(

private static <A extends Annotation> void applyColumnComment(
JaxbCommentable jaxbColumn,
MutableAnnotationTarget target,
MutableAnnotationUsage<A> columnAnn,
XmlDocumentContext xmlDocumentContext) {
if ( StringHelper.isNotEmpty( jaxbColumn.getComment() ) ) {
Expand Down

0 comments on commit 97c86f0

Please sign in to comment.