Project

General

Profile

Download (7.71 KB) Statistics
| Branch: | Tag: | Revision:
1
/**
2
* Copyright (C) 2007 EDIT
3
* European Distributed Institute of Taxonomy
4
* http://www.e-taxonomy.eu
5
*
6
* The contents of this file are subject to the Mozilla Public License Version 1.1
7
* See LICENSE.TXT at the top of this package for the full license terms.
8
*/
9

    
10
package eu.etaxonomy.cdm.model.name;
11

    
12

    
13
import javax.persistence.Entity;
14
import javax.persistence.FetchType;
15
import javax.persistence.JoinColumn;
16
import javax.persistence.ManyToOne;
17
import javax.persistence.Transient;
18
import javax.xml.bind.annotation.XmlAccessType;
19
import javax.xml.bind.annotation.XmlAccessorType;
20
import javax.xml.bind.annotation.XmlElement;
21
import javax.xml.bind.annotation.XmlIDREF;
22
import javax.xml.bind.annotation.XmlRootElement;
23
import javax.xml.bind.annotation.XmlSchemaType;
24
import javax.xml.bind.annotation.XmlType;
25

    
26
import org.apache.log4j.Logger;
27
import org.hibernate.annotations.Cascade;
28
import org.hibernate.annotations.CascadeType;
29
import org.hibernate.envers.Audited;
30

    
31
import eu.etaxonomy.cdm.model.occurrence.DerivedUnit;
32
import eu.etaxonomy.cdm.model.reference.Reference;
33

    
34
/**
35
 * The class representing a typification of one or several {@link TaxonName taxon names} by a
36
 * {@link eu.etaxonomy.cdm.model.occurrence.DerivedUnit specimen or a figure}. All {@link TaxonName taxon names}
37
 * which have a {@link Rank rank} "species aggregate" or lower can only be typified
38
 * by specimens. Moreover each typification by a specimen (or by a figure) has a
39
 * {@link SpecimenTypeDesignationStatus status} like "holotype" or "isotype".
40
 * <P>
41
 * This class corresponds to: <ul>
42
 * <li> NomenclaturalType according to the TDWG ontology
43
 * <li> Typification (partially) according to the TCS
44
 * <li> NomenclaturalTypeDesignation according to the ABCD schema
45
 * </ul>
46
 *
47
 * @see		TypeDesignationBase
48
 * @see		NameTypeDesignation
49
 * @author	m.doering
50
 * @since 08-Nov-2007 13:06:38
51
 */
52
@XmlRootElement(name = "SpecimenTypeDesignation")
53
@XmlAccessorType(XmlAccessType.FIELD)
54
@XmlType(name = "SpecimenTypeDesignation", propOrder = {
55
    "typeSpecimen"
56
})
57
@Entity
58
@Audited
59
public class SpecimenTypeDesignation
60
        extends TypeDesignationBase<SpecimenTypeDesignationStatus>
61
        implements ITypeDesignation, Cloneable {
62
	private static final long serialVersionUID = 6481627446997275007L;
63
	private static final Logger logger = Logger.getLogger(SpecimenTypeDesignation.class);
64

    
65
	@XmlElement(name = "TypeSpecimen")
66
	@XmlIDREF
67
	@XmlSchemaType(name = "IDREF")
68
	@ManyToOne(fetch = FetchType.LAZY)
69
	@JoinColumn(name="typeSpecimen_id")
70
	@Cascade({CascadeType.SAVE_UPDATE,CascadeType.MERGE})
71
	private DerivedUnit typeSpecimen;
72

    
73
//	/**
74
//	 * Creates a new specimen type designation instance
75
//	 * (including its {@link reference.Reference reference source} and eventually
76
//	 * the taxon name string originally used by this reference when establishing
77
//	 * the former designation) and adds it to the corresponding
78
//	 * {@link HomotypicalGroup#getSpecimenTypeDesignations() specimen type designation set} of the
79
//	 * {@link HomotypicalGroup homotypical group}.
80
//	 *
81
//	 * @param specimen				the derived unit (specimen or figure) used as type
82
//	 * @param status				the type designation status
83
//	 * @param citation				the reference source for the new designation
84
//	 * @param citationMicroReference	the string with the details describing the exact localisation within the reference
85
//	 * @param originalNameString	the taxon name string used originally in the reference source for the new designation
86
//	 * @see							#SpecimenTypeDesignation(DerivedUnit, TypeDesignationStatus, Reference, String, String)
87
//	 * @see							HomotypicalGroup#addSpecimenTypeDesignation(SpecimenTypeDesignation, boolean)
88
//	 * @see							occurrence.DerivedUnit
89
//	 */
90
//	protected static SpecimenTypeDesignation NewInstance2(DerivedUnit specimen, TypeDesignationStatus status,
91
//			Reference citation, String citationMicroReference, String originalNameString){
92
//		SpecimenTypeDesignation specTypeDesig = new SpecimenTypeDesignation(specimen, status, citation, citationMicroReference, originalNameString);
93
//		return specTypeDesig;
94
//	}
95

    
96

    
97
	// ************* CONSTRUCTORS *************/
98
	/**
99
	 * Class constructor: creates a new empty specimen type designation.
100
	 *
101
	 * @see	#SpecimenTypeDesignation(DerivedUnit, SpecimenTypeDesignationStatus,
102
	 * Reference, String, String, boolean)
103
	 */
104
	protected SpecimenTypeDesignation(){
105
	}
106

    
107
	public static SpecimenTypeDesignation NewInstance() {
108
		return new SpecimenTypeDesignation();
109
	}
110

    
111
	/**
112
	 * Class constructor: creates a new specimen type designation instance
113
	 * (including its {@link eu.etaxonomy.cdm.model.reference.Reference reference source} and
114
	 * eventually the taxon name string originally used by this reference when
115
	 * establishing the former designation).
116
	 *
117
	 * @param specimen				the derived unit (specimen or figure) used
118
	 * 								as type
119
	 * @param status				the type designation status
120
	 * @param citation				the reference source for the new designation
121
	 * @param citationMicroReference	the string with the details describing
122
	 * 								the exact localisation within the reference
123
	 * @param originalNameString	the taxon name string used originally in the
124
	 * 								reference source for the new designation
125
	 * @param isNotDesignated		the boolean flag indicating whether there is no specimen type at all for
126
	 * 								<i>this</i> specimen type designation
127
	 * @see							#SpecimenTypeDesignation()
128
	 * @see							TaxonName#addSpecimenTypeDesignation(Specimen, SpecimenTypeDesignationStatus, Reference, String, String, boolean, boolean)
129
	 * @see							TypeDesignationBase#isNotDesignated()
130
	 * @see							eu.etaxonomy.cdm.model.occurrence.DerivedUnit
131
	 */
132
	protected SpecimenTypeDesignation(DerivedUnit specimen, SpecimenTypeDesignationStatus status, Reference citation, String citationMicroReference,
133
			String originalNameString, boolean isNotDesignated) {
134
		super(citation, citationMicroReference, originalNameString, isNotDesignated);
135
		this.setTypeSpecimen(specimen);
136

    
137
		this.setTypeStatus(status);
138
	}
139

    
140
	//********* METHODS **************************************/
141

    
142

    
143
	/* (non-Javadoc)
144
	 * @see eu.etaxonomy.cdm.model.name.TypeDesignationBase#removeType()
145
	 */
146
	@Override
147
	public void removeType() {
148
		this.setTypeSpecimen(null);
149
	}
150

    
151
	/**
152
	 * Returns the {@link DerivedUnit.DerivedUnit derived unit} (specimen or figure) that is used
153
	 * in <i>this</i> specimen type designation to typify the {@link TaxonName taxon name}.
154
	 *
155
	 * @see   #getHomotypicalGroup()
156
	 */
157
	public DerivedUnit getTypeSpecimen(){
158
		return this.typeSpecimen;
159
	}
160

    
161
	/**
162
	 * @see  #getTypeSpecimen()
163
	 */
164
	public void setTypeSpecimen(DerivedUnit typeSpecimen){
165
		if (this.typeSpecimen == typeSpecimen){
166
			return;
167
		}
168
		if (this.typeSpecimen != null){
169
			this.typeSpecimen.removeSpecimenTypeDesignation(this);
170
		}
171
		if (typeSpecimen != null && ! typeSpecimen.getSpecimenTypeDesignations().contains(this)){
172
			typeSpecimen.addSpecimenTypeDesignation(this);
173
		}
174
		this.typeSpecimen = typeSpecimen;
175
	}
176

    
177
	@Override
178
    @Transient
179
	public boolean isLectoType() {
180
		if(getTypeStatus() == null){
181
			return false;
182
		}
183
		return getTypeStatus().isLectotype();
184
	}
185

    
186
//*********************** CLONE ********************************************************/
187

    
188
	/**
189
	 * Clones <i>this</i> type specimen. This is a shortcut that enables to create
190
	 * a new instance that differs only slightly from <i>this</i> type specimen by
191
	 * modifying only some of the attributes.
192
	 *
193
	 * @see eu.etaxonomy.cdm.model.name.TypeDesignationBase#clone()
194
	 * @see java.lang.Object#clone()
195
	 */
196
	@Override
197
	public Object clone() {
198
		SpecimenTypeDesignation result;
199
		try {
200
			result = (SpecimenTypeDesignation)super.clone();
201
			//no changes to: typeSpecimen
202
			return result;
203
		} catch (CloneNotSupportedException e) {
204
			logger.warn("Object does not implement cloneable");
205
			e.printStackTrace();
206
			return null;
207
		}
208
	}
209

    
210

    
211
}
(27-27/36)