/* * Hibernate, Relational Persistence for Idiomatic Java * * License: GNU Lesser General Public License (LGPL), version 2.1 or later. * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.annotations; import org.hibernate.cache.spi.access.AccessType; /** * Cache concurrency strategy. * * @author Emmanuel Bernard */ public enum CacheConcurrencyStrategy { /** * Indicates no concurrency strategy should be applied. */ NONE( null ), /** * Indicates that read-only strategy should be applied. * * @see AccessType#READ_ONLY */ READ_ONLY( AccessType.READ_ONLY ), /** * Indicates that the non-strict read-write strategy should be applied. * * @see AccessType#NONSTRICT_READ_WRITE */ NONSTRICT_READ_WRITE( AccessType.NONSTRICT_READ_WRITE ), /** * Indicates that the read-write strategy should be applied. * * @see AccessType#READ_WRITE */ READ_WRITE( AccessType.READ_WRITE ), /** * Indicates that the transaction strategy should be applied. * * @see AccessType#TRANSACTIONAL */ TRANSACTIONAL( AccessType.TRANSACTIONAL ); private final AccessType accessType; private CacheConcurrencyStrategy(AccessType accessType) { this.accessType = accessType; } /** * Get the AccessType corresponding to this concurrency strategy. * * @return The corresponding concurrency strategy. Note that this will return {@code null} for * {@link #NONE} */ public AccessType toAccessType() { return accessType; } /** * Conversion from {@link AccessType} to {@link CacheConcurrencyStrategy}. * * @param accessType The access type to convert * * @return The corresponding enum value. {@link #NONE} is returned by default if unable to * recognize {@code accessType} or if {@code accessType} is {@code null}. */ public static CacheConcurrencyStrategy fromAccessType(AccessType accessType) { if ( null == accessType ) { return NONE; } switch ( accessType ) { case READ_ONLY: { return READ_ONLY; } case READ_WRITE: { return READ_WRITE; } case NONSTRICT_READ_WRITE: { return NONSTRICT_READ_WRITE; } case TRANSACTIONAL: { return TRANSACTIONAL; } default: { return NONE; } } } /** * Parse an external representation of a CacheConcurrencyStrategy value. * * @param name The external representation * * @return The corresponding enum value, or {@code null} if not match was found. */ public static CacheConcurrencyStrategy parse(String name) { if ( READ_ONLY.isMatch( name ) ) { return READ_ONLY; } else if ( READ_WRITE.isMatch( name ) ) { return READ_WRITE; } else if ( NONSTRICT_READ_WRITE.isMatch( name ) ) { return NONSTRICT_READ_WRITE; } else if ( TRANSACTIONAL.isMatch( name ) ) { return TRANSACTIONAL; } else if ( NONE.isMatch( name ) ) { return NONE; } else { return null; } } private boolean isMatch(String name) { return ( accessType != null && accessType.getExternalName().equalsIgnoreCase( name ) ) || name().equalsIgnoreCase( name ); } }