use std::{borrow::Cow, ffi::OsStr, path::Path};
pub fn precompose(s: Cow<'_, str>) -> Cow<'_, str> {
use unicode_normalization::{is_nfc, UnicodeNormalization};
if is_nfc(s.as_ref()) {
s
} else {
Cow::Owned(s.as_ref().nfc().collect())
}
}
pub fn decompose(s: Cow<'_, str>) -> Cow<'_, str> {
use unicode_normalization::{is_nfd, UnicodeNormalization};
if is_nfd(s.as_ref()) {
s
} else {
Cow::Owned(s.as_ref().nfd().collect())
}
}
pub fn precompose_path(path: Cow<'_, Path>) -> Cow<'_, Path> {
match path.to_str() {
None => path,
Some(maybe_decomposed) => match precompose(maybe_decomposed.into()) {
Cow::Borrowed(_) => path,
Cow::Owned(precomposed) => Cow::Owned(precomposed.into()),
},
}
}
pub fn precompose_os_string(name: Cow<'_, OsStr>) -> Cow<'_, OsStr> {
match name.to_str() {
None => name,
Some(maybe_decomposed) => match precompose(maybe_decomposed.into()) {
Cow::Borrowed(_) => name,
Cow::Owned(precomposed) => Cow::Owned(precomposed.into()),
},
}
}
#[cfg(feature = "bstr")]
pub fn precompose_bstr(s: Cow<'_, bstr::BStr>) -> Cow<'_, bstr::BStr> {
use bstr::ByteSlice;
match s.to_str().ok() {
None => s,
Some(maybe_decomposed) => match precompose(maybe_decomposed.into()) {
Cow::Borrowed(_) => s,
Cow::Owned(precomposed) => Cow::Owned(precomposed.into()),
},
}
}