commit | 8c44ae1bcceff7eb75065b3187207ae95f37e926 | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <[email protected]> | Thu Sep 12 23:11:54 2024 +0000 |
committer | Android Build Coastguard Worker <[email protected]> | Thu Sep 12 23:11:54 2024 +0000 |
tree | 7c48796a9c73b7c243496a1aaa4577b24eda3fdd | |
parent | 4cc89fcd3fb8ccbce1aade0d7ebe0290546c4c2b [diff] | |
parent | 56b7e7f260a8ad7d28421669d5ac7d6eb9b647ea [diff] |
Snap for 12361654 from 56b7e7f260a8ad7d28421669d5ac7d6eb9b647ea to 24Q4-release Change-Id: I224d6b4de57cf8920a86a70633575a29349b5faf
Equivalent
and Comparable
are Rust traits for key comparison in maps.
These may be used in the implementation of maps where the lookup type Q
may be different than the stored key type K
.
Q: Equivalent<K>
checks for equality, similar to the HashMap<K, V>
constraint K: Borrow<Q>, Q: Eq
.Q: Comparable<K>
checks the ordering, similar to the BTreeMap<K, V>
constraint K: Borrow<Q>, Q: Ord
.These traits are not used by the maps in the standard library, but they may add more flexibility in third-party map implementations, especially in situations where a strict K: Borrow<Q>
relationship is not available.
Equivalent is distributed under the terms of both the MIT license and the Apache License (Version 2.0). See LICENSE-APACHE and LICENSE-MIT for details. Opening a pull request is assumed to signal agreement with these licensing terms.