clean up CacheModeHelper
Signed-off-by: Gavin King <gavin@hibernate.org>
This commit is contained in:
parent
07dc9f0a68
commit
39a6f9880b
|
@ -42,22 +42,18 @@ public final class CacheModeHelper {
|
||||||
retrieveMode = DEFAULT_RETRIEVE_MODE;
|
retrieveMode = DEFAULT_RETRIEVE_MODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
final boolean get = ( CacheRetrieveMode.USE == retrieveMode );
|
final boolean get = CacheRetrieveMode.USE == retrieveMode;
|
||||||
|
|
||||||
switch ( storeMode ) {
|
switch ( storeMode ) {
|
||||||
case USE: {
|
case USE:
|
||||||
return get ? CacheMode.NORMAL : CacheMode.PUT;
|
return get ? CacheMode.NORMAL : CacheMode.PUT;
|
||||||
}
|
case BYPASS:
|
||||||
case REFRESH: {
|
return get ? CacheMode.GET : CacheMode.IGNORE;
|
||||||
|
case REFRESH:
|
||||||
// really (get == true) here is a bit of an invalid combo...
|
// really (get == true) here is a bit of an invalid combo...
|
||||||
return CacheMode.REFRESH;
|
return CacheMode.REFRESH;
|
||||||
}
|
default:
|
||||||
case BYPASS: {
|
throw new IllegalStateException( "Unrecognized CacheStoreMode: " + storeMode );
|
||||||
return get ? CacheMode.GET : CacheMode.IGNORE;
|
|
||||||
}
|
|
||||||
default: {
|
|
||||||
throw new IllegalStateException( "huh? :)" );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,37 +64,11 @@ public final class CacheModeHelper {
|
||||||
* @param storeMode The JPA shared-cache store mode.
|
* @param storeMode The JPA shared-cache store mode.
|
||||||
* @param retrieveMode The JPA shared-cache retrieve mode.
|
* @param retrieveMode The JPA shared-cache retrieve mode.
|
||||||
*
|
*
|
||||||
* @return Corresponding {@link CacheMode}.
|
* @return Corresponding {@link CacheMode}, or null if both arguments are null.
|
||||||
*/
|
*/
|
||||||
public static CacheMode effectiveCacheMode(CacheStoreMode storeMode, CacheRetrieveMode retrieveMode) {
|
public static CacheMode effectiveCacheMode(CacheStoreMode storeMode, CacheRetrieveMode retrieveMode) {
|
||||||
if ( storeMode == null && retrieveMode == null ) {
|
return storeMode == null && retrieveMode == null ? null
|
||||||
return null;
|
: interpretCacheMode( storeMode, retrieveMode );
|
||||||
}
|
|
||||||
|
|
||||||
if ( storeMode == null ) {
|
|
||||||
storeMode = DEFAULT_STORE_MODE;
|
|
||||||
}
|
|
||||||
if ( retrieveMode == null ) {
|
|
||||||
retrieveMode = DEFAULT_RETRIEVE_MODE;
|
|
||||||
}
|
|
||||||
|
|
||||||
final boolean get = ( CacheRetrieveMode.USE == retrieveMode );
|
|
||||||
|
|
||||||
switch ( storeMode ) {
|
|
||||||
case USE: {
|
|
||||||
return get ? CacheMode.NORMAL : CacheMode.PUT;
|
|
||||||
}
|
|
||||||
case REFRESH: {
|
|
||||||
// really (get == true) here is a bit of an invalid combo...
|
|
||||||
return CacheMode.REFRESH;
|
|
||||||
}
|
|
||||||
case BYPASS: {
|
|
||||||
return get ? CacheMode.GET : CacheMode.IGNORE;
|
|
||||||
}
|
|
||||||
default: {
|
|
||||||
throw new IllegalStateException( "huh? :)" );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static CacheStoreMode interpretCacheStoreMode(CacheMode cacheMode) {
|
public static CacheStoreMode interpretCacheStoreMode(CacheMode cacheMode) {
|
||||||
|
@ -106,21 +76,23 @@ public final class CacheModeHelper {
|
||||||
cacheMode = DEFAULT_LEGACY_MODE;
|
cacheMode = DEFAULT_LEGACY_MODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( CacheMode.REFRESH == cacheMode ) {
|
switch (cacheMode) {
|
||||||
return CacheStoreMode.REFRESH;
|
case NORMAL:
|
||||||
}
|
case PUT:
|
||||||
if ( CacheMode.NORMAL == cacheMode || CacheMode.PUT == cacheMode ) {
|
|
||||||
return CacheStoreMode.USE;
|
return CacheStoreMode.USE;
|
||||||
}
|
case REFRESH:
|
||||||
|
return CacheStoreMode.REFRESH;
|
||||||
|
default:
|
||||||
return CacheStoreMode.BYPASS;
|
return CacheStoreMode.BYPASS;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static CacheRetrieveMode interpretCacheRetrieveMode(CacheMode cacheMode) {
|
public static CacheRetrieveMode interpretCacheRetrieveMode(CacheMode cacheMode) {
|
||||||
if ( cacheMode == null ) {
|
if ( cacheMode == null ) {
|
||||||
cacheMode = DEFAULT_LEGACY_MODE;
|
cacheMode = DEFAULT_LEGACY_MODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ( CacheMode.NORMAL == cacheMode || CacheMode.GET == cacheMode )
|
return CacheMode.NORMAL == cacheMode || CacheMode.GET == cacheMode
|
||||||
? CacheRetrieveMode.USE
|
? CacheRetrieveMode.USE
|
||||||
: CacheRetrieveMode.BYPASS;
|
: CacheRetrieveMode.BYPASS;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue