From 76ffc60971e1c28e5e555af45853a6beb80eecf3 Mon Sep 17 00:00:00 2001 From: Nikolay Kim Date: Fri, 27 Oct 2017 19:26:53 -0700 Subject: [PATCH] better path recognision --- src/recognizer.rs | 21 +++++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/src/recognizer.rs b/src/recognizer.rs index ff80f624c..312c2b375 100644 --- a/src/recognizer.rs +++ b/src/recognizer.rs @@ -57,17 +57,26 @@ impl RouteRecognizer { } pub fn set_prefix(&mut self, prefix: P) { - self.prefix = prefix.to_string().len() - 1; + let p = prefix.to_string(); + if p.ends_with('/') { + self.prefix = p.len() - 1; + } else { + self.prefix = p.len(); + } } pub fn recognize(&self, path: &str) -> Option<(Option, &T)> { - if let Some(idx) = self.patterns.matches(&path[self.prefix..]).into_iter().next() - { + let p = &path[self.prefix..]; + if p.is_empty() { + if let Some(idx) = self.patterns.matches("/").into_iter().next() { + let (ref pattern, ref route) = self.routes[idx]; + return Some((pattern.match_info(&path[self.prefix..]), route)) + } + } else if let Some(idx) = self.patterns.matches(p).into_iter().next() { let (ref pattern, ref route) = self.routes[idx]; - Some((pattern.match_info(&path[self.prefix..]), route)) - } else { - None + return Some((pattern.match_info(&path[self.prefix..]), route)) } + None } }