blob: fe00f95b2ef480a7503babd16ca2f31c8b76e065 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2007, 2009 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.jpa1.context.java;
import java.util.Iterator;
import java.util.List;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jpt.core.context.BaseJoinColumn;
import org.eclipse.jpt.core.context.java.JavaJoinColumn;
import org.eclipse.jpt.core.context.java.JavaJpaContextNode;
import org.eclipse.jpt.core.internal.context.MappingTools;
import org.eclipse.jpt.core.internal.context.java.AbstractJavaBaseColumn;
import org.eclipse.jpt.core.internal.validation.DefaultJpaValidationMessages;
import org.eclipse.jpt.core.internal.validation.JpaValidationMessages;
import org.eclipse.jpt.core.resource.java.JoinColumnAnnotation;
import org.eclipse.jpt.core.utility.TextRange;
import org.eclipse.jpt.db.Column;
import org.eclipse.jpt.db.Table;
import org.eclipse.jpt.utility.Filter;
import org.eclipse.jpt.utility.internal.StringTools;
import org.eclipse.jpt.utility.internal.iterators.EmptyIterator;
import org.eclipse.jpt.utility.internal.iterators.FilteringIterator;
import org.eclipse.wst.validation.internal.provisional.core.IMessage;
import org.eclipse.wst.validation.internal.provisional.core.IReporter;
public class GenericJavaJoinColumn extends AbstractJavaBaseColumn<JoinColumnAnnotation> implements JavaJoinColumn
{
protected String specifiedReferencedColumnName;
protected String defaultReferencedColumnName;
protected JoinColumnAnnotation joinColumn;
public GenericJavaJoinColumn(JavaJpaContextNode parent, JavaJoinColumn.Owner owner) {
super(parent, owner);
}
@Override
protected JoinColumnAnnotation getResourceColumn() {
return this.joinColumn;
}
public String getReferencedColumnName() {
return (this.specifiedReferencedColumnName == null) ? this.defaultReferencedColumnName : this.specifiedReferencedColumnName;
}
public String getSpecifiedReferencedColumnName() {
return this.specifiedReferencedColumnName;
}
public void setSpecifiedReferencedColumnName(String newSpecifiedReferencedColumnName) {
String oldSpecifiedReferencedColumnName = this.specifiedReferencedColumnName;
this.specifiedReferencedColumnName = newSpecifiedReferencedColumnName;
this.joinColumn.setReferencedColumnName(newSpecifiedReferencedColumnName);
firePropertyChanged(BaseJoinColumn.SPECIFIED_REFERENCED_COLUMN_NAME_PROPERTY, oldSpecifiedReferencedColumnName, newSpecifiedReferencedColumnName);
}
protected void setSpecifiedReferencedColumnName_(String newSpecifiedReferencedColumnName) {
String oldSpecifiedReferencedColumnName = this.specifiedReferencedColumnName;
this.specifiedReferencedColumnName = newSpecifiedReferencedColumnName;
firePropertyChanged(BaseJoinColumn.SPECIFIED_REFERENCED_COLUMN_NAME_PROPERTY, oldSpecifiedReferencedColumnName, newSpecifiedReferencedColumnName);
}
public String getDefaultReferencedColumnName() {
return this.defaultReferencedColumnName;
}
protected void setDefaultReferencedColumnName(String newDefaultReferencedColumnName) {
String oldDefaultReferencedColumnName = this.defaultReferencedColumnName;
this.defaultReferencedColumnName = newDefaultReferencedColumnName;
firePropertyChanged(BaseJoinColumn.DEFAULT_REFERENCED_COLUMN_NAME_PROPERTY, oldDefaultReferencedColumnName, newDefaultReferencedColumnName);
}
@Override
public JavaJoinColumn.Owner getOwner() {
return (JavaJoinColumn.Owner) super.getOwner();
}
public boolean isVirtual() {
return getOwner().isVirtual(this);
}
public Table getReferencedColumnDbTable() {
return getOwner().getReferencedColumnDbTable();
}
public Column getReferencedDbColumn() {
Table table = this.getReferencedColumnDbTable();
return (table == null) ? null : table.getColumnForIdentifier(this.getReferencedColumnName());
}
@Override
public boolean tableIsAllowed() {
return this.getOwner().tableIsAllowed();
}
public boolean referencedColumnNameTouches(int pos, CompilationUnit astRoot) {
return getResourceColumn().referencedColumnNameTouches(pos, astRoot);
}
@Override
public Iterator<String> connectedJavaCompletionProposals(int pos, Filter<String> filter, CompilationUnit astRoot) {
Iterator<String> result = super.connectedJavaCompletionProposals(pos, filter, astRoot);
if (result != null) {
return result;
}
if (this.referencedColumnNameTouches(pos, astRoot)) {
return this.javaCandidateReferencedColumnNames(filter);
}
return null;
}
private Iterator<String> javaCandidateReferencedColumnNames(Filter<String> filter) {
return StringTools.convertToJavaStringLiterals(this.candidateReferencedColumnNames(filter));
}
private Iterator<String> candidateReferencedColumnNames(Filter<String> filter) {
return new FilteringIterator<String, String>(this.candidateReferencedColumnNames(), filter);
}
private Iterator<String> candidateReferencedColumnNames() {
Table table = this.getOwner().getReferencedColumnDbTable();
return (table != null) ? table.sortedColumnIdentifiers() : EmptyIterator.<String> instance();
}
public boolean isReferencedColumnResolved() {
return getReferencedDbColumn() != null;
}
public TextRange getReferencedColumnNameTextRange(CompilationUnit astRoot) {
TextRange textRange = getResourceColumn().getReferencedColumnNameTextRange(astRoot);
return (textRange != null) ? textRange : getOwner().getValidationTextRange(astRoot);
}
public TextRange getValidationTextRange(CompilationUnit astRoot) {
// TODO Auto-generated method stub
return null;
}
@Override
public void initialize(JoinColumnAnnotation annotation) {
this.joinColumn = annotation;
super.initialize(annotation);
this.specifiedReferencedColumnName = annotation.getReferencedColumnName();
this.defaultReferencedColumnName = this.buildDefaultReferencedColumnName();
}
@Override
public void update(JoinColumnAnnotation annotation) {
this.joinColumn = annotation;
super.update(annotation);
this.setSpecifiedReferencedColumnName_(annotation.getReferencedColumnName());
this.setDefaultReferencedColumnName(this.buildDefaultReferencedColumnName());
}
@Override
protected String buildDefaultName() {
return MappingTools.buildJoinColumnDefaultName(this);
}
protected String buildDefaultReferencedColumnName() {
return MappingTools.buildJoinColumnDefaultReferencedColumnName(this.getOwner());
}
@Override
public void validate(List<IMessage> messages, IReporter reporter, CompilationUnit astRoot) {
super.validate(messages, reporter, astRoot);
validateName(messages, astRoot);
validateReferencedColumnName(messages, astRoot);
}
protected void validateName(List<IMessage> messages, CompilationUnit astRoot) {
if ( ! this.isResolved() && getDbTable() != null) {
if (getName() != null) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_UNRESOLVED_NAME,
new String[] {this.getName()},
this,
this.getNameTextRange(astRoot)
)
);
}
else if (getOwner().joinColumnsSize() > 1) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_UNRESOLVED_NAME_MULTIPLE_JOIN_COLUMNS,
this,
this.getNameTextRange(astRoot)
)
);
}
//If the name is null and there is only one join-column, one of these validation messages will apply
// 1. target entity does not have a primary key
// 2. target entity is not specified
// 3. target entity is not an entity
}
}
protected void validateReferencedColumnName(List<IMessage> messages, CompilationUnit astRoot) {
if ( ! this.isReferencedColumnResolved() && getReferencedColumnDbTable() != null) {
if (getReferencedColumnName() != null) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_REFERENCED_COLUMN_UNRESOLVED_NAME,
new String[] {this.getReferencedColumnName(), this.getName()},
this,
this.getReferencedColumnNameTextRange(astRoot)
)
);
}
else if (getOwner().joinColumnsSize() > 1) {
messages.add(
DefaultJpaValidationMessages.buildMessage(
IMessage.HIGH_SEVERITY,
JpaValidationMessages.JOIN_COLUMN_REFERENCED_COLUMN_UNRESOLVED_NAME_MULTIPLE_JOIN_COLUMNS,
this,
this.getNameTextRange(astRoot)
)
);
}
//If the referenced column name is null and there is only one join-column, one of these validation messages will apply
// 1. target entity does not have a primary key
// 2. target entity is not specified
// 3. target entity is not an entity
}
}
}