javax.jdo.identity.IntIdentity Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jdo-api Show documentation
Show all versions of jdo-api Show documentation
The Java Data Objects (JDO) API is a standard interface-based Java model abstraction of persistence, developed as Java Specification Request 243 under the auspices of the Java Community Process.
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*/
/*
* IntIdentity.java
*
*/
package javax.jdo.identity;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
/** This class is for identity with a single int field.
* @version 2.0
*/
public class IntIdentity extends SingleFieldIdentity {
private int key;
private void construct(int key) {
this.key = key;
hashCode = hashClassName() ^ key;
}
/** Constructor with class and key.
* @param pcClass the class
* @param key the key
*/
public IntIdentity (Class pcClass, int key) {
super(pcClass);
construct(key);
}
/** Constructor with class and key.
* @param pcClass the class
* @param key the key
*/
public IntIdentity (Class pcClass, Integer key) {
super(pcClass);
setKeyAsObject(key);
construct(key.intValue ());
}
/** Constructor with class and key.
* @param pcClass the class
* @param str the key
*/
public IntIdentity (Class pcClass, String str) {
super(pcClass);
assertKeyNotNull(str);
construct(Integer.parseInt(str));
}
/** Constructor only for Externalizable.
*/
public IntIdentity () {
}
/** Return the key.
* @return the key
*/
public int getKey () {
return key;
}
/** Return the String form of the key.
* @return the String form of the key
*/
public String toString () {
return Integer.toString(key);
}
/** Determine if the other object represents the same object id.
* @param obj the other object
* @return true if both objects represent the same object id
*/
public boolean equals (Object obj) {
if (this == obj) {
return true;
} else if (!super.equals (obj)) {
return false;
} else {
IntIdentity other = (IntIdentity) obj;
return key == other.key;
}
}
/** Determine the ordering of identity objects.
* @param o Other identity
* @return The relative ordering between the objects
* @since 2.2
*/
public int compareTo(Object o) {
if (o instanceof IntIdentity) {
IntIdentity other = (IntIdentity)o;
int result = super.compare(other);
if (result == 0) {
return (key - other.key);
} else {
return result;
}
}
else if (o == null) {
throw new ClassCastException("object is null");
}
throw new ClassCastException(this.getClass().getName() + " != " + o.getClass().getName());
}
/** Create the key as an Object.
* @return the key as an Object
* @since 2.0
*/
protected Object createKeyAsObject() {
return Integer.valueOf(key);
}
/** Write this object. Write the superclass first.
* @param out the output
*/
public void writeExternal(ObjectOutput out) throws IOException {
super.writeExternal (out);
out.writeInt(key);
}
/** Read this object. Read the superclass first.
* @param in the input
*/
public void readExternal(ObjectInput in)
throws IOException, ClassNotFoundException {
super.readExternal (in);
key = in.readInt();
}
}