blob: a5be5db84fcdd40c3146224fd8478853f3546170 (
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
|
/*******************************************************************************
* Copyright (c) 2008, 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.eclipselink.core.internal.context.java;
import java.util.List;
import java.util.Vector;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jpt.core.context.java.JavaConverter;
import org.eclipse.jpt.core.context.java.JavaPersistentAttribute;
import org.eclipse.jpt.core.internal.context.java.AbstractJavaIdMapping;
import org.eclipse.jpt.eclipselink.core.context.EclipseLinkConvert;
import org.eclipse.jpt.eclipselink.core.context.EclipseLinkIdMapping;
import org.eclipse.jpt.eclipselink.core.context.EclipseLinkMutable;
import org.eclipse.jpt.eclipselink.core.resource.java.EclipseLink;
import org.eclipse.jpt.eclipselink.core.resource.java.EclipseLinkConvertAnnotation;
import org.eclipse.wst.validation.internal.provisional.core.IMessage;
import org.eclipse.wst.validation.internal.provisional.core.IReporter;
public class JavaEclipseLinkIdMapping
extends AbstractJavaIdMapping
implements EclipseLinkIdMapping
{
protected final JavaEclipseLinkMutable mutable;
public JavaEclipseLinkIdMapping(JavaPersistentAttribute parent) {
super(parent);
this.mutable = new JavaEclipseLinkMutable(this);
}
//************** JavaAttributeMapping implementation ***************
@Override
protected void addSupportingAnnotationNamesTo(Vector<String> names) {
super.addSupportingAnnotationNamesTo(names);
names.add(EclipseLink.MUTABLE);
names.add(EclipseLink.CONVERT);
}
//************** AbstractJavaIdMapping overrides ***************
@Override
protected JavaConverter buildConverter(String converterType) {
JavaConverter javaConverter = super.buildConverter(converterType);
if (javaConverter != null) {
return javaConverter;
}
if (this.valuesAreEqual(converterType, EclipseLinkConvert.ECLIPSE_LINK_CONVERTER)) {
return new JavaEclipseLinkConvert(this, this.getResourcePersistentAttribute());
}
throw new IllegalArgumentException();
}
@Override
protected String getResourceConverterType() {
//check @Convert first, this is the order that EclipseLink searches
if (this.getResourcePersistentAttribute().getAnnotation(EclipseLinkConvertAnnotation.ANNOTATION_NAME) != null) {
return EclipseLinkConvert.ECLIPSE_LINK_CONVERTER;
}
return super.getResourceConverterType();
}
//************ EclipselinkIdMapping implementation ****************
public EclipseLinkMutable getMutable() {
return this.mutable;
}
//************ initialization/update ****************
@Override
protected void initialize() {
super.initialize();
this.mutable.initialize(this.getResourcePersistentAttribute());
}
@Override
protected void update() {
super.update();
this.mutable.update(this.getResourcePersistentAttribute());
}
//************ validation ****************
@Override
public void validate(List<IMessage> messages, IReporter reporter, CompilationUnit astRoot) {
super.validate(messages, reporter, astRoot);
this.mutable.validate(messages, reporter, astRoot);
}
}
|