diff options
author | 2013-06-24 01:51:02 -0700 | |
---|---|---|
committer | 2013-06-24 01:51:02 -0700 | |
commit | d5f635a72f00dfc2fdf6a420974cf5a518c9194f (patch) | |
tree | 598d2f333cbbf52d6fd260d7ffe4be11f2aca960 /java/src/com/android/inputmethod/latin/utils/BoundedTreeSet.java | |
parent | e189103e0035a25458f567c1267b0d32f3223c83 (diff) | |
parent | bc1813186df823e4e1a5aabceb3198674387061e (diff) | |
download | latinime-d5f635a72f00dfc2fdf6a420974cf5a518c9194f.tar.gz latinime-d5f635a72f00dfc2fdf6a420974cf5a518c9194f.tar.xz latinime-d5f635a72f00dfc2fdf6a420974cf5a518c9194f.zip |
am bc181318: Merge "Move util classes to the latin/utils directory"
* commit 'bc1813186df823e4e1a5aabceb3198674387061e':
Move util classes to the latin/utils directory
Diffstat (limited to 'java/src/com/android/inputmethod/latin/utils/BoundedTreeSet.java')
-rw-r--r-- | java/src/com/android/inputmethod/latin/utils/BoundedTreeSet.java | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/java/src/com/android/inputmethod/latin/utils/BoundedTreeSet.java b/java/src/com/android/inputmethod/latin/utils/BoundedTreeSet.java new file mode 100644 index 000000000..ae1fd3f79 --- /dev/null +++ b/java/src/com/android/inputmethod/latin/utils/BoundedTreeSet.java @@ -0,0 +1,49 @@ +/* + * Copyright (C) 2012 The Android Open Source Project + * + * 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.android.inputmethod.latin.utils; + +import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo; + +import java.util.Collection; +import java.util.Comparator; +import java.util.TreeSet; + +/** + * A TreeSet that is bounded in size and throws everything that's smaller than its limit + */ +public final class BoundedTreeSet extends TreeSet<SuggestedWordInfo> { + private final int mCapacity; + public BoundedTreeSet(final Comparator<SuggestedWordInfo> comparator, final int capacity) { + super(comparator); + mCapacity = capacity; + } + + @Override + public boolean add(final SuggestedWordInfo e) { + if (size() < mCapacity) return super.add(e); + if (comparator().compare(e, last()) > 0) return false; + super.add(e); + pollLast(); // removes the last element + return true; + } + + @Override + public boolean addAll(final Collection<? extends SuggestedWordInfo> e) { + if (null == e) return false; + return super.addAll(e); + } +} |