Examples of XAnnotatedElement


Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    this.inheritanceStatePerClass = inheritanceStatePerClass;
    extractInheritanceType();
  }

  private void extractInheritanceType() {
    XAnnotatedElement element = getClazz();
    Inheritance inhAnn = element.getAnnotation( Inheritance.class );
    MappedSuperclass mappedSuperClass = element.getAnnotation( MappedSuperclass.class );
    if ( mappedSuperClass != null ) {
      setEmbeddableSuperclass( true );
      setType( inhAnn == null ? null : inhAnn.strategy() );
    }
    else {
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      /**
       * The property must be put in hibernate.properties as it's a system wide property. Fixable?
       * TODO support true/false/default on the property instead of present / not present
       * TODO is @Column mandatory?
       * TODO add method support
       */
      if ( mappings.isSpecjProprietarySyntaxEnabled() ) {
        if ( element.isAnnotationPresent( Id.class ) && element.isAnnotationPresent( Column.class ) ) {
          String columnName = element.getAnnotation( Column.class ).name();
          for ( XProperty prop : declaringClass.getDeclaredProperties( AccessType.FIELD.getType() ) ) {
            if ( prop.isAnnotationPresent( JoinColumn.class )
                && prop.getAnnotation( JoinColumn.class ).name().equals( columnName )
                && !prop.isAnnotationPresent( MapsId.class ) ) {
              //create a PropertyData fpr the specJ property holding the mapping
              PropertyData specJPropertyData = new PropertyInferredData(
                  declaringClass,  //same dec
                  prop, // the actual @XToOne property
                  propertyAccessor, //TODO we should get the right accessor but the same as id would do
                  mappings.getReflectionManager()
              );
              mappings.addPropertyAnnotatedWithMapsIdSpecj( entity, specJPropertyData, element.toString() );
            }
          }
        }
      }

      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      /**
       * The property must be put in hibernate.properties as it's a system wide property. Fixable?
       * TODO support true/false/default on the property instead of present / not present
       * TODO is @Column mandatory?
       * TODO add method support
       */
      if ( mappings.isSpecjProprietarySyntaxEnabled() ) {
        if ( element.isAnnotationPresent( Id.class ) && element.isAnnotationPresent( Column.class ) ) {
          String columnName = element.getAnnotation( Column.class ).name();
          for ( XProperty prop : declaringClass.getDeclaredProperties( AccessType.FIELD.getType() ) ) {
            if ( !prop.isAnnotationPresent( MapsId.class ) ) {
              /**
               * The detection of a configured individual JoinColumn differs between Annotation
               * and XML configuration processing.
               */
              boolean isRequiredAnnotationPresent = false;
              JoinColumns groupAnnotation = prop.getAnnotation( JoinColumns.class );
              if ( (prop.isAnnotationPresent( JoinColumn.class )
                  && prop.getAnnotation( JoinColumn.class ).name().equals( columnName )) ) {
                isRequiredAnnotationPresent = true;
              }
              else if ( prop.isAnnotationPresent( JoinColumns.class ) ) {
                for ( JoinColumn columnAnnotation : groupAnnotation.value() ) {
                  if ( columnName.equals( columnAnnotation.name() ) ) {
                    isRequiredAnnotationPresent = true;
                    break;
                  }
                }
              }
              if ( isRequiredAnnotationPresent ) {
                //create a PropertyData fpr the specJ property holding the mapping
                PropertyData specJPropertyData = new PropertyInferredData(
                    declaringClass,
                    //same dec
                    prop,
                    // the actual @XToOne property
                    propertyAccessor,
                    //TODO we should get the right accessor but the same as id would do
                    mappings.getReflectionManager()
                );
                mappings.addPropertyAnnotatedWithMapsIdSpecj(
                    entity,
                    specJPropertyData,
                    element.toString()
                );
              }
            }
          }
        }
      }

      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      /**
       * The property must be put in hibernate.properties as it's a system wide property. Fixable?
       * TODO support true/false/default on the property instead of present / not present
       * TODO is @Column mandatory?
       * TODO add method support
       */
      if ( mappings.isSpecjProprietarySyntaxEnabled() ) {
        if ( element.isAnnotationPresent( Id.class ) && element.isAnnotationPresent( Column.class ) ) {
          String columnName = element.getAnnotation( Column.class ).name();
          for ( XProperty prop : declaringClass.getDeclaredProperties( AccessType.FIELD.getType() ) ) {
            if ( prop.isAnnotationPresent( JoinColumn.class )
                && prop.getAnnotation( JoinColumn.class ).name().equals( columnName )
                && !prop.isAnnotationPresent( MapsId.class ) ) {
              //create a PropertyData fpr the specJ property holding the mapping
              PropertyData specJPropertyData = new PropertyInferredData(
                  declaringClass,  //same dec
                  prop, // the actual @XToOne property
                  propertyAccessor, //TODO we should get the right accessor but the same as id would do
                  mappings.getReflectionManager()
              );
              mappings.addPropertyAnnotatedWithMapsIdSpecj( entity, specJPropertyData, element.toString() );
            }
          }
        }
      }

      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      /**
       * The property must be put in hibernate.properties as it's a system wide property. Fixable?
       * TODO support true/false/default on the property instead of present / not present
       * TODO is @Column mandatory?
       * TODO add method support
       */
      if ( mappings.isSpecjProprietarySyntaxEnabled() ) {
        if ( element.isAnnotationPresent( Id.class ) && element.isAnnotationPresent( Column.class ) ) {
          String columnName = element.getAnnotation( Column.class ).name();
          for ( XProperty prop : declaringClass.getDeclaredProperties( AccessType.FIELD.getType() ) ) {
            if ( prop.isAnnotationPresent( JoinColumn.class )
                && prop.getAnnotation( JoinColumn.class ).name().equals( columnName )
                && !prop.isAnnotationPresent( MapsId.class ) ) {
              //create a PropertyData fpr the specJ property holding the mapping
              PropertyData specJPropertyData = new PropertyInferredData(
                  declaringClass,  //same dec
                  prop, // the actual @XToOne property
                  propertyAccessor, //TODO we should get the right accessor but the same as id would do
                  mappings.getReflectionManager()
              );
              mappings.addPropertyAnnotatedWithMapsIdSpecj( entity, specJPropertyData, element.toString() );
            }
          }
        }
      }

      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

      throw new AnnotationException(
          "Annotated class should have a @javax.persistence.Entity, @javax.persistence.Embeddable or @javax.persistence.EmbeddedSuperclass annotation: " + clazzToProcess
              .getName()
      );
    }
    XAnnotatedElement annotatedClass = clazzToProcess;
    log.info( "Binding entity from annotated class: {}", clazzToProcess.getName() );
    final ReflectionManager reflectionManager = mappings.getReflectionManager();
    InheritanceState superEntityState =
        InheritanceState.getSuperEntityInheritanceState(
            clazzToProcess, inheritanceStatePerClass, reflectionManager
        );
    PersistentClass superEntity = superEntityState != null ?
        mappings.getClass(
            superEntityState.clazz.getName()
        ) :
        null;
    if ( superEntity == null ) {
      //check if superclass is not a potential persistent class
      if ( inheritanceState.hasParents ) {
        throw new AssertionFailure(
            "Subclass has to be binded after it's mother class: "
                + superEntityState.clazz.getName()
        );
      }
    }
    bindQueries( annotatedClass, mappings );
    bindFilterDefs( annotatedClass, mappings );
    bindTypeDefs( annotatedClass, mappings );
    BinderHelper.bindAnyMetaDefs( annotatedClass, mappings );

    String schema = "";
    String table = ""; //might be no @Table annotation on the annotated class
    String catalog = "";
    String discrimValue = null;
    List<String[]> uniqueConstraints = new ArrayList<String[]>();
    Ejb3DiscriminatorColumn discriminatorColumn = null;
    Ejb3JoinColumn[] inheritanceJoinedColumns = null;

    if ( annotatedClass.isAnnotationPresent( javax.persistence.Table.class ) ) {
      javax.persistence.Table tabAnn = annotatedClass.getAnnotation( javax.persistence.Table.class );
      table = tabAnn.name();
      schema = tabAnn.schema();
      catalog = tabAnn.catalog();
      uniqueConstraints = TableBinder.buildUniqueConstraints( tabAnn.uniqueConstraints() );
    }
    final boolean hasJoinedColumns = inheritanceState.hasParents
        && InheritanceType.JOINED.equals( inheritanceState.type );
    if ( hasJoinedColumns ) {
      //@Inheritance(JOINED) subclass need to link back to the super entity
      PrimaryKeyJoinColumns jcsAnn = annotatedClass.getAnnotation( PrimaryKeyJoinColumns.class );
      boolean explicitInheritanceJoinedColumns = jcsAnn != null && jcsAnn.value().length != 0;
      if ( explicitInheritanceJoinedColumns ) {
        int nbrOfInhJoinedColumns = jcsAnn.value().length;
        PrimaryKeyJoinColumn jcAnn;
        inheritanceJoinedColumns = new Ejb3JoinColumn[nbrOfInhJoinedColumns];
        for (int colIndex = 0; colIndex < nbrOfInhJoinedColumns; colIndex++) {
          jcAnn = jcsAnn.value()[colIndex];
          inheritanceJoinedColumns[colIndex] = Ejb3JoinColumn.buildJoinColumn(
              jcAnn, null, superEntity.getIdentifier(),
              (Map<String, Join>) null, (PropertyHolder) null, mappings
          );
        }
      }
      else {
        PrimaryKeyJoinColumn jcAnn = annotatedClass.getAnnotation( PrimaryKeyJoinColumn.class );
        inheritanceJoinedColumns = new Ejb3JoinColumn[1];
        inheritanceJoinedColumns[0] = Ejb3JoinColumn.buildJoinColumn(
            jcAnn, null, superEntity.getIdentifier(),
            (Map<String, Join>) null, (PropertyHolder) null, mappings
        );
      }
      log.debug( "Subclass joined column(s) created" );
    }
    else {
      if ( annotatedClass.isAnnotationPresent( javax.persistence.PrimaryKeyJoinColumns.class )
          || annotatedClass.isAnnotationPresent( javax.persistence.PrimaryKeyJoinColumn.class ) ) {
        log.warn( "Root entity should not hold an PrimaryKeyJoinColum(s), will be ignored" );
      }
    }

    if ( InheritanceType.SINGLE_TABLE.equals( inheritanceState.type ) ) {
      javax.persistence.DiscriminatorColumn discAnn = annotatedClass.getAnnotation(
          javax.persistence.DiscriminatorColumn.class
      );
      DiscriminatorType discriminatorType = discAnn != null ?
          discAnn.discriminatorType() :
          DiscriminatorType.STRING;

      org.hibernate.annotations.DiscriminatorFormula discFormulaAnn = annotatedClass.getAnnotation(
          org.hibernate.annotations.DiscriminatorFormula.class
      );
      if ( !inheritanceState.hasParents ) {
        discriminatorColumn = Ejb3DiscriminatorColumn.buildDiscriminatorColumn(
            discriminatorType, discAnn, discFormulaAnn, mappings
        );
      }
      if ( discAnn != null && inheritanceState.hasParents ) {
        log.warn(
            "Discriminator column has to be defined in the root entity, it will be ignored in subclass: {}",
            clazzToProcess.getName()
        );
      }
      discrimValue = annotatedClass.isAnnotationPresent( DiscriminatorValue.class ) ?
          annotatedClass.getAnnotation( DiscriminatorValue.class ).value() :
          null;
    }

    //we now know what kind of persistent entity it is
    PersistentClass persistentClass;
    //create persistent class
    if ( !inheritanceState.hasParents ) {
      persistentClass = new RootClass();
    }
    else if ( InheritanceType.SINGLE_TABLE.equals( inheritanceState.type ) ) {
      persistentClass = new SingleTableSubclass( superEntity );
    }
    else if ( InheritanceType.JOINED.equals( inheritanceState.type ) ) {
      persistentClass = new JoinedSubclass( superEntity );
    }
    else if ( InheritanceType.TABLE_PER_CLASS.equals( inheritanceState.type ) ) {
      persistentClass = new UnionSubclass( superEntity );
    }
    else {
      throw new AssertionFailure( "Unknown inheritance type: " + inheritanceState.type );
    }
    Proxy proxyAnn = annotatedClass.getAnnotation( Proxy.class );
    BatchSize sizeAnn = annotatedClass.getAnnotation( BatchSize.class );
    Where whereAnn = annotatedClass.getAnnotation( Where.class );
    Entity entityAnn = annotatedClass.getAnnotation( Entity.class );
    org.hibernate.annotations.Entity hibEntityAnn = annotatedClass.getAnnotation(
        org.hibernate.annotations.Entity.class
    );
    org.hibernate.annotations.Cache cacheAnn = annotatedClass.getAnnotation(
        org.hibernate.annotations.Cache.class
    );
    EntityBinder entityBinder = new EntityBinder(
        entityAnn, hibEntityAnn, clazzToProcess, persistentClass, mappings
    );
    entityBinder.setDiscriminatorValue( discrimValue );
    entityBinder.setBatchSize( sizeAnn );
    entityBinder.setProxy( proxyAnn );
    entityBinder.setWhere( whereAnn );
    entityBinder.setCache( cacheAnn );
    entityBinder.setInheritanceState( inheritanceState );
   
    //Filters are not allowed on subclasses
    if ( !inheritanceState.hasParents ) {
      bindFilters(clazzToProcess, entityBinder, mappings);
    }
   
    entityBinder.bindEntity();

    if ( inheritanceState.hasTable() ) {
      Check checkAnn = annotatedClass.getAnnotation( Check.class );
      String constraints = checkAnn == null ?
          null :
          checkAnn.constraints();
      entityBinder.bindTable(
          schema, catalog, table, uniqueConstraints,
          constraints, inheritanceState.hasDenormalizedTable() ?
          superEntity.getTable() :
          null
      );
    }
    else {
      if ( annotatedClass.isAnnotationPresent( Table.class ) ) {
        log.warn( "Illegal use of @Table in a subclass of a SINGLE_TABLE hierarchy: " + clazzToProcess
            .getName() );
      }
    }
//    Map<String, Column[]> columnOverride = PropertyHolderBuilder.buildHierarchyColumnOverride(
//        clazzToProcess,
//        persistentClass.getClassName()
//    );
    PropertyHolder propertyHolder = PropertyHolderBuilder.buildPropertyHolder(
        clazzToProcess,
        persistentClass,
        entityBinder, mappings, inheritanceStatePerClass
    );

    javax.persistence.SecondaryTable secTabAnn = annotatedClass.getAnnotation(
        javax.persistence.SecondaryTable.class
    );
    javax.persistence.SecondaryTables secTabsAnn = annotatedClass.getAnnotation(
        javax.persistence.SecondaryTables.class
    );
    entityBinder.firstLevelSecondaryTablesBinding( secTabAnn, secTabsAnn );

    OnDelete onDeleteAnn = annotatedClass.getAnnotation( OnDelete.class );
    boolean onDeleteAppropriate = false;
    if ( InheritanceType.JOINED.equals( inheritanceState.type ) && inheritanceState.hasParents ) {
      onDeleteAppropriate = true;
      final JoinedSubclass jsc = (JoinedSubclass) persistentClass;
      if ( persistentClass.getEntityPersisterClass() == null ) {
        persistentClass.getRootClass().setEntityPersisterClass( JoinedSubclassEntityPersister.class );
      }
      SimpleValue key = new DependantValue( jsc.getTable(), jsc.getIdentifier() );
      jsc.setKey( key );
      ForeignKey fk = annotatedClass.getAnnotation( ForeignKey.class );
      if ( fk != null && !BinderHelper.isDefault( fk.name() ) ) {
        key.setForeignKeyName( fk.name() );
      }
      if ( onDeleteAnn != null ) {
        key.setCascadeDeleteEnabled( OnDeleteAction.CASCADE.equals( onDeleteAnn.action() ) );
      }
      else {
        key.setCascadeDeleteEnabled( false );
      }
      //we are never in a second pass at that stage, so queue it
      SecondPass sp = new JoinedSubclassFkSecondPass( jsc, inheritanceJoinedColumns, key, mappings );
      mappings.addSecondPass( sp );
      mappings.addSecondPass( new CreateKeySecondPass( jsc ) );

    }
    else if ( InheritanceType.SINGLE_TABLE.equals( inheritanceState.type ) ) {
      if ( inheritanceState.hasParents ) {
        if ( persistentClass.getEntityPersisterClass() == null ) {
          persistentClass.getRootClass().setEntityPersisterClass( SingleTableEntityPersister.class );
        }
      }
      else {
        if ( inheritanceState.hasSons || !discriminatorColumn.isImplicit() ) {
          //need a discriminator column
          bindDiscriminatorToPersistentClass(
              (RootClass) persistentClass,
              discriminatorColumn,
              entityBinder.getSecondaryTables(),
              propertyHolder
          );
          entityBinder.bindDiscriminatorValue();//bind it again since the type might have changed
        }
      }
    }
    else if ( InheritanceType.TABLE_PER_CLASS.equals( inheritanceState.type ) ) {
      if ( inheritanceState.hasParents ) {
        if ( persistentClass.getEntityPersisterClass() == null ) {
          persistentClass.getRootClass().setEntityPersisterClass( UnionSubclassEntityPersister.class );
        }
      }
    }
    if ( onDeleteAnn != null && !onDeleteAppropriate ) {
      log.warn(
          "Inapropriate use of @OnDelete on entity, annotation ignored: {}", propertyHolder.getEntityName()
      );
    }

    //try to find class level generators
    HashMap<String, IdGenerator> classGenerators = buildLocalGenerators( annotatedClass, mappings );

    // check properties
    List<PropertyData> elements =
        getElementsToProcess(
            persistentClass, clazzToProcess, inheritanceStatePerClass, propertyHolder, entityBinder, mappings
        );
    if ( elements == null ) {
      throw new AnnotationException( "No identifier specified for entity: " + propertyHolder.getEntityName() );
    }
    final boolean subclassAndSingleTableStrategy = inheritanceState.type == InheritanceType.SINGLE_TABLE
        && inheritanceState.hasParents;
    //process idclass if any
    Set<String> idProperties = new HashSet<String>();
    IdClass idClass = null;
    XClass current = null;
    if ( !inheritanceState.hasParents ) {
      //look for idClass
      current = inheritanceState.clazz;
      InheritanceState state = inheritanceState;
      do {
        current = state.clazz;
        if ( current.isAnnotationPresent( IdClass.class ) ) {
          idClass = current.getAnnotation( IdClass.class );
          break;
        }
        state = InheritanceState.getSuperclassInheritanceState(
            current, inheritanceStatePerClass, reflectionManager
        );
      }
      while ( state != null );
    }
    if ( idClass != null ) {
      XClass compositeClass = reflectionManager.toXClass( idClass.value() );
      boolean isComponent = true;
      boolean propertyAnnotated = entityBinder.isPropertyAnnotated( compositeClass );
      String propertyAccessor = entityBinder.getPropertyAccessor( compositeClass );
      String generatorType = "assigned";
      String generator = BinderHelper.ANNOTATION_STRING_DEFAULT;
      PropertyData inferredData = new PropertyPreloadedData(
          entityBinder.getPropertyAccessor(), "id", compositeClass
      );
      PropertyData baseInferredData = new PropertyPreloadedData(
                  entityBinder.getPropertyAccessor(), "id", current
            );
      HashMap<String, IdGenerator> localGenerators = new HashMap<String, IdGenerator>();
      boolean ignoreIdAnnotations = entityBinder.isIgnoreIdAnnotations();
      entityBinder.setIgnoreIdAnnotations( true );
      bindId(
          generatorType,
          generator,
          inferredData,
          baseInferredData,
          null,
          propertyHolder,
          localGenerators,
          isComponent,
          propertyAnnotated,
          propertyAccessor, entityBinder,
          true,
          false, mappings, inheritanceStatePerClass
      );
      inferredData = new PropertyPreloadedData(
          propertyAccessor, "_identifierMapper", compositeClass
      );
      Component mapper = fillComponent(
          propertyHolder,
          inferredData,
          baseInferredData,
          propertyAnnotated,
          propertyAccessor, false,
          entityBinder,
          true, true,
          false, mappings, inheritanceStatePerClass
      );
      entityBinder.setIgnoreIdAnnotations( ignoreIdAnnotations );
      persistentClass.setIdentifierMapper( mapper );

      //If id definition is on a mapped superclass, update the mapping
      final org.hibernate.mapping.MappedSuperclass superclass = BinderHelper.getMappedSuperclassOrNull(
          inferredData.getDeclaringClass(),
          inheritanceStatePerClass,
          mappings
      );
      if (superclass != null) {
        superclass.setDeclaredIdentifierMapper(mapper);
      }
      else {
        //we are for sure on the entity
        persistentClass.setDeclaredIdentifierMapper( mapper );
      }

      Property property = new Property();
      property.setName( "_identifierMapper" );
      property.setNodeName( "id" );
      property.setUpdateable( false );
      property.setInsertable( false );
      property.setValue( mapper );
      property.setPropertyAccessorName( "embedded" );
      persistentClass.addProperty( property );
      entityBinder.setIgnoreIdAnnotations( true );

      Iterator properties = mapper.getPropertyIterator();
      while ( properties.hasNext() ) {
        idProperties.add( ( (Property) properties.next() ).getName() );
      }
    }
    Set<String> missingIdProperties = new HashSet<String>( idProperties );
    for (PropertyData propertyAnnotatedElement : elements) {
      String propertyName = propertyAnnotatedElement.getPropertyName();
      if ( !idProperties.contains( propertyName ) ) {
        processElementAnnotations(
            propertyHolder,
            subclassAndSingleTableStrategy ?
                Nullability.FORCED_NULL :
                Nullability.NO_CONSTRAINT,
            propertyAnnotatedElement.getProperty(),
            propertyAnnotatedElement, classGenerators, entityBinder,
            false, false, false, mappings, inheritanceStatePerClass
        );
      }
      else {
        missingIdProperties.remove( propertyName );
      }
    }

    if ( missingIdProperties.size() != 0 ) {
      StringBuilder missings = new StringBuilder();
      for (String property : missingIdProperties) {
        missings.append( property ).append( ", " );
      }
      throw new AnnotationException(
          "Unable to find properties ("
              + missings.substring( 0, missings.length() - 2 )
              + ") in entity annotated with @IdClass:" + persistentClass.getEntityName()
      );
    }

    if ( !inheritanceState.hasParents ) {
      final RootClass rootClass = (RootClass) persistentClass;
      mappings.addSecondPass( new CreateKeySecondPass( rootClass ) );
    }
    else {
      superEntity.addSubclass( (Subclass) persistentClass );
    }

    mappings.addClass( persistentClass );

    //Process secondary tables and complementary definitions (ie o.h.a.Table)
    mappings.addSecondPass( new SecondaryTableSecondPass( entityBinder, propertyHolder, annotatedClass ) );

    //add process complementary Table definition (index & all)
    entityBinder.processComplementaryTableDefinitions( annotatedClass.getAnnotation( org.hibernate.annotations.Table.class ) );
    entityBinder.processComplementaryTableDefinitions( annotatedClass.getAnnotation( org.hibernate.annotations.Tables.class ) );

  }
View Full Code Here

Examples of org.hibernate.annotations.common.reflection.XAnnotatedElement

    /*
     * put element annotated by @Id in front
     * since it has to be parsed before any association by Hibernate
     */
    final XAnnotatedElement element = propertyAnnotatedElement.getProperty();
    if ( element.isAnnotationPresent( Id.class ) || element.isAnnotationPresent( EmbeddedId.class ) ) {
      annElts.add( 0, propertyAnnotatedElement );
      /**
       * The property must be put in hibernate.properties as it's a system wide property. Fixable?
       * TODO support true/false/default on the property instead of present / not present
       * TODO is @Column mandatory?
       * TODO add method support
       */
      if ( mappings.isSpecjProprietarySyntaxEnabled() ) {
        if ( element.isAnnotationPresent( Id.class ) && element.isAnnotationPresent( Column.class ) ) {
          String columnName = element.getAnnotation( Column.class ).name();
          for ( XProperty prop : declaringClass.getDeclaredProperties( AccessType.FIELD.getType() ) ) {
            if ( !prop.isAnnotationPresent( MapsId.class ) ) {
              /**
               * The detection of a configured individual JoinColumn differs between Annotation
               * and XML configuration processing.
               */
              boolean isRequiredAnnotationPresent = false;
              JoinColumns groupAnnotation = prop.getAnnotation( JoinColumns.class );
              if ( (prop.isAnnotationPresent( JoinColumn.class )
                  && prop.getAnnotation( JoinColumn.class ).name().equals( columnName )) ) {
                isRequiredAnnotationPresent = true;
              }
              else if ( prop.isAnnotationPresent( JoinColumns.class ) ) {
                for ( JoinColumn columnAnnotation : groupAnnotation.value() ) {
                  if ( columnName.equals( columnAnnotation.name() ) ) {
                    isRequiredAnnotationPresent = true;
                    break;
                  }
                }
              }
              if ( isRequiredAnnotationPresent ) {
                //create a PropertyData fpr the specJ property holding the mapping
                PropertyData specJPropertyData = new PropertyInferredData(
                    declaringClass,
                    //same dec
                    prop,
                    // the actual @XToOne property
                    propertyAccessor,
                    //TODO we should get the right accessor but the same as id would do
                    mappings.getReflectionManager()
                );
                mappings.addPropertyAnnotatedWithMapsIdSpecj(
                    entity,
                    specJPropertyData,
                    element.toString()
                );
              }
            }
          }
        }
      }

      if ( element.isAnnotationPresent( ManyToOne.class ) || element.isAnnotationPresent( OneToOne.class ) ) {
        mappings.addToOneAndIdProperty( entity, propertyAnnotatedElement );
      }
      idPropertyCounter++;
    }
    else {
      annElts.add( propertyAnnotatedElement );
    }
    if ( element.isAnnotationPresent( MapsId.class ) ) {
      mappings.addPropertyAnnotatedWithMapsId( entity, propertyAnnotatedElement );
    }

    return idPropertyCounter;
  }
View Full Code Here
TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.