aboutsummaryrefslogtreecommitdiffstats
path: root/src/url.rs
diff options
context:
space:
mode:
authorTeddy Wing2020-08-01 15:32:17 +0200
committerTeddy Wing2020-08-01 15:32:17 +0200
commitfdc1cc7bc3d237ef4976f9f9d2ffc09b7ba164d5 (patch)
tree4dc68f07d4a2e7ad8193f2b5f9a90c9fe6792aec /src/url.rs
parentb218abebdf8a0aed73bfe6f61ab22e51a0f2f43c (diff)
downloadgit-suggestion-fdc1cc7bc3d237ef4976f9f9d2ffc09b7ba164d5.tar.bz2
Move library to a separate crate
Keep the binaries in the root crate, and add a new crate for the `github-suggestion` library. I want to add some library code to the CLI programs to extract common functionality between the different binaries.
Diffstat (limited to 'src/url.rs')
-rw-r--r--src/url.rs52
1 files changed, 0 insertions, 52 deletions
diff --git a/src/url.rs b/src/url.rs
deleted file mode 100644
index 60a3d0e..0000000
--- a/src/url.rs
+++ /dev/null
@@ -1,52 +0,0 @@
-use std::str::FromStr;
-
-use thiserror::Error;
-
-use url;
-use url::Url;
-
-
-#[derive(Debug, Error)]
-pub enum Error {
- #[error("Unable to parse URL")]
- Url(#[from] url::ParseError),
-
- #[error("URL has no path")]
- NoPath,
-
- #[error("URL has no fragment")]
- NoFragment,
-
- #[error("Unable to parse owner or repo")]
- NoOwnerRepo,
-}
-
-#[derive(Debug)]
-pub struct SuggestionUrl {
- pub owner: String,
- pub repo: String,
- pub comment_id: String,
-}
-
-impl FromStr for SuggestionUrl {
- type Err = Error;
-
- fn from_str(s: &str) -> Result<Self, Self::Err> {
- let url = Url::parse(s)?;
- let path = url.path_segments()
- .ok_or(Error::NoPath)?
- .collect::<Vec<_>>();
-
- if path.len() < 2 {
- return Err(Error::NoOwnerRepo);
- }
-
- Ok(SuggestionUrl {
- owner: path[0].to_owned(),
- repo: path[1].to_owned(),
- comment_id: url.fragment()
- .ok_or(Error::NoFragment)?
- .replacen("discussion_r", "", 1),
- })
- }
-}