use std::{
fmt,
path::{Path, PathBuf},
sync::Arc,
};
use crate::PackageJson;
#[derive(Debug, Clone, Copy, Eq, PartialEq)]
pub enum ModuleType {
Module,
CommonJs,
Json,
Wasm,
Addon,
}
pub struct Resolution {
pub(crate) path: PathBuf,
pub(crate) query: Option<String>,
pub(crate) fragment: Option<String>,
pub(crate) package_json: Option<Arc<PackageJson>>,
pub(crate) module_type: Option<ModuleType>,
}
impl Clone for Resolution {
fn clone(&self) -> Self {
Self {
path: self.path.clone(),
query: self.query.clone(),
fragment: self.fragment.clone(),
package_json: self.package_json.clone(),
module_type: self.module_type,
}
}
}
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("module_type", &self.module_type)
.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 {
#[must_use]
pub fn path(&self) -> &Path {
&self.path
}
#[must_use]
pub fn into_path_buf(self) -> PathBuf {
self.path
}
#[must_use]
pub fn query(&self) -> Option<&str> {
self.query.as_deref()
}
#[must_use]
pub fn fragment(&self) -> Option<&str> {
self.fragment.as_deref()
}
#[must_use]
pub fn package_json(&self) -> Option<&Arc<PackageJson>> {
self.package_json.as_ref()
}
#[must_use]
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)
}
#[must_use]
pub fn module_type(&self) -> Option<ModuleType> {
self.module_type
}
}