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.system;
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.data.aquaculture.ProductionSector;
29 import java.io.Serializable;
30
31 /**
32 * Gestion de la géométrie surfacique des zone de production aquacoles
33 */
34 // HibernateEntity.vsl annotations merge-point
35 public abstract class ProdSectorArea
36 implements Serializable, Comparable<ProdSectorArea>
37 {
38 /**
39 * The serial version UID of this class. Needed for serialization.
40 */
41 private static final long serialVersionUID = 7913918321873214069L;
42
43 // Generate 2 attributes
44 private String prodSectorPosition;
45
46 /**
47 * Positionnement de l'objet
48 * @return this.prodSectorPosition String
49 */
50 public String getProdSectorPosition()
51 {
52 return this.prodSectorPosition;
53 }
54
55 /**
56 * Positionnement de l'objet
57 * @param prodSectorPositionIn String
58 */
59 public void setProdSectorPosition(String prodSectorPositionIn)
60 {
61 this.prodSectorPosition = prodSectorPositionIn;
62 }
63
64 private Integer prodSectorAreaId;
65
66 /**
67 *
68 * @return this.prodSectorAreaId Integer
69 */
70 public Integer getProdSectorAreaId()
71 {
72 return this.prodSectorAreaId;
73 }
74
75 /**
76 *
77 * @param prodSectorAreaIdIn Integer
78 */
79 public void setProdSectorAreaId(Integer prodSectorAreaIdIn)
80 {
81 this.prodSectorAreaId = prodSectorAreaIdIn;
82 }
83
84 // Generate 1 associations
85 private ProductionSector productionSector;
86
87 /**
88 * Secteur de production conchylicole
89 * @return this.productionSector ProductionSector
90 */
91 public ProductionSector getProductionSector()
92 {
93 return this.productionSector;
94 }
95
96 /**
97 * Secteur de production conchylicole
98 * @param productionSectorIn ProductionSector
99 */
100 public void setProductionSector(ProductionSector productionSectorIn)
101 {
102 this.productionSector = productionSectorIn;
103 }
104
105 /**
106 * Returns <code>true</code> if the argument is an ProdSectorArea instance and all identifiers for this entity
107 * equal the identifiers of the argument entity. Returns <code>false</code> otherwise.
108 */
109 @Override
110 public boolean equals(Object object)
111 {
112 if (this == object)
113 {
114 return true;
115 }
116 if (!(object instanceof ProdSectorArea))
117 {
118 return false;
119 }
120 final ProdSectorArea that = (ProdSectorArea)object;
121 if (this.prodSectorAreaId == null || that.getProdSectorAreaId() == null || !this.prodSectorAreaId.equals(that.getProdSectorAreaId()))
122 {
123 return false;
124 }
125 return true;
126 }
127
128 /**
129 * Returns a hash code based on this entity's identifiers.
130 */
131 @Override
132 public int hashCode()
133 {
134 int hashCode = 0;
135 hashCode = 29 * hashCode + (this.prodSectorAreaId == null ? 0 : this.prodSectorAreaId.hashCode());
136
137 return hashCode;
138 }
139
140 /**
141 * Constructs new instances of {@link ProdSectorArea}.
142 */
143 public static final class Factory
144 {
145 /**
146 * Constructs a new instance of {@link ProdSectorArea}.
147 * @return new ProdSectorAreaImpl()
148 */
149 public static ProdSectorArea newInstance()
150 {
151 return new ProdSectorAreaImpl();
152 }
153
154
155 /**
156 * Constructs a new instance of {@link ProdSectorArea}, taking all possible properties
157 * (except the identifier(s))as arguments.
158 * @param prodSectorPosition String
159 * @param productionSector ProductionSector
160 * @return newInstance ProdSectorArea
161 */
162 public static ProdSectorArea newInstance(String prodSectorPosition, ProductionSector productionSector)
163 {
164 final ProdSectorArea entity = new ProdSectorAreaImpl();
165 entity.setProdSectorPosition(prodSectorPosition);
166 entity.setProductionSector(productionSector);
167 return entity;
168 }
169 }
170
171 /**
172 * @see Comparable#compareTo
173 */
174 public int compareTo(ProdSectorArea o)
175 {
176 int cmp = 0;
177 if (this.getProdSectorAreaId() != null)
178 {
179 cmp = this.getProdSectorAreaId().compareTo(o.getProdSectorAreaId());
180 }
181 else
182 {
183 if (this.getProdSectorPosition() != null)
184 {
185 cmp = (cmp != 0 ? cmp : this.getProdSectorPosition().compareTo(o.getProdSectorPosition()));
186 }
187 }
188 return cmp;
189 }
190 // HibernateEntity.vsl merge-point
191 // ProdSectorArea.java merge-point
192 }