src/jdk.internal.vm.compiler/share/classes/org.graalvm.collections/src/org/graalvm/collections/EconomicMap.java
author iveresov
Fri, 02 Feb 2018 17:28:17 -0800
changeset 48861 47f19ff9903c
permissions -rw-r--r--
8194819: Update Graal Reviewed-by: kvn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     1
/*
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     2
 * Copyright (c) 2017, 2017, Oracle and/or its affiliates. All rights reserved.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     4
 *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    10
 *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    15
 * accompanied this code).
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    16
 *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    20
 *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    23
 * questions.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    24
 */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    25
package org.graalvm.collections;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    26
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    27
import java.util.Iterator;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    28
import java.util.Map;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    29
import java.util.function.BiFunction;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    30
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    31
/**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    32
 * Memory efficient map data structure.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    33
 *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    34
 * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    35
 */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    36
public interface EconomicMap<K, V> extends UnmodifiableEconomicMap<K, V> {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    37
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    38
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    39
     * Associates {@code value} with {@code key} in this map. If the map previously contained a
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    40
     * mapping for {@code key}, the old value is replaced by {@code value}.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    41
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    42
     * @return the previous value associated with {@code key}, or {@code null} if there was no
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    43
     *         mapping for {@code key}.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    44
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    45
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    46
    V put(K key, V value);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    47
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    48
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    49
     * Copies all of the mappings from {@code other} to this map.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    50
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    51
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    52
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    53
    default void putAll(EconomicMap<K, V> other) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    54
        MapCursor<K, V> e = other.getEntries();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    55
        while (e.advance()) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    56
            put(e.getKey(), e.getValue());
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    57
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    58
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    59
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    60
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    61
     * Copies all of the mappings from {@code other} to this map.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    62
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    63
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    64
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    65
    default void putAll(UnmodifiableEconomicMap<? extends K, ? extends V> other) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    66
        UnmodifiableMapCursor<? extends K, ? extends V> entry = other.getEntries();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    67
        while (entry.advance()) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    68
            put(entry.getKey(), entry.getValue());
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    69
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    70
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    71
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    72
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    73
     * Removes all of the mappings from this map. The map will be empty after this call returns.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    74
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    75
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    76
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    77
    void clear();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    78
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    79
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    80
     * Removes the mapping for {@code key} from this map if it is present. The map will not contain
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    81
     * a mapping for {@code key} once the call returns.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    82
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    83
     * @return the previous value associated with {@code key}, or {@code null} if there was no
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    84
     *         mapping for {@code key}.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    85
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    86
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    87
    V removeKey(K key);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    88
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    89
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    90
     * Returns a {@link MapCursor} view of the mappings contained in this map.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    91
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    92
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    93
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    94
    @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    95
    MapCursor<K, V> getEntries();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    96
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    97
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    98
     * Replaces each entry's value with the result of invoking {@code function} on that entry until
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
    99
     * all entries have been processed or the function throws an exception. Exceptions thrown by the
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   100
     * function are relayed to the caller.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   101
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   102
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   103
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   104
    void replaceAll(BiFunction<? super K, ? super V, ? extends V> function);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   105
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   106
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   107
     * Creates a new map that guarantees insertion order on the key set with the default
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   108
     * {@link Equivalence#DEFAULT} comparison strategy for keys.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   109
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   110
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   111
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   112
    static <K, V> EconomicMap<K, V> create() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   113
        return EconomicMap.create(Equivalence.DEFAULT);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   114
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   115
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   116
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   117
     * Creates a new map that guarantees insertion order on the key set with the default
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   118
     * {@link Equivalence#DEFAULT} comparison strategy for keys and initializes with a specified
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   119
     * capacity.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   120
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   121
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   122
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   123
    static <K, V> EconomicMap<K, V> create(int initialCapacity) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   124
        return EconomicMap.create(Equivalence.DEFAULT, initialCapacity);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   125
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   126
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   127
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   128
     * Creates a new map that guarantees insertion order on the key set with the given comparison
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   129
     * strategy for keys.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   130
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   131
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   132
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   133
    static <K, V> EconomicMap<K, V> create(Equivalence strategy) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   134
        return EconomicMapImpl.create(strategy, false);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   135
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   136
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   137
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   138
     * Creates a new map that guarantees insertion order on the key set with the default
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   139
     * {@link Equivalence#DEFAULT} comparison strategy for keys and copies all elements from the
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   140
     * specified existing map.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   141
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   142
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   143
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   144
    static <K, V> EconomicMap<K, V> create(UnmodifiableEconomicMap<K, V> m) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   145
        return EconomicMap.create(Equivalence.DEFAULT, m);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   146
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   147
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   148
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   149
     * Creates a new map that guarantees insertion order on the key set and copies all elements from
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   150
     * the specified existing map.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   151
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   152
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   153
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   154
    static <K, V> EconomicMap<K, V> create(Equivalence strategy, UnmodifiableEconomicMap<K, V> m) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   155
        return EconomicMapImpl.create(strategy, m, false);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   156
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   157
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   158
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   159
     * Creates a new map that guarantees insertion order on the key set and initializes with a
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   160
     * specified capacity.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   161
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   162
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   163
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   164
    static <K, V> EconomicMap<K, V> create(Equivalence strategy, int initialCapacity) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   165
        return EconomicMapImpl.create(strategy, initialCapacity, false);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   166
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   167
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   168
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   169
     * Wraps an existing {@link Map} as an {@link EconomicMap}.
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   170
     *
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   171
     * @since 1.0
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   172
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   173
    static <K, V> EconomicMap<K, V> wrapMap(Map<K, V> map) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   174
        return new EconomicMap<K, V>() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   175
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   176
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   177
            public V get(K key) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   178
                V result = map.get(key);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   179
                return result;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   180
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   181
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   182
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   183
            public V put(K key, V value) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   184
                V result = map.put(key, value);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   185
                return result;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   186
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   187
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   188
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   189
            public int size() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   190
                int result = map.size();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   191
                return result;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   192
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   193
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   194
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   195
            public boolean containsKey(K key) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   196
                return map.containsKey(key);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   197
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   198
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   199
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   200
            public void clear() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   201
                map.clear();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   202
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   203
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   204
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   205
            public V removeKey(K key) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   206
                V result = map.remove(key);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   207
                return result;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   208
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   209
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   210
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   211
            public Iterable<V> getValues() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   212
                return map.values();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   213
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   214
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   215
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   216
            public Iterable<K> getKeys() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   217
                return map.keySet();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   218
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   219
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   220
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   221
            public boolean isEmpty() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   222
                return map.isEmpty();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   223
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   224
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   225
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   226
            public MapCursor<K, V> getEntries() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   227
                Iterator<java.util.Map.Entry<K, V>> iterator = map.entrySet().iterator();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   228
                return new MapCursor<K, V>() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   229
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   230
                    private Map.Entry<K, V> current;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   231
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   232
                    @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   233
                    public boolean advance() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   234
                        boolean result = iterator.hasNext();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   235
                        if (result) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   236
                            current = iterator.next();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   237
                        }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   238
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   239
                        return result;
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   240
                    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   241
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   242
                    @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   243
                    public K getKey() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   244
                        return current.getKey();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   245
                    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   246
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   247
                    @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   248
                    public V getValue() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   249
                        return current.getValue();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   250
                    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   251
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   252
                    @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   253
                    public void remove() {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   254
                        iterator.remove();
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   255
                    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   256
                };
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   257
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   258
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   259
            @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   260
            public void replaceAll(BiFunction<? super K, ? super V, ? extends V> function) {
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   261
                map.replaceAll(function);
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   262
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   263
        };
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   264
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents:
diff changeset
   265
}