/////////////////////////////////////////////////////////////////////////////// // Copyright (c) 2008, Robert D. Eden All Rights Reserved. // Copyright (c) 2009, Jeff Randall All Rights Reserved. // // This library 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 library 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 General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. /////////////////////////////////////////////////////////////////////////////// package gnu.trove.impl.sync; ////////////////////////////////////////////////// // THIS IS A GENERATED CLASS. DO NOT HAND EDIT! // ////////////////////////////////////////////////// //////////////////////////////////////////////////////////// // THIS IS AN IMPLEMENTATION CLASS. DO NOT USE DIRECTLY! // // Access to these methods should be through TCollections // //////////////////////////////////////////////////////////// import gnu.trove.iterator.*; import gnu.trove.procedure.*; import gnu.trove.set.*; import gnu.trove.list.*; import gnu.trove.function.*; import gnu.trove.map.*; import gnu.trove.*; import java.util.Collection; import java.util.Iterator; import java.util.Set; import java.util.Map; import java.util.RandomAccess; import java.util.Random; import java.io.Serializable; import java.io.ObjectOutputStream; import java.io.IOException; public class TSynchronizedObjectLongMap<K> implements TObjectLongMap<K>, Serializable { private static final long serialVersionUID = 1978198479659022715L; private final TObjectLongMap<K> m; // Backing Map final Object mutex; // Object on which to synchronize public TSynchronizedObjectLongMap( TObjectLongMap<K> m ) { if ( m == null ) throw new NullPointerException(); this.m = m; mutex = this; } public TSynchronizedObjectLongMap( TObjectLongMap<K> m, Object mutex ) { this.m = m; this.mutex = mutex; } public int size() { synchronized( mutex ) { return m.size(); } } public boolean isEmpty(){ synchronized( mutex ) { return m.isEmpty(); } } public boolean containsKey( Object key ) { synchronized( mutex ) { return m.containsKey( key ); } } public boolean containsValue( long value ){ synchronized( mutex ) { return m.containsValue( value ); } } public long get( Object key ) { synchronized( mutex ) { return m.get( key ); } } public long put( K key, long value ) { synchronized( mutex ) { return m.put( key, value ); } } public long remove( Object key ) { synchronized( mutex ) { return m.remove( key ); } } public void putAll( Map<? extends K, ? extends Long> map ) { synchronized( mutex ) { m.putAll( map ); } } public void putAll( TObjectLongMap<K> map ) { synchronized( mutex ) { m.putAll( map ); } } public void clear() { synchronized( mutex ) { m.clear(); } } private transient Set<K> keySet = null; private transient TLongCollection values = null; public Set<K> keySet() { synchronized( mutex ) { if ( keySet == null ) { keySet = new SynchronizedSet<K>( m.keySet(), mutex ); } return keySet; } } public Object[] keys() { synchronized( mutex ) { return m.keys(); } } public K[] keys( K[] array ) { synchronized( mutex ) { return m.keys( array ); } } public TLongCollection valueCollection() { synchronized( mutex ) { if ( values == null ) values = new TSynchronizedLongCollection( m.valueCollection(), mutex ); return values; } } public long[] values() { synchronized( mutex ) { return m.values(); } } public long[] values( long[] array ) { synchronized( mutex ) { return m.values( array ); } } public TObjectLongIterator<K> iterator() { return m.iterator(); // Must be manually synched by user! } // unchanging over the life of the map, no need to lock public long getNoEntryValue() { return m.getNoEntryValue(); } public long putIfAbsent( K key, long value ) { synchronized( mutex ) { return m.putIfAbsent( key, value ); } } public boolean forEachKey( TObjectProcedure<K> procedure ) { synchronized( mutex ) { return m.forEachKey( procedure ); } } public boolean forEachValue( TLongProcedure procedure ) { synchronized( mutex ) { return m.forEachValue( procedure ); } } public boolean forEachEntry( TObjectLongProcedure<K> procedure ) { synchronized( mutex ) { return m.forEachEntry( procedure ); } } public void transformValues( TLongFunction function ) { synchronized( mutex ) { m.transformValues( function ); } } public boolean retainEntries( TObjectLongProcedure<K> procedure ) { synchronized( mutex ) { return m.retainEntries( procedure ); } } public boolean increment( K key ) { synchronized( mutex ) { return m.increment( key ); } } public boolean adjustValue( K key, long amount ) { synchronized( mutex ) { return m.adjustValue( key, amount ); } } public long adjustOrPutValue( K key, long adjust_amount, long put_amount ) { synchronized( mutex ) { return m.adjustOrPutValue( key, adjust_amount, put_amount ); } } public boolean equals( Object o ) { synchronized( mutex ) { return m.equals( o ); } } public int hashCode() { synchronized( mutex ) { return m.hashCode(); } } public String toString() { synchronized( mutex ) { return m.toString(); } } private void writeObject( ObjectOutputStream s ) throws IOException { synchronized( mutex ) { s.defaultWriteObject(); } } }