/* * Copyright (c) 2008-2012, Hazel Bilisim Ltd. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.hazelcast.impl; import com.hazelcast.core.HazelcastInstance; import com.hazelcast.core.Prefix; import com.hazelcast.impl.ConcurrentMapManager.MAtomicNumber; import com.hazelcast.impl.base.FactoryAwareNamedProxy; import com.hazelcast.impl.monitor.AtomicNumberOperationsCounter; import com.hazelcast.impl.monitor.LocalAtomicNumberStatsImpl; import com.hazelcast.monitor.LocalAtomicNumberStats; import com.hazelcast.nio.Data; import static com.hazelcast.nio.IOUtil.toData; public class AtomicNumberProxyImpl extends FactoryAwareNamedProxy implements AtomicNumberProxy { private transient AtomicNumberProxy base = null; Data nameAsData = null; public AtomicNumberProxyImpl() { } AtomicNumberProxyImpl(String name, FactoryImpl factory) { setName(name); setHazelcastInstance(factory); base = new AtomicNumberProxyReal(); } Data getNameAsData() { if (nameAsData == null) { nameAsData = toData(name); } return nameAsData; } private void ensure() { factory.initialChecks(); if (base == null) { base = (AtomicNumberProxy) factory.getOrCreateProxyByName(name); } } @Override public String toString() { return "AtomicLong [" + getName() + "]"; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; AtomicNumberProxyImpl that = (AtomicNumberProxyImpl) o; return !(name != null ? !name.equals(that.name) : that.name != null); } @Override public int hashCode() { return name != null ? name.hashCode() : 0; } public void destroy() { ensure(); base.destroy(); } public InstanceType getInstanceType() { ensure(); return base.getInstanceType(); } public Object getId() { ensure(); return base.getId(); } public String getName() { ensure(); return base.getName(); } public String getLongName() { return name; } public long addAndGet(long delta) { ensure(); return base.addAndGet(delta); } public boolean compareAndSet(long expect, long update) { ensure(); return base.compareAndSet(expect, update); } public long decrementAndGet() { ensure(); return base.decrementAndGet(); } public long get() { ensure(); return base.get(); } public long getAndAdd(long delta) { ensure(); return base.getAndAdd(delta); } public long getAndSet(long newValue) { ensure(); return base.getAndSet(newValue); } public long incrementAndGet() { ensure(); return base.incrementAndGet(); } public void set(long newValue) { ensure(); base.set(newValue); } public AtomicNumberOperationsCounter getOperationsCounter() { ensure(); return base.getOperationsCounter(); } public LocalAtomicNumberStats getLocalAtomicNumberStats() { ensure(); return base.getLocalAtomicNumberStats(); } @Deprecated public void lazySet(long newValue) { set(newValue); } @Deprecated public boolean weakCompareAndSet(long expect, long update) { return compareAndSet(expect, update); } private class AtomicNumberProxyReal implements AtomicNumberProxy { AtomicNumberOperationsCounter operationsCounter = new AtomicNumberOperationsCounter(); public AtomicNumberProxyReal() { } public String getName() { return name.substring(Prefix.ATOMIC_NUMBER.length()); } public String getLongName() { return name; } public Object getId() { return name; } public long addAndGet(long delta) { return newMAtomicNumber().addAndGet(getNameAsData(), delta); } public boolean compareAndSet(long expect, long update) { return newMAtomicNumber().compareAndSet(getNameAsData(), expect, update); } public long decrementAndGet() { return addAndGet(-1L); } public long get() { return addAndGet(0L); } public long getAndAdd(long delta) { return newMAtomicNumber().getAndAdd(getNameAsData(), delta); } public long getAndSet(long newValue) { return newMAtomicNumber().getAndSet(getNameAsData(), newValue); } public long incrementAndGet() { return addAndGet(1L); } public void set(long newValue) { getAndSet(newValue); } public InstanceType getInstanceType() { return InstanceType.ATOMIC_NUMBER; } public void destroy() { newMAtomicNumber().destroy(getNameAsData()); factory.destroyInstanceClusterWide(name, null); } public AtomicNumberOperationsCounter getOperationsCounter() { return operationsCounter; } public LocalAtomicNumberStats getLocalAtomicNumberStats() { LocalAtomicNumberStatsImpl localAtomicStats = new LocalAtomicNumberStatsImpl(); localAtomicStats.setOperationStats(operationsCounter.getPublishedStats()); return localAtomicStats; } @Deprecated public void lazySet(long newValue) { set(newValue); } @Deprecated public boolean weakCompareAndSet(long expect, long update) { return compareAndSet(expect, update); } MAtomicNumber newMAtomicNumber() { MAtomicNumber mAtomicNumber = factory.node.concurrentMapManager.new MAtomicNumber(); mAtomicNumber.setOperationsCounter(operationsCounter); return mAtomicNumber; } public void setHazelcastInstance(HazelcastInstance hazelcastInstance) { } } }