blob: 8f2ca074e0686e9901c725437998113cb8088ad7 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2007, 2008 Oracle. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0, which accompanies this distribution
* and is available at http://www.eclipse.org/legal/epl-v10.html.
*
* Contributors:
* Oracle - initial API and implementation
******************************************************************************/
package org.eclipse.jpt.core.internal.context.java;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jpt.core.TextRange;
import org.eclipse.jpt.core.context.AbstractJoinColumn;
import org.eclipse.jpt.core.context.AttributeMapping;
import org.eclipse.jpt.core.context.Entity;
import org.eclipse.jpt.core.context.JoinColumn;
import org.eclipse.jpt.core.context.JoinTable;
import org.eclipse.jpt.core.context.NonOwningMapping;
import org.eclipse.jpt.core.context.PersistentAttribute;
import org.eclipse.jpt.core.context.RelationshipMapping;
import org.eclipse.jpt.core.context.TypeMapping;
import org.eclipse.jpt.core.context.java.JavaJoinColumn;
import org.eclipse.jpt.core.context.java.JavaJoinTable;
import org.eclipse.jpt.core.context.java.JavaRelationshipMapping;
import org.eclipse.jpt.core.internal.resource.java.NullJoinColumn;
import org.eclipse.jpt.core.internal.validation.DefaultJpaValidationMessages;
import org.eclipse.jpt.core.internal.validation.JpaValidationMessages;
import org.eclipse.jpt.core.resource.java.JavaResourcePersistentAttribute;
import org.eclipse.jpt.core.resource.java.JoinColumnAnnotation;
import org.eclipse.jpt.core.resource.java.JoinTableAnnotation;
import org.eclipse.jpt.utility.internal.CollectionTools;
import org.eclipse.jpt.utility.internal.Filter;
import org.eclipse.jpt.utility.internal.iterators.CloneListIterator;
import org.eclipse.jpt.utility.internal.iterators.EmptyListIterator;
import org.eclipse.jpt.utility.internal.iterators.SingleElementListIterator;
import org.eclipse.wst.validation.internal.provisional.core.IMessage;
public class GenericJavaJoinTable extends AbstractJavaTable implements JavaJoinTable
{
protected final List<JavaJoinColumn> specifiedJoinColumns;
protected JavaJoinColumn defaultJoinColumn;
protected final List<JavaJoinColumn> specifiedInverseJoinColumns;
protected JavaJoinColumn defaultInverseJoinColumn;
protected JavaResourcePersistentAttribute attributeResource;
public GenericJavaJoinTable(JavaRelationshipMapping parent) {
super(parent);
this.specifiedJoinColumns = new ArrayList<JavaJoinColumn>();
this.specifiedInverseJoinColumns = new ArrayList<JavaJoinColumn>();
}
@Override
public JavaRelationshipMapping parent() {
return (JavaRelationshipMapping) super.parent();
}
//******************* AbstractJavaTable implementation *****************
@Override
protected String annotationName() {
return JoinTableAnnotation.ANNOTATION_NAME;
}
/**
* Default join table name from the JPA spec:
* The concatenated names of the two associated primary
* entity tables, separated by a underscore.
*
* [owning table name]_[target table name]
*/
@Override
protected String defaultName() {
if (!relationshipMapping().isRelationshipOwner()) {
return null;
}
String owningTableName = relationshipMapping().typeMapping().tableName();
if (owningTableName == null) {
return null;
}
Entity targetEntity = relationshipMapping().getResolvedTargetEntity();
if (targetEntity == null) {
return null;
}
String targetTableName = targetEntity.tableName();
if (targetTableName == null) {
return null;
}
return owningTableName + "_" + targetTableName;
}
@Override
protected String defaultCatalog() {
if (!relationshipMapping().isRelationshipOwner()) {
return null;
}
return super.defaultCatalog();
}
@Override
protected String defaultSchema() {
if (!relationshipMapping().isRelationshipOwner()) {
return null;
}
return super.defaultSchema();
}
@Override
protected JoinTableAnnotation tableResource() {
return (JoinTableAnnotation) this.attributeResource.nonNullAnnotation(JoinTableAnnotation.ANNOTATION_NAME);
}
/**
* Return the join table java resource, null if the annotation does not exist.
* Use tableResource() if you want a non null implementation
*/
protected JoinTableAnnotation joinTableResource() {
return (JoinTableAnnotation) this.attributeResource.annotation(JoinTableAnnotation.ANNOTATION_NAME);
}
protected void addJoinTableResource() {
this.attributeResource.addAnnotation(JoinTableAnnotation.ANNOTATION_NAME);
}
//******************* IJoinTable implementation *****************
public ListIterator<JavaJoinColumn> joinColumns() {
return this.containsSpecifiedJoinColumns() ? this.specifiedJoinColumns() : this.defaultJoinColumns();
}
public int joinColumnsSize() {
return this.containsSpecifiedJoinColumns() ? this.specifiedJoinColumnsSize() : this.defaultJoinColumnsSize();
}
public JavaJoinColumn getDefaultJoinColumn() {
return this.defaultJoinColumn;
}
protected void setDefaultJoinColumn(JavaJoinColumn newJoinColumn) {
JavaJoinColumn oldJoinColumn = this.defaultJoinColumn;
this.defaultJoinColumn = newJoinColumn;
firePropertyChanged(JoinTable.DEFAULT_JOIN_COLUMN, oldJoinColumn, newJoinColumn);
}
protected ListIterator<JavaJoinColumn> defaultJoinColumns() {
if (this.defaultJoinColumn != null) {
return new SingleElementListIterator<JavaJoinColumn>(this.defaultJoinColumn);
}
return EmptyListIterator.instance();
}
protected int defaultJoinColumnsSize() {
return (this.defaultJoinColumn == null) ? 0 : 1;
}
public ListIterator<JavaJoinColumn> specifiedJoinColumns() {
return new CloneListIterator<JavaJoinColumn>(this.specifiedJoinColumns);
}
public int specifiedJoinColumnsSize() {
return this.specifiedJoinColumns.size();
}
public boolean containsSpecifiedJoinColumns() {
return !this.specifiedJoinColumns.isEmpty();
}
public JavaJoinColumn addSpecifiedJoinColumn(int index) {
JoinColumn oldDefaultJoinColumn = this.getDefaultJoinColumn();
if (oldDefaultJoinColumn != null) {
//null the default join column now if one already exists.
//if one does not exist, there is already a specified join column.
//Remove it now so that it doesn't get removed during an update and
//cause change notifications to be sent to the UI in the wrong order
this.defaultJoinColumn = null;
}
if (joinTableResource() == null) {
//Add the JoinTable before creating the specifiedJoinColumn.
//Otherwise we will remove it and create another during an update
//from the java resource model
addJoinTableResource();
}
JavaJoinColumn joinColumn = jpaFactory().buildJavaJoinColumn(this, createJoinColumnOwner());
this.specifiedJoinColumns.add(index, joinColumn);
JoinColumnAnnotation joinColumnResource = this.tableResource().addJoinColumn(index);
joinColumn.initializeFromResource(joinColumnResource);
this.fireItemAdded(JoinTable.SPECIFIED_JOIN_COLUMNS_LIST, index, joinColumn);
if (oldDefaultJoinColumn != null) {
this.firePropertyChanged(JoinTable.DEFAULT_JOIN_COLUMN, oldDefaultJoinColumn, null);
}
return joinColumn;
}
protected void addSpecifiedJoinColumn(int index, JavaJoinColumn joinColumn) {
addItemToList(index, joinColumn, this.specifiedJoinColumns, JoinTable.SPECIFIED_JOIN_COLUMNS_LIST);
}
public void removeSpecifiedJoinColumn(JoinColumn joinColumn) {
this.removeSpecifiedJoinColumn(this.specifiedJoinColumns.indexOf(joinColumn));
}
public void removeSpecifiedJoinColumn(int index) {
JavaJoinColumn removedJoinColumn = this.specifiedJoinColumns.remove(index);
if (!containsSpecifiedJoinColumns()) {
//create the defaultJoinColumn now or this will happen during project update
//after removing the join column from the resource model. That causes problems
//in the UI because the change notifications end up in the wrong order.
this.defaultJoinColumn = createJoinColumn(new NullJoinColumn(tableResource()));
}
this.tableResource().removeJoinColumn(index);
fireItemRemoved(JoinTable.SPECIFIED_JOIN_COLUMNS_LIST, index, removedJoinColumn);
if (this.defaultJoinColumn != null) {
//fire change notification if a defaultJoinColumn was created above
this.firePropertyChanged(JoinTable.DEFAULT_JOIN_COLUMN, null, this.defaultJoinColumn);
}
}
protected void removeSpecifiedJoinColumn_(JavaJoinColumn joinColumn) {
removeItemFromList(joinColumn, this.specifiedJoinColumns, JoinTable.SPECIFIED_JOIN_COLUMNS_LIST);
}
public void moveSpecifiedJoinColumn(int targetIndex, int sourceIndex) {
CollectionTools.move(this.specifiedJoinColumns, targetIndex, sourceIndex);
this.tableResource().moveJoinColumn(targetIndex, sourceIndex);
fireItemMoved(JoinTable.SPECIFIED_JOIN_COLUMNS_LIST, targetIndex, sourceIndex);
}
public ListIterator<JavaJoinColumn> inverseJoinColumns() {
return this.containsSpecifiedInverseJoinColumns() ? this.specifiedInverseJoinColumns() : this.defaultInverseJoinColumns();
}
public int inverseJoinColumnsSize() {
return this.containsSpecifiedInverseJoinColumns() ? this.specifiedInverseJoinColumnsSize() : this.defaultInverseJoinColumnsSize();
}
public JavaJoinColumn getDefaultInverseJoinColumn() {
return this.defaultInverseJoinColumn;
}
protected void setDefaultInverseJoinColumn(JavaJoinColumn newInverseJoinColumn) {
JavaJoinColumn oldInverseJoinColumn = this.defaultInverseJoinColumn;
this.defaultInverseJoinColumn = newInverseJoinColumn;
firePropertyChanged(JoinTable.DEFAULT_INVERSE_JOIN_COLUMN, oldInverseJoinColumn, newInverseJoinColumn);
}
protected ListIterator<JavaJoinColumn> defaultInverseJoinColumns() {
if (this.defaultInverseJoinColumn != null) {
return new SingleElementListIterator<JavaJoinColumn>(this.defaultInverseJoinColumn);
}
return EmptyListIterator.instance();
}
protected int defaultInverseJoinColumnsSize() {
return (this.defaultInverseJoinColumn == null) ? 0 : 1;
}
public ListIterator<JavaJoinColumn> specifiedInverseJoinColumns() {
return new CloneListIterator<JavaJoinColumn>(this.specifiedInverseJoinColumns);
}
public int specifiedInverseJoinColumnsSize() {
return this.specifiedInverseJoinColumns.size();
}
public boolean containsSpecifiedInverseJoinColumns() {
return !this.specifiedInverseJoinColumns.isEmpty();
}
public JavaJoinColumn addSpecifiedInverseJoinColumn(int index) {
JoinColumn oldDefaultInverseJoinColumn = this.getDefaultInverseJoinColumn();
if (oldDefaultInverseJoinColumn != null) {
//null the default join column now if one already exists.
//if one does not exist, there is already a specified join column.
//Remove it now so that it doesn't get removed during an update and
//cause change notifications to be sent to the UI in the wrong order
this.defaultInverseJoinColumn = null;
}
if (joinTableResource() == null) {
//Add the JoinTable before creating the specifiedJoinColumn.
//Otherwise we will remove it and create another during an update
//from the java resource model
addJoinTableResource();
}
JavaJoinColumn inverseJoinColumn = jpaFactory().buildJavaJoinColumn(this, createInverseJoinColumnOwner());
this.specifiedInverseJoinColumns.add(index, inverseJoinColumn);
JoinColumnAnnotation joinColumnResource = this.tableResource().addInverseJoinColumn(index);
inverseJoinColumn.initializeFromResource(joinColumnResource);
this.fireItemAdded(JoinTable.SPECIFIED_INVERSE_JOIN_COLUMNS_LIST, index, inverseJoinColumn);
if (oldDefaultInverseJoinColumn != null) {
this.firePropertyChanged(JoinTable.DEFAULT_INVERSE_JOIN_COLUMN, oldDefaultInverseJoinColumn, null);
}
return inverseJoinColumn;
}
protected void addSpecifiedInverseJoinColumn(int index, JavaJoinColumn inverseJoinColumn) {
addItemToList(index, inverseJoinColumn, this.specifiedInverseJoinColumns, JoinTable.SPECIFIED_INVERSE_JOIN_COLUMNS_LIST);
}
public void removeSpecifiedInverseJoinColumn(JoinColumn inverseJoinColumn) {
this.removeSpecifiedInverseJoinColumn(this.specifiedInverseJoinColumns.indexOf(inverseJoinColumn));
}
public void removeSpecifiedInverseJoinColumn(int index) {
JavaJoinColumn removedJoinColumn = this.specifiedInverseJoinColumns.remove(index);
if (!containsSpecifiedInverseJoinColumns()) {
//create the defaultJoinColumn now or this will happen during project update
//after removing the join column from the resource model. That causes problems
//in the UI because the change notifications end up in the wrong order.
this.defaultInverseJoinColumn = createInverseJoinColumn(new NullJoinColumn(tableResource()));
}
this.tableResource().removeInverseJoinColumn(index);
fireItemRemoved(JoinTable.SPECIFIED_INVERSE_JOIN_COLUMNS_LIST, index, removedJoinColumn);
if (this.defaultInverseJoinColumn != null) {
//fire change notification if a defaultJoinColumn was created above
this.firePropertyChanged(JoinTable.DEFAULT_INVERSE_JOIN_COLUMN, null, this.defaultInverseJoinColumn);
}
}
protected void removeSpecifiedInverseJoinColumn_(JavaJoinColumn joinColumn) {
removeItemFromList(joinColumn, this.specifiedInverseJoinColumns, JoinTable.SPECIFIED_INVERSE_JOIN_COLUMNS_LIST);
}
public void moveSpecifiedInverseJoinColumn(int targetIndex, int sourceIndex) {
CollectionTools.move(this.specifiedInverseJoinColumns, targetIndex, sourceIndex);
this.tableResource().moveInverseJoinColumn(targetIndex, sourceIndex);
fireItemMoved(JoinTable.SPECIFIED_INVERSE_JOIN_COLUMNS_LIST, targetIndex, sourceIndex);
}
public RelationshipMapping relationshipMapping() {
return (RelationshipMapping) this.parent();
}
public boolean isSpecified() {
return joinTableResource() != null;
}
@Override
public Iterator<String> javaCompletionProposals(int pos, Filter<String> filter, CompilationUnit astRoot) {
Iterator<String> result = super.javaCompletionProposals(pos, filter, astRoot);
if (result != null) {
return result;
}
for (JavaJoinColumn column : CollectionTools.iterable(this.joinColumns())) {
result = column.javaCompletionProposals(pos, filter, astRoot);
if (result != null) {
return result;
}
}
for (JavaJoinColumn column : CollectionTools.iterable(this.inverseJoinColumns())) {
result = column.javaCompletionProposals(pos, filter, astRoot);
if (result != null) {
return result;
}
}
return null;
}
protected JavaJoinColumn.Owner createJoinColumnOwner() {
return new JoinColumnOwner();
}
protected JavaJoinColumn.Owner createInverseJoinColumnOwner() {
return new InverseJoinColumnOwner();
}
public void initializeFromResource(JavaResourcePersistentAttribute attributeResource) {
this.attributeResource = attributeResource;
JoinTableAnnotation joinTable = tableResource();
this.initializeFromResource(joinTable);
this.initializeSpecifiedJoinColumns(joinTable);
this.initializeDefaultJoinColumn(joinTable);
this.initializeSpecifiedInverseJoinColumns(joinTable);
this.initializeDefaultInverseJoinColumn(joinTable);
}
protected void initializeSpecifiedJoinColumns(JoinTableAnnotation joinTableResource) {
ListIterator<JoinColumnAnnotation> annotations = joinTableResource.joinColumns();
while(annotations.hasNext()) {
this.specifiedJoinColumns.add(createJoinColumn(annotations.next()));
}
}
protected boolean shouldBuildDefaultJoinColumn() {
return !containsSpecifiedJoinColumns() && relationshipMapping().isRelationshipOwner();
}
protected void initializeDefaultJoinColumn(JoinTableAnnotation joinTable) {
if (!shouldBuildDefaultJoinColumn()) {
return;
}
this.defaultJoinColumn = this.jpaFactory().buildJavaJoinColumn(this, createJoinColumnOwner());
this.defaultJoinColumn.initializeFromResource(new NullJoinColumn(joinTable));
}
protected void initializeSpecifiedInverseJoinColumns(JoinTableAnnotation joinTableResource) {
ListIterator<JoinColumnAnnotation> annotations = joinTableResource.inverseJoinColumns();
while(annotations.hasNext()) {
this.specifiedInverseJoinColumns.add(createInverseJoinColumn(annotations.next()));
}
}
protected boolean shouldBuildDefaultInverseJoinColumn() {
return !containsSpecifiedInverseJoinColumns() && relationshipMapping().isRelationshipOwner();
}
protected void initializeDefaultInverseJoinColumn(JoinTableAnnotation joinTable) {
if (!shouldBuildDefaultInverseJoinColumn()) {
return;
}
this.defaultInverseJoinColumn = this.jpaFactory().buildJavaJoinColumn(this, createInverseJoinColumnOwner());
this.defaultInverseJoinColumn.initializeFromResource(new NullJoinColumn(joinTable));
}
public void update(JavaResourcePersistentAttribute attributeResource) {
this.attributeResource = attributeResource;
JoinTableAnnotation joinTable = tableResource();
this.update(joinTable);
this.updateSpecifiedJoinColumns(joinTable);
this.updateDefaultJoinColumn(joinTable);
this.updateSpecifiedInverseJoinColumns(joinTable);
this.updateDefaultInverseJoinColumn(joinTable);
}
protected void updateSpecifiedJoinColumns(JoinTableAnnotation joinTableResource) {
ListIterator<JavaJoinColumn> joinColumns = specifiedJoinColumns();
ListIterator<JoinColumnAnnotation> resourceJoinColumns = joinTableResource.joinColumns();
while (joinColumns.hasNext()) {
JavaJoinColumn joinColumn = joinColumns.next();
if (resourceJoinColumns.hasNext()) {
joinColumn.update(resourceJoinColumns.next());
}
else {
removeSpecifiedJoinColumn_(joinColumn);
}
}
while (resourceJoinColumns.hasNext()) {
addSpecifiedJoinColumn(specifiedJoinColumnsSize(), createJoinColumn(resourceJoinColumns.next()));
}
}
protected void updateDefaultJoinColumn(JoinTableAnnotation joinTable) {
if (!shouldBuildDefaultJoinColumn()) {
setDefaultJoinColumn(null);
return;
}
if (getDefaultJoinColumn() == null) {
JoinColumnAnnotation joinColumnResource = new NullJoinColumn(joinTable);
this.setDefaultJoinColumn(createJoinColumn(joinColumnResource));
}
else {
this.defaultJoinColumn.update(new NullJoinColumn(joinTable));
}
}
protected void updateSpecifiedInverseJoinColumns(JoinTableAnnotation joinTableResource) {
ListIterator<JavaJoinColumn> joinColumns = specifiedInverseJoinColumns();
ListIterator<JoinColumnAnnotation> resourceJoinColumns = joinTableResource.inverseJoinColumns();
while (joinColumns.hasNext()) {
JavaJoinColumn joinColumn = joinColumns.next();
if (resourceJoinColumns.hasNext()) {
joinColumn.update(resourceJoinColumns.next());
}
else {
removeSpecifiedInverseJoinColumn_(joinColumn);
}
}
while (resourceJoinColumns.hasNext()) {
addSpecifiedInverseJoinColumn(specifiedInverseJoinColumnsSize(), createInverseJoinColumn(resourceJoinColumns.next()));
}
}
protected void updateDefaultInverseJoinColumn(JoinTableAnnotation joinTable) {
if (!shouldBuildDefaultInverseJoinColumn()) {
setDefaultInverseJoinColumn(null);
return;
}
if (getDefaultInverseJoinColumn() == null) {
JoinColumnAnnotation joinColumnResource = new NullJoinColumn(joinTable);
this.setDefaultInverseJoinColumn(createInverseJoinColumn(joinColumnResource));
}
else {
this.defaultInverseJoinColumn.update(new NullJoinColumn(joinTable));
}
}
protected JavaJoinColumn createJoinColumn(JoinColumnAnnotation joinColumnResource) {
JavaJoinColumn joinColumn = jpaFactory().buildJavaJoinColumn(this, createJoinColumnOwner());
joinColumn.initializeFromResource(joinColumnResource);
return joinColumn;
}
protected JavaJoinColumn createInverseJoinColumn(JoinColumnAnnotation joinColumnResource) {
JavaJoinColumn joinColumn = jpaFactory().buildJavaJoinColumn(this, createInverseJoinColumnOwner());
joinColumn.initializeFromResource(joinColumnResource);
return joinColumn;
}
@Override
public void addToMessages(List<IMessage> messages, CompilationUnit astRoot) {
super.addToMessages(messages, astRoot);
boolean doContinue = isConnected();
String schema = getSchema();
if (doContinue && ! hasResolvedSchema()) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_TABLE_UNRESOLVED_SCHEMA,
new String[] {schema, getName()},
this,
schemaTextRange(astRoot))
);
doContinue = false;
}
if (doContinue && !isResolved()) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_TABLE_UNRESOLVED_NAME,
new String[] {getName()},
this,
nameTextRange(astRoot))
);
doContinue = false;
}
for (Iterator<JavaJoinColumn> stream = joinColumns(); stream.hasNext(); ) {
JavaJoinColumn joinColumn = stream.next();
if (doContinue && ! joinColumn.isResolved()) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_UNRESOLVED_NAME,
new String[] {joinColumn.getName()},
joinColumn, joinColumn.nameTextRange(astRoot))
);
}
if (doContinue && ! joinColumn.isReferencedColumnResolved()) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_REFERENCED_COLUMN_UNRESOLVED_NAME,
new String[] {joinColumn.getReferencedColumnName(), joinColumn.getName()},
joinColumn, joinColumn.referencedColumnNameTextRange(astRoot))
);
}
}
for (Iterator<JavaJoinColumn> stream = inverseJoinColumns(); stream.hasNext(); ) {
JavaJoinColumn joinColumn = stream.next();
if (doContinue && ! joinColumn.isResolved()) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_UNRESOLVED_NAME,
new String[] {joinColumn.getName()},
joinColumn, joinColumn.nameTextRange(astRoot))
);
}
if (doContinue && ! joinColumn.isReferencedColumnResolved()) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_REFERENCED_COLUMN_UNRESOLVED_NAME,
new String[] {joinColumn.getReferencedColumnName(), joinColumn.getName()},
joinColumn, joinColumn.referencedColumnNameTextRange(astRoot))
);
}
}
}
/**
* just a little common behavior
*/
abstract class AbstractJoinColumnOwner implements JavaJoinColumn.Owner
{
AbstractJoinColumnOwner() {
super();
}
public TypeMapping typeMapping() {
return relationshipMapping().typeMapping();
}
public RelationshipMapping relationshipMapping() {
return GenericJavaJoinTable.this.relationshipMapping();
}
/**
* the default table name is always valid and a specified table name
* is prohibited (which will be handled elsewhere)
*/
public boolean tableNameIsInvalid(String tableName) {
return false;
}
/**
* the join column can only be on the join table itself
*/
public boolean tableIsAllowed() {
return false;
}
public org.eclipse.jpt.db.internal.Table dbTable(String tableName) {
if (GenericJavaJoinTable.this.getName() == null) {
return null;
}
return (GenericJavaJoinTable.this.getName().equals(tableName)) ? GenericJavaJoinTable.this.dbTable() : null;
}
/**
* by default, the join column is, obviously, in the join table;
* not sure whether it can be anywhere else...
*/
public String defaultTableName() {
return GenericJavaJoinTable.this.getName();
}
public TextRange validationTextRange(CompilationUnit astRoot) {
return GenericJavaJoinTable.this.validationTextRange(astRoot);
}
}
/**
* owner for "forward-pointer" JoinColumns;
* these point at the target/inverse entity
*/
class InverseJoinColumnOwner extends AbstractJoinColumnOwner
{
public InverseJoinColumnOwner() {
super();
}
public Entity targetEntity() {
return GenericJavaJoinTable.this.relationshipMapping().getResolvedTargetEntity();
}
public String attributeName() {
return GenericJavaJoinTable.this.relationshipMapping().persistentAttribute().getName();
}
@Override
public org.eclipse.jpt.db.internal.Table dbTable(String tableName) {
org.eclipse.jpt.db.internal.Table dbTable = super.dbTable(tableName);
if (dbTable != null) {
return dbTable;
}
Entity targetEntity = targetEntity();
return (targetEntity == null) ? null : targetEntity.dbTable(tableName);
}
public org.eclipse.jpt.db.internal.Table dbReferencedColumnTable() {
Entity targetEntity = targetEntity();
return (targetEntity == null) ? null : targetEntity.primaryDbTable();
}
public boolean isVirtual(AbstractJoinColumn joinColumn) {
return GenericJavaJoinTable.this.defaultInverseJoinColumn == joinColumn;
}
public String defaultColumnName() {
// TODO Auto-generated method stub
return null;
}
public int joinColumnsSize() {
return GenericJavaJoinTable.this.inverseJoinColumnsSize();
}
}
/**
* owner for "back-pointer" JoinColumns;
* these point at the source/owning entity
*/
class JoinColumnOwner extends AbstractJoinColumnOwner
{
public JoinColumnOwner() {
super();
}
public Entity targetEntity() {
return GenericJavaJoinTable.this.relationshipMapping().getEntity();
}
public String attributeName() {
Entity targetEntity = GenericJavaJoinTable.this.relationshipMapping().getResolvedTargetEntity();
if (targetEntity == null) {
return null;
}
String attributeName = GenericJavaJoinTable.this.relationshipMapping().persistentAttribute().getName();
for (Iterator<PersistentAttribute> stream = targetEntity.persistentType().allAttributes(); stream.hasNext();) {
PersistentAttribute attribute = stream.next();
AttributeMapping mapping = attribute.getMapping();
if (mapping instanceof NonOwningMapping) {
String mappedBy = ((NonOwningMapping) mapping).getMappedBy();
if ((mappedBy != null) && mappedBy.equals(attributeName)) {
return attribute.getName();
}
}
}
return null;
}
@Override
public org.eclipse.jpt.db.internal.Table dbTable(String tableName) {
org.eclipse.jpt.db.internal.Table dbTable = super.dbTable(tableName);
if (dbTable != null) {
return dbTable;
}
return typeMapping().dbTable(tableName);
}
public org.eclipse.jpt.db.internal.Table dbReferencedColumnTable() {
return typeMapping().primaryDbTable();
}
public boolean isVirtual(AbstractJoinColumn joinColumn) {
return GenericJavaJoinTable.this.defaultJoinColumn == joinColumn;
}
public String defaultColumnName() {
// TODO Auto-generated method stub
return null;
}
public int joinColumnsSize() {
return GenericJavaJoinTable.this.joinColumnsSize();
}
}
}