| // Copyright (c) 2024, the R8 project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| package com.android.tools.r8.utils; |
| |
| import java.util.LinkedHashMap; |
| import java.util.Map; |
| |
| public class LRUCache<K, V> extends LinkedHashMap<K, V> { |
| |
| private final int maxSize; |
| |
| public LRUCache(int maxSize) { |
| super(maxSize + 1, 0.75F, true); |
| this.maxSize = maxSize; |
| } |
| |
| @Override |
| protected boolean removeEldestEntry(Map.Entry<K, V> eldest) { |
| return this.size() > this.maxSize; |
| } |
| } |