diff options
author | Christian Duerr <chrisduerr@users.noreply.github.com> | 2019-05-16 21:05:00 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-05-16 21:05:00 +0000 |
commit | d934df6c0e2279aa386fc2aa4154195e7b13ce64 (patch) | |
tree | 878a461562dad01ab1f91260538cdbdd8fa708bd /alacritty_terminal | |
parent | 2a6e9843eaa583b67d9b853f396dd72e69a20585 (diff) | |
download | alacritty-d934df6c0e2279aa386fc2aa4154195e7b13ce64.tar.gz alacritty-d934df6c0e2279aa386fc2aa4154195e7b13ce64.zip |
Fix URL detection matching invalid URLs
Fixes #2450.
Diffstat (limited to 'alacritty_terminal')
-rw-r--r-- | alacritty_terminal/src/url.rs | 28 |
1 files changed, 18 insertions, 10 deletions
diff --git a/alacritty_terminal/src/url.rs b/alacritty_terminal/src/url.rs index 088cf657..7f47e12d 100644 --- a/alacritty_terminal/src/url.rs +++ b/alacritty_terminal/src/url.rs @@ -13,14 +13,14 @@ // limitations under the License. use unicode_width::UnicodeWidthChar; -use url; use crate::term::cell::{Cell, Flags}; // See https://tools.ietf.org/html/rfc3987#page-13 const URL_SEPARATOR_CHARS: [char; 10] = ['<', '>', '"', ' ', '{', '}', '|', '\\', '^', '`']; const URL_DENY_END_CHARS: [char; 8] = ['.', ',', ';', ':', '?', '!', '/', '(']; -const URL_SCHEMES: [&str; 8] = ["http", "https", "mailto", "news", "file", "git", "ssh", "ftp"]; +const URL_SCHEMES: [&str; 8] = + ["http://", "https://", "mailto:", "news:", "file://", "git://", "ssh://", "ftp://"]; /// URL text and origin of the original click position. #[derive(Debug, PartialEq)] @@ -117,16 +117,15 @@ impl UrlParser { } // Check if string is valid url - match url::Url::parse(&self.state) { - Ok(url) => { - if URL_SCHEMES.contains(&url.scheme()) && self.origin > 0 { - Some(Url { origin: self.origin - 1, text: self.state }) - } else { - None + if self.origin > 0 && url::Url::parse(&self.state).is_ok() { + for scheme in &URL_SCHEMES { + if self.state.starts_with(scheme) { + return Some(Url { origin: self.origin - 1, text: self.state }); } - }, - Err(_) => None, + } } + + None } fn advance(&mut self, c: char, pos: usize) -> bool { @@ -305,5 +304,14 @@ mod tests { url_test("git://example.org", "git://example.org"); url_test("ssh://example.org", "ssh://example.org"); url_test("ftp://example.org", "ftp://example.org"); + + assert_eq!(url_create_term("mailto.example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("https:example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("http:example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("news.example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("file:example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("git:example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("ssh:example.org").url_search(Point::default()), None); + assert_eq!(url_create_term("ftp:example.org").url_search(Point::default()), None); } } |