View Javadoc
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.quadrige2.core.dao.system;
7   
8   /*-
9    * #%L
10   * Quadrige2 Core :: Server API
11   * %%
12   * Copyright (C) 2017 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  
29  import com.vividsolutions.jts.geom.Point;
30  import java.io.Serializable;
31  
32  /**
33   * Gestion de la géométrie ponctuelle des localisations
34   */
35  // HibernateEntity.vsl annotations merge-point
36  public abstract class LocPoint
37      implements Serializable, Comparable<LocPoint>
38  {
39      /**
40       * The serial version UID of this class. Needed for serialization.
41       */
42      private static final long serialVersionUID = -3080467737646398619L;
43  
44      // Generate 2 attributes
45      private Point locPosition;
46  
47      /**
48       * Géométrie ponctuelle de la localisation
49       * @return this.locPosition Point
50       */
51      public Point getLocPosition()
52      {
53          return this.locPosition;
54      }
55  
56      /**
57       * Géométrie ponctuelle de la localisation
58       * @param locPositionIn Point
59       */
60      public void setLocPosition(Point locPositionIn)
61      {
62          this.locPosition = locPositionIn;
63      }
64  
65      private Integer locPointId;
66  
67      /**
68       * 
69       * @return this.locPointId Integer
70       */
71      public Integer getLocPointId()
72      {
73          return this.locPointId;
74      }
75  
76      /**
77       * 
78       * @param locPointIdIn Integer
79       */
80      public void setLocPointId(Integer locPointIdIn)
81      {
82          this.locPointId = locPointIdIn;
83      }
84  
85      // Generate 1 associations
86      private Location locId;
87  
88      /**
89       * Localisations pouvant être utilisées pour initialiser la localisation des passages.
90       * @return this.locId Location
91       */
92      public Location getLocId()
93      {
94          return this.locId;
95      }
96  
97      /**
98       * Localisations pouvant être utilisées pour initialiser la localisation des passages.
99       * @param locIdIn Location
100      */
101     public void setLocId(Location locIdIn)
102     {
103         this.locId = locIdIn;
104     }
105 
106     /**
107      * Returns <code>true</code> if the argument is an LocPoint instance and all identifiers for this entity
108      * equal the identifiers of the argument entity. Returns <code>false</code> otherwise.
109      */
110     @Override
111     public boolean equals(Object object)
112     {
113         if (this == object)
114         {
115             return true;
116         }
117         if (!(object instanceof LocPoint))
118         {
119             return false;
120         }
121         final LocPoint that = (LocPoint)object;
122         if (this.locPointId == null || that.getLocPointId() == null || !this.locPointId.equals(that.getLocPointId()))
123         {
124             return false;
125         }
126         return true;
127     }
128 
129     /**
130      * Returns a hash code based on this entity's identifiers.
131      */
132     @Override
133     public int hashCode()
134     {
135         int hashCode = 0;
136         hashCode = 29 * hashCode + (this.locPointId == null ? 0 : this.locPointId.hashCode());
137 
138         return hashCode;
139     }
140 
141     /**
142      * Constructs new instances of {@link LocPoint}.
143      */
144     public static final class Factory
145     {
146         /**
147          * Constructs a new instance of {@link LocPoint}.
148          * @return new LocPointImpl()
149          */
150         public static LocPoint newInstance()
151         {
152             return new LocPointImpl();
153         }
154 
155 
156         /**
157          * Constructs a new instance of {@link LocPoint}, taking all possible properties
158          * (except the identifier(s))as arguments.
159          * @param locPosition Point
160          * @param locId Location
161          * @return newInstance LocPoint
162          */
163         public static LocPoint newInstance(Point locPosition, Location locId)
164         {
165             final LocPoint entity = new LocPointImpl();
166             entity.setLocPosition(locPosition);
167             entity.setLocId(locId);
168             return entity;
169         }
170     }
171 
172     /**
173      * @see Comparable#compareTo
174      */
175     public int compareTo(LocPoint o)
176     {
177         int cmp = 0;
178         if (this.getLocPointId() != null)
179         {
180             cmp = this.getLocPointId().compareTo(o.getLocPointId());
181         }
182         else
183         {
184             if (this.getLocPosition() != null)
185             {
186                 cmp = (cmp != 0 ? cmp : this.getLocPosition().compareTo(o.getLocPosition()));
187             }
188         }
189         return cmp;
190     }
191 // HibernateEntity.vsl merge-point
192 // LocPoint.java merge-point
193 }