Skip to main content
summaryrefslogtreecommitdiffstats
blob: 1ca902e8756accb73cf1c3ff026a98ac2c33863a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*******************************************************************************
 * Copyright (c) 2006, 2007 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 org.eclipse.jpt.core.internal.context.base.IEntity;
import org.eclipse.jpt.core.internal.context.base.InheritanceType;
import org.eclipse.jpt.core.internal.resource.java.JavaPersistentResource;
import org.eclipse.jpt.core.internal.resource.java.Table;


public class JavaTable extends AbstractJavaTable implements IJavaTable
{
	protected JavaPersistentResource persistentResource;

	public JavaTable(IJavaEntity parent) {
		super(parent);
	}
	
	public void initializeFromResource(JavaPersistentResource persistentResource) {
		this.persistentResource = persistentResource;
		initializeFromResource(tableResource());
	}

	
	//query for the table resource every time on setters.
	//call one setter and the tableResource could change. 
	//You could call more than one setter before this object has received any notification
	//from the java resource model
	@Override
	protected Table tableResource() {
		//TODO get the NullTable from the resource model or build it here in the context model??
		return (Table) this.persistentResource.nonNullAnnotation(annotationName());
	}

	@Override
	protected String annotationName() {
		return Table.ANNOTATION_NAME;
	}
	
	@Override
	public IJavaEntity parent() {
		return (IJavaEntity) super.parent();
	}
	
	protected IJavaEntity javaEntity() {
		return parent();
	}
	
	protected IEntity rootEntity() {
		return javaEntity().rootEntity();
	}
	
	@Override
	/**
	 * Table name default to the owning java entity name.
	 * If this entity is part of a single table inheritance hierarchy, table
	 * name defaults to the root entity's table name.
	 */
	protected String defaultName() {
		if (javaEntity().getInheritanceStrategy() == InheritanceType.SINGLE_TABLE) {
			if (rootEntity() != javaEntity()) {
				return rootEntity().getTable().getName();
			}
		}
		return javaEntity().getName();
	}
	
	@Override
	protected String defaultSchema() {
		if (javaEntity().getInheritanceStrategy() == InheritanceType.SINGLE_TABLE) {
			if (rootEntity() != javaEntity()) {
				return rootEntity().getTable().getSchema();
			}
		}
		return super.defaultSchema();
	}
	
	@Override
	protected String defaultCatalog() {
		if (javaEntity().getInheritanceStrategy() == InheritanceType.SINGLE_TABLE) {
			if (rootEntity() != javaEntity()) {
				return rootEntity().getTable().getCatalog();
			}
		}
		return super.defaultCatalog();
	}
	
//	@Override
//	protected JavaUniqueConstraint createJavaUniqueConstraint(int index) {
//		return JavaUniqueConstraint.createTableUniqueConstraint(new UniqueConstraintOwner(this), this.getMember(), index);
//	}
	
	
	public void update(JavaPersistentResource persistentResource) {
		this.persistentResource = persistentResource;
		this.update(tableResource());
	}

}

Back to the top