use std::{
fmt,
path::{Path, PathBuf},
sync::Arc,
};
use crate::package_json::PackageJson;
#[derive(Clone)]
pub struct Resolution {
pub(crate) path: PathBuf,
pub(crate) query: Option<String>,
pub(crate) fragment: Option<String>,
pub(crate) package_json: Option<Arc<PackageJson>>,
}
impl fmt::Debug for Resolution {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_struct("Resolution")
.field("path", &self.path)
.field("query", &self.query)
.field("fragment", &self.fragment)
.field("package_json", &self.package_json.as_ref().map(|p| &p.path))
.finish()
}
}
impl PartialEq for Resolution {
fn eq(&self, other: &Self) -> bool {
self.path == other.path && self.query == other.query && self.fragment == other.fragment
}
}
impl Eq for Resolution {}
impl Resolution {
pub fn path(&self) -> &Path {
&self.path
}
pub fn into_path_buf(self) -> PathBuf {
self.path
}
pub fn query(&self) -> Option<&str> {
self.query.as_deref()
}
pub fn fragment(&self) -> Option<&str> {
self.fragment.as_deref()
}
pub fn package_json(&self) -> Option<&Arc<PackageJson>> {
self.package_json.as_ref()
}
pub fn full_path(&self) -> PathBuf {
let mut path = self.path.clone().into_os_string();
if let Some(query) = &self.query {
path.push(query);
}
if let Some(fragment) = &self.fragment {
path.push(fragment);
}
PathBuf::from(path)
}
}
#[tokio::test]
async fn test() {
let resolution = Resolution {
path: PathBuf::from("foo"),
query: Some("?query".to_string()),
fragment: Some("#fragment".to_string()),
package_json: None,
};
assert_eq!(resolution.path(), Path::new("foo"));
assert_eq!(resolution.query(), Some("?query"));
assert_eq!(resolution.fragment(), Some("#fragment"));
assert_eq!(resolution.full_path(), PathBuf::from("foo?query#fragment"));
assert_eq!(resolution.into_path_buf(), PathBuf::from("foo"));
}