/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* Copyright (c) 2008-2011, Red Hat Inc. or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.hibernate.action.internal;
import java.io.Serializable;
import java.util.concurrent.atomic.AtomicLong;
Acts as a stand-in for an entity identifier which is supposed to be
generated on insert (like an IDENTITY column) where the insert needed to
be delayed because we were outside a transaction when the persist
occurred (save currently still performs the insert).
The stand-in is only used within the PersistenceContext
in order to distinguish one instance from another; it is never injected into the entity instance or returned to the client... Author: Steve Ebersole, Sanne Grinovero
/**
* Acts as a stand-in for an entity identifier which is supposed to be
* generated on insert (like an IDENTITY column) where the insert needed to
* be delayed because we were outside a transaction when the persist
* occurred (save currently still performs the insert).
* <p/>
* The stand-in is only used within the {@link org.hibernate.engine.spi.PersistenceContext}
* in order to distinguish one instance from another; it is never injected into
* the entity instance or returned to the client...
*
* @author Steve Ebersole
* @author Sanne Grinovero
*/
public class DelayedPostInsertIdentifier implements Serializable, Comparable<DelayedPostInsertIdentifier> {
private static final AtomicLong SEQUENCE = new AtomicLong( 0 );
private final long identifier;
Constructs a DelayedPostInsertIdentifier
/**
* Constructs a DelayedPostInsertIdentifier
*/
public DelayedPostInsertIdentifier() {
long value = SEQUENCE.incrementAndGet();
if ( value < 0 ) {
synchronized (SEQUENCE) {
value = SEQUENCE.incrementAndGet();
if ( value < 0 ) {
SEQUENCE.set( 0 );
value = 0;
}
}
}
this.identifier = value;
}
@Override
public boolean equals(Object o) {
if ( this == o ) {
return true;
}
if ( o == null || getClass() != o.getClass() ) {
return false;
}
final DelayedPostInsertIdentifier that = (DelayedPostInsertIdentifier) o;
return identifier == that.identifier;
}
@Override
public int hashCode() {
return (int) ( identifier ^ ( identifier >>> 32 ) );
}
@Override
public String toString() {
return "<delayed:" + identifier + ">";
}
@Override
public int compareTo(DelayedPostInsertIdentifier that) {
if ( this.identifier < that.identifier ) {
return -1;
}
else if ( this.identifier > that.identifier ) {
return 1;
}
else {
return 0;
}
}
}