/* * Copyright 2011 Red Hat, Inc. and/or its affiliates. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA */ package org.infinispan.configuration.cache; import org.infinispan.util.TypedProperties; /** * Lock supporting cache store configuration. * * @author Galder ZamarreƱo * @since 5.1 */ public abstract class AbstractLockSupportCacheStoreConfiguration extends AbstractLoaderConfiguration { private final int lockConcurrencyLevel; private final long lockAcquistionTimeout; AbstractLockSupportCacheStoreConfiguration(long lockAcquistionTimeout, int lockConcurrencyLevel, boolean purgeOnStartup, boolean purgeSynchronously, int purgerThreads, boolean fetchPersistentState, boolean ignoreModifications, TypedProperties properties, AsyncLoaderConfiguration async, SingletonStoreConfiguration singletonStore) { super(purgeOnStartup, purgeSynchronously, purgerThreads, fetchPersistentState, ignoreModifications, properties, async, singletonStore); this.lockAcquistionTimeout = lockAcquistionTimeout; this.lockConcurrencyLevel = lockConcurrencyLevel; } public long lockAcquistionTimeout() { return lockAcquistionTimeout; } public int lockConcurrencyLevel() { return lockConcurrencyLevel; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; if (!super.equals(o)) return false; AbstractLockSupportCacheStoreConfiguration that = (AbstractLockSupportCacheStoreConfiguration) o; if (lockAcquistionTimeout != that.lockAcquistionTimeout) return false; if (lockConcurrencyLevel != that.lockConcurrencyLevel) return false; return true; } @Override public int hashCode() { int result = super.hashCode(); result = 31 * result + lockConcurrencyLevel; result = 31 * result + (int) (lockAcquistionTimeout ^ (lockAcquistionTimeout >>> 32)); return result; } }