OPENJPA-203.

git-svn-id: https://svn.apache.org/repos/asf/incubator/openjpa/trunk@525950 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Srinivasa Segu 2007-04-05 20:06:24 +00:00
parent 80f7795fef
commit e541936463
2 changed files with 10 additions and 10 deletions

View File

@ -86,7 +86,7 @@ public class PessimisticLockManager
setLockLevel(sm, LOCK_DATASTORE_ONLY);
}
protected void lockInternal(OpenJPAStateManager sm, int level, int timeout,
protected void lockInternal(OpenJPAStateManager sm, int level, long timeout,
Object sdata) {
// we can skip any already-locked instance regardless of level because
// we treat all locks the same (though super doesn't)
@ -103,7 +103,7 @@ public class PessimisticLockManager
* Lock the specified instance row by issuing a "SELECT ... FOR UPDATE"
* statement.
*/
private void lockRow(OpenJPAStateManager sm, int timeout) {
private void lockRow(OpenJPAStateManager sm, long timeout) {
// assert that the dictionary supports the "SELECT ... FOR UPDATE"
// construct; if not, and we the assertion does not throw an
// exception, then just return without locking
@ -136,7 +136,7 @@ public class PessimisticLockManager
if (log.isWarnEnabled())
log.warn(_loc.get("millis-query-timeout"));
}
stmnt.setQueryTimeout(timeout / 1000);
stmnt.setQueryTimeout((int) (timeout / 1000));
}
rs = stmnt.executeQuery();
if (!rs.next())

View File

@ -69,17 +69,15 @@ public class VersionLockManager
return;
while (sm.getOwner() != null)
sm = sm.getOwner();
int oldlevel = getLockLevel(sm);
if (!sm.isPersistent() || sm.isNew() || level <= oldlevel)
int oldLevel = getLockLevel(sm);
if (!sm.isPersistent() || sm.isNew() || level <= oldLevel)
return;
// set the lock level first to avoid infinite recursion
setLockLevel(sm, level);
try {
lockInternal(sm, level, timeout, sdata);
} catch (RuntimeException re) {
// revert lock
setLockLevel(sm, oldlevel);
setLockLevel(sm, oldLevel);
throw re;
}
}
@ -94,6 +92,9 @@ public class VersionLockManager
*/
protected void lockInternal(OpenJPAStateManager sm, int level, long timeout,
Object sdata) {
// Set lock level first to prevent infinite recursion with
// transactional(..) call
setLockLevel(sm, level);
if (level >= LockLevels.LOCK_WRITE && _versionUpdateOnWriteLock)
getContext().transactional(sm.getManagedInstance(), true, null);
else if (level >= LockLevels.LOCK_READ && _versionCheckOnReadLock)
@ -134,4 +135,3 @@ public class VersionLockManager
return _versionUpdateOnWriteLock;
}
}