1 // license-header java merge-point
2 //
3 // Attention: Generated code! Do not modify by hand!
4 // Generated by: hibernate/HibernateEntity.vsl in andromda-hibernate-cartridge.
5 //
6 package fr.ifremer.quadrige3.core.dao.data.aquaculture;
7
8 /*-
9 * #%L
10 * Quadrige3 Core :: Client API
11 * %%
12 * Copyright (C) 2017 - 2024 Ifremer
13 * %%
14 * This program is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Affero General Public License as published by
16 * the Free Software Foundation, either version 3 of the License, or
17 * (at your option) any later version.
18 *
19 * This program is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * You should have received a copy of the GNU Affero General Public License
25 * along with this program. If not, see <http://www.gnu.org/licenses/>.
26 * #L%
27 */
28 import fr.ifremer.quadrige3.core.dao.referential.Status;
29 import java.io.Serializable;
30 import java.sql.Timestamp;
31
32 /**
33 * Classe d'âge d'une population initiale
34 */
35 // HibernateEntity.vsl annotations merge-point
36 public abstract class AgeGroup
37 implements Serializable, Comparable<AgeGroup>
38 {
39 /**
40 * The serial version UID of this class. Needed for serialization.
41 */
42 private static final long serialVersionUID = -818363897210850022L;
43
44 // Generate 3 attributes
45 private String ageGroupCd;
46
47 /**
48 * Code de la classe d'âge
49 * @return this.ageGroupCd String
50 */
51 public String getAgeGroupCd()
52 {
53 return this.ageGroupCd;
54 }
55
56 /**
57 * Code de la classe d'âge
58 * @param ageGroupCdIn String
59 */
60 public void setAgeGroupCd(String ageGroupCdIn)
61 {
62 this.ageGroupCd = ageGroupCdIn;
63 }
64
65 private String ageGroupNm;
66
67 /**
68 * Libellé de la classe d'âge
69 * @return this.ageGroupNm String
70 */
71 public String getAgeGroupNm()
72 {
73 return this.ageGroupNm;
74 }
75
76 /**
77 * Libellé de la classe d'âge
78 * @param ageGroupNmIn String
79 */
80 public void setAgeGroupNm(String ageGroupNmIn)
81 {
82 this.ageGroupNm = ageGroupNmIn;
83 }
84
85 private Timestamp updateDt;
86
87 /**
88 * Date de maj
89 * @return this.updateDt Timestamp
90 */
91 public Timestamp getUpdateDt()
92 {
93 return this.updateDt;
94 }
95
96 /**
97 * Date de maj
98 * @param updateDtIn Timestamp
99 */
100 public void setUpdateDt(Timestamp updateDtIn)
101 {
102 this.updateDt = updateDtIn;
103 }
104
105 // Generate 2 associations
106 private Status status;
107
108 /**
109 * Liste des états possibles d'un objet.
110 * @return this.status Status
111 */
112 public Status getStatus()
113 {
114 return this.status;
115 }
116
117 /**
118 * Liste des états possibles d'un objet.
119 * @param statusIn Status
120 */
121 public void setStatus(Status statusIn)
122 {
123 this.status = statusIn;
124 }
125
126 /**
127 * Returns <code>true</code> if the argument is an AgeGroup instance and all identifiers for this entity
128 * equal the identifiers of the argument entity. Returns <code>false</code> otherwise.
129 */
130 @Override
131 public boolean equals(Object object)
132 {
133 if (this == object)
134 {
135 return true;
136 }
137 if (!(object instanceof AgeGroup))
138 {
139 return false;
140 }
141 final AgeGroup that = (AgeGroup)object;
142 if (this.ageGroupCd == null || that.getAgeGroupCd() == null || !this.ageGroupCd.equals(that.getAgeGroupCd()))
143 {
144 return false;
145 }
146 return true;
147 }
148
149 /**
150 * Returns a hash code based on this entity's identifiers.
151 */
152 @Override
153 public int hashCode()
154 {
155 int hashCode = 0;
156 hashCode = 29 * hashCode + (this.ageGroupCd == null ? 0 : this.ageGroupCd.hashCode());
157
158 return hashCode;
159 }
160
161 /**
162 * Constructs new instances of {@link AgeGroup}.
163 */
164 public static final class Factory
165 {
166 /**
167 * Constructs a new instance of {@link AgeGroup}.
168 * @return new AgeGroupImpl()
169 */
170 public static AgeGroup newInstance()
171 {
172 return new AgeGroupImpl();
173 }
174
175 /**
176 * Constructs a new instance of {@link AgeGroup}, taking all required and/or
177 * read-only properties as arguments, except for identifiers.
178 * @param ageGroupNm String
179 * @param status Status
180 * @return newInstance
181 */
182 public static AgeGroup newInstance(String ageGroupNm, Status status)
183 {
184 final AgeGroup entity = new AgeGroupImpl();
185 entity.setAgeGroupNm(ageGroupNm);
186 entity.setStatus(status);
187 return entity;
188 }
189
190 /**
191 * Constructs a new instance of {@link AgeGroup}, taking all possible properties
192 * (except the identifier(s))as arguments.
193 * @param ageGroupNm String
194 * @param updateDt Timestamp
195 * @param status Status
196 * @return newInstance AgeGroup
197 */
198 public static AgeGroup newInstance(String ageGroupNm, Timestamp updateDt, Status status)
199 {
200 final AgeGroup entity = new AgeGroupImpl();
201 entity.setAgeGroupNm(ageGroupNm);
202 entity.setUpdateDt(updateDt);
203 entity.setStatus(status);
204 return entity;
205 }
206 }
207
208 /**
209 * @see Comparable#compareTo
210 */
211 public int compareTo(AgeGroup o)
212 {
213 int cmp = 0;
214 if (this.getAgeGroupCd() != null)
215 {
216 cmp = this.getAgeGroupCd().compareTo(o.getAgeGroupCd());
217 }
218 else
219 {
220 if (this.getAgeGroupNm() != null)
221 {
222 cmp = (cmp != 0 ? cmp : this.getAgeGroupNm().compareTo(o.getAgeGroupNm()));
223 }
224 if (this.getUpdateDt() != null)
225 {
226 cmp = (cmp != 0 ? cmp : this.getUpdateDt().compareTo(o.getUpdateDt()));
227 }
228 }
229 return cmp;
230 }
231 // HibernateEntity.vsl merge-point
232 // AgeGroup.java merge-point
233 }