001 /*
002 * Copyright (C) 2007 Google Inc.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016
017 package com.google.common.collect;
018
019 import com.google.common.annotations.GwtCompatible;
020
021 import java.util.Map;
022
023 import javax.annotation.Nullable;
024
025 /**
026 * A map entry which forwards all its method calls to another map entry.
027 * Subclasses should override one or more methods to modify the behavior of the
028 * backing map entry as desired per the <a
029 * href="http://en.wikipedia.org/wiki/Decorator_pattern">decorator pattern</a>.
030 *
031 * @author Mike Bostock
032 * @since 2 (imported from Google Collections Library)
033 */
034 @GwtCompatible
035 public abstract class ForwardingMapEntry<K, V>
036 extends ForwardingObject implements Map.Entry<K, V> {
037
038 /** Constructor for use by subclasses. */
039 protected ForwardingMapEntry() {}
040
041 @Override protected abstract Map.Entry<K, V> delegate();
042
043 public K getKey() {
044 return delegate().getKey();
045 }
046
047 public V getValue() {
048 return delegate().getValue();
049 }
050
051 public V setValue(V value) {
052 return delegate().setValue(value);
053 }
054
055 @Override public boolean equals(@Nullable Object object) {
056 return delegate().equals(object);
057 }
058
059 @Override public int hashCode() {
060 return delegate().hashCode();
061 }
062 }