aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIsis Lovecruft <isis@torproject.org>2018-03-21 02:09:04 +0000
committerIsis Lovecruft <isis@torproject.org>2018-04-02 19:34:25 +0000
commit35b86a12e60a8696b512261e96dc6f1c75ecebfc (patch)
tree2426d9dd0147b7d98b3a5db1d709a8beb95313dc
parent2eb1b7f2fd05eb0302e41b55f5cb61959cc9528e (diff)
downloadtor-35b86a12e60a8696b512261e96dc6f1c75ecebfc.tar.gz
tor-35b86a12e60a8696b512261e96dc6f1c75ecebfc.zip
rust: Refactor protover::is_supported_here().
This changes `protover::is_supported_here()` to be aware of new datatypes (e.g. don't call `.0` on things which are no longer tuple structs) and also changes the method signature to take borrows, making it faster, threadable, and easier to read (i.e. the caller can know from reading the function signature that the function won't mutate values passed into it). * CHANGE the `protover::is_supported_here()` function to take borrows. * REFACTOR the `protover::is_supported_here()` function to be aware of new datatypes. * FIXES part of #24031: https://bugs.torproject.org/24031
-rw-r--r--src/rust/protover/protover.rs19
1 files changed, 9 insertions, 10 deletions
diff --git a/src/rust/protover/protover.rs b/src/rust/protover/protover.rs
index 6f1ad768e4..247166c23a 100644
--- a/src/rust/protover/protover.rs
+++ b/src/rust/protover/protover.rs
@@ -590,26 +590,25 @@ impl ProtoverVote {
///
/// # Examples
/// ```
-/// use protover::*;
+/// use protover::is_supported_here;
+/// use protover::Protocol;
///
-/// let is_supported = is_supported_here(Proto::Link, 10);
+/// let is_supported = is_supported_here(&Protocol::Link, &10);
/// assert_eq!(false, is_supported);
///
-/// let is_supported = is_supported_here(Proto::Link, 1);
+/// let is_supported = is_supported_here(&Protocol::Link, &1);
/// assert_eq!(true, is_supported);
/// ```
-pub fn is_supported_here(proto: Proto, vers: Version) -> bool {
- let currently_supported = match SupportedProtocols::tor_supported() {
- Ok(result) => result.0,
+pub fn is_supported_here(proto: &Protocol, vers: &Version) -> bool {
+ let currently_supported: ProtoEntry = match ProtoEntry::supported() {
+ Ok(result) => result,
Err(_) => return false,
};
-
- let supported_versions = match currently_supported.get(&proto) {
+ let supported_versions = match currently_supported.get(proto) {
Some(n) => n,
None => return false,
};
-
- supported_versions.0.contains(&vers)
+ supported_versions.contains(vers)
}
/// Older versions of Tor cannot infer their own subprotocols