X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=support%2Fgeneral%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fpersistence%2FPersistent.java;fp=support%2Fgeneral%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fpersistence%2FPersistent.java;h=57faf95e16694de8a9827d6763670e225e2f9c24;hb=32a62ca2c752e33a7873ac868a7a1f289caedcd4;hp=0000000000000000000000000000000000000000;hpb=d2bdf4e813c6a3964958c87b2ce56eaadf8a1f0a;p=utils diff --git a/support/general/src/main/java/org/wamblee/persistence/Persistent.java b/support/general/src/main/java/org/wamblee/persistence/Persistent.java new file mode 100644 index 00000000..57faf95e --- /dev/null +++ b/support/general/src/main/java/org/wamblee/persistence/Persistent.java @@ -0,0 +1,58 @@ +/* + * Copyright 2005 the original author or authors. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.wamblee.persistence; + +import java.io.Serializable; + +/** + * Interface for persistent objects. This defines required functionality for all objects + * that are persisted. + * + * Objects that implement this interface and which implement + * {@link java.lang.Object#equals(java.lang.Object)} + * should exclude the primary key and version from determining equality. + */ +public interface Persistent { + + /** + * Gets the primary key. + * @return Primary key. + * @see #setPrimaryKey(Serializable) + */ + Serializable getPrimaryKey(); + + /** + * Sets the primary key. + * @param aKey Primary key. + * @see #getPrimaryKey() + */ + void setPrimaryKey(Serializable aKey); + + /** + * Gets the version. + * @return Version. + * @see #setPersistedVersion(int) + */ + int getPersistedVersion(); + + /** + * Sets the version. + * @param aVersion Version. + * @see #getPersistedVersion() + */ + void setPersistedVersion(int aVersion); +}