// license-header java merge-point // // Attention: Generated code! Do not modify by hand! // Generated by EntityEmbeddable.vsl in andromda-ejb3-cartridge on 09/18/2014 16:56:06. // package org.andromda.test.howto6.a; import java.io.Serializable; import javax.persistence.Column; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.MappedSuperclass; import javax.validation.constraints.NotNull; /** *

* TODO: Model Documentation for org.andromda.test.howto6.a.Car *

* * Autogenerated POJO EJB mapped super class for Car containing the * bulk of the entity implementation. * * This is a mapped super class and autogenerated by AndroMDA using the EJB3 * cartridge. * * DO NOT MODIFY this class. */ @MappedSuperclass public abstract class CarEmbeddable implements Serializable{ private static final long serialVersionUID = -7140762284700160581L; // ----------- 4 Attribute Definitions ------------ protected String serial; protected String name; protected CarType type; protected Long id; // --------- 1 Relationship Definitions ----------- protected Person owner; // ---- Manageable Display Attributes (Transient) ----- // -------- 4 Attribute Accessors ---------- /** *

* TODO: Model Documentation for serial *

* Get the serial property. * @return String The value of serial */ @Column(name="SERIAL", nullable=false, insertable=true, updatable=true) @NotNull(message="serial is required") public String getSerial() { return this.serial; } /** *

* TODO: Model Documentation for serial *

* Set the serial property. * @param value the new value */ public void setSerial(String value) { this.serial = value; } /** *

* TODO: Model Documentation for name *

* Get the name property. * @return String The value of name */ @Column(name="NAME", nullable=false, insertable=true, updatable=true) @NotNull(message="name is required") public String getName() { return this.name; } /** *

* TODO: Model Documentation for name *

* Set the name property. * @param value the new value */ public void setName(String value) { this.name = value; } /** *

* TODO: Model Documentation for type *

* Get the type property. * @return CarType The value of type */ @Column(name="TYPE", nullable=false, insertable=true, updatable=true, columnDefinition="VARCHAR(20)") @NotNull(message="type is required") public CarType getType() { return this.type; } /** *

* TODO: Model Documentation for type *

* Set the type property. * @param value the new value */ public void setType(CarType value) { this.type = value; } /** *

* TODO: Model Documentation for id *

* Get the id property. * @return Long The value of id */ @Id @GeneratedValue(strategy=GenerationType.AUTO) @Column(name="ID", nullable=false, insertable=true, updatable=true) public Long getId() { return this.id; } /** *

* TODO: Model Documentation for id *

* Set the id property. * @param value the new value */ public void setId(Long value) { this.id = value; } // ------------- 1 Relations ------------------ /** *

* TODO: Model Documentation for owner *

* Get the owner * @return Person */ @ManyToOne(optional=false) @JoinColumn(name="OWNER_FK", insertable=true, updatable=true) public Person getOwner() { return this.owner; } /** *

* TODO: Model Documentation for owner *

* Set the owner * @param ownerIn */ public void setOwner(Person ownerIn) { this.owner = ownerIn; } // --------------- Constructors ----------------- /** * Default empty no-arg constructor */ public CarEmbeddable() { // Default empty constructor } /** * Constructor with all updatable Entity attributes except auto incremented identifiers. * * @param serial String value for the serial property required=true lower=1 * @param name String value for the name property required=true lower=1 * @param type CarType value for the type property required=true lower=1 */ public CarEmbeddable(String serial, String name, CarType type) { this.serial = serial; this.name = name; this.type = type; } /** * Constructor with all Entity attribute values and CMR relations. * * @param serial String value for the serial property * @param name String value for the name property * @param type CarType value for the type property * @param owner Person value for the owner relation */ public CarEmbeddable(String serial, String name, CarType type, Person owner) { // 3 updatableAttributes setSerial(serial); setName(name); setType(type); // 1 relations setOwner(owner); } // -------- Common Methods ----------- /** * Indicates if the argument is of the same type and all values are equal. * @param object The target object to compare with * @return boolean True if both objects a 'equal' * @see Object#equals(Object) */ @Override public boolean equals(Object object) { if (null == object) { return false; } if (this == object) { return true; } if (!(object instanceof CarEmbeddable)) { return false; } final CarEmbeddable that = (CarEmbeddable)object; if (this.getId() == null || that.getId() == null || !this.getId().equals(that.getId())) { return false; } return true; } /** * Returns a hash code value for the object * @return int The hash code value * @see Object#hashCode */ @Override public int hashCode() { int hashCode = 0; hashCode = 29 * hashCode + (getId() == null ? 0 : getId().hashCode()); return hashCode; } /** * Returns a String representation of the object * @return String Textual representation of the object displaying name/value pairs for all attributes * @see Object#toString */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("CarEmbeddable("); sb.append(" serial=").append(getSerial()); sb.append(" name=").append(getName()); sb.append(" type=").append(getType()); sb.append(" id=").append(getId()); sb.append(" owner=").append(getOwner()); sb.append(")"); return sb.toString(); } }