summaryrefslogtreecommitdiff
path: root/src/viewmodel/name.rs
diff options
context:
space:
mode:
authorjelemux <jeremias.weber@protonmail.com>2021-01-28 17:41:49 +0100
committerjelemux <jeremias.weber@protonmail.com>2021-01-28 17:41:49 +0100
commit3f0892368bcf475fdae39f24ef51b82b3013535f (patch)
tree087a0869e618cc37b48e6d462c99bc1b289ddabf /src/viewmodel/name.rs
parent4a0c73eebb8dfd6a5543945049175f64b9817c96 (diff)
downloadwasm-card-3f0892368bcf475fdae39f24ef51b82b3013535f.tar.gz
wasm-card-3f0892368bcf475fdae39f24ef51b82b3013535f.tar.bz2
try to fix problem with vcard mutable references
Diffstat (limited to 'src/viewmodel/name.rs')
-rw-r--r--src/viewmodel/name.rs72
1 files changed, 64 insertions, 8 deletions
diff --git a/src/viewmodel/name.rs b/src/viewmodel/name.rs
index 55c1b4c..e0c3a5b 100644
--- a/src/viewmodel/name.rs
+++ b/src/viewmodel/name.rs
@@ -61,27 +61,69 @@ impl VCardPropertyInputObject<properties::Name, NameView> for Name {
},
]
}
- fn to_vcard_property(&self) -> std::result::Result<properties::Name, VCardPropertyInputError> {
+ fn is_empty(&self) -> bool {
+ self.prefix.is_empty() &&
+ self.first_name.is_empty() &&
+ self.middle_name.is_empty() &&
+ self.last_name.is_empty() &&
+ self.suffix.is_empty()
+ }
+ fn to_vcard_property(&self) -> std::result::Result<properties::Name, Error> {
let name_value = values::name_value::NameValue::from_components(
match self.last_name.is_empty() {
true => None,
- false => Some(text::Component::from_str(&self.last_name).unwrap()),
+ false => Some(
+ match text::Component::from_str(&self.last_name) {
+ Ok(last_name) => last_name,
+ Err(_) => return Err(Error{
+ msg: String::from("Illegal character in last name."),
+ }),
+ }
+ ),
},
match self.first_name.is_empty() {
true => None,
- false => Some(text::Component::from_str(&self.first_name).unwrap()),
+ false => Some(
+ match text::Component::from_str(&self.first_name) {
+ Ok(first_name) => first_name,
+ Err(_) => return Err(Error{
+ msg: String::from("Illegal character in first name."),
+ }),
+ }
+ ),
},
match self.middle_name.is_empty() {
true => None,
- false => Some(text::Component::from_str(&self.middle_name).unwrap()),
+ false => Some(
+ match text::Component::from_str(&self.middle_name) {
+ Ok(middle_name) => middle_name,
+ Err(_) => return Err(Error{
+ msg: String::from("Illegal character in middle name."),
+ }),
+ }
+ ),
},
match self.prefix.is_empty() {
true => None,
- false => Some(text::Component::from_str(&self.prefix).unwrap()),
+ false => Some(
+ match text::Component::from_str(&self.prefix) {
+ Ok(prefix) => prefix,
+ Err(_) => return Err(Error{
+ msg: String::from("Illegal character in prefix."),
+ }),
+ }
+ ),
},
match self.suffix.is_empty() {
true => None,
- false => Some(text::Component::from_str(&self.suffix).unwrap()),
+ false => Some(
+ match text::Component::from_str(&self.suffix) {
+ Ok(suffix) => suffix,
+ Err(_) => return Err(Error{
+ msg: String::from("Illegal character in suffix."),
+ }),
+ }
+ ),
},
);
@@ -90,7 +132,7 @@ impl VCardPropertyInputObject<properties::Name, NameView> for Name {
}
impl Name {
- pub fn formatted_name(&self) -> String {
+ pub fn formatted_name(&self) -> Result<properties::FormattedName, Error> {
let mut formatted_name = String::new();
if !self.prefix.is_empty() {
@@ -113,6 +155,20 @@ impl Name {
formatted_name.push_str(&self.suffix);
}
- formatted_name
+ if formatted_name.is_empty() {
+ return Err(Error{
+ msg: String::from("Primary name field must not be empty for the formatted name field to be generated."),
+ });
+ }
+
+ let formatted_name = properties::FormattedName::from_text(
+ match text::Text::from_string(formatted_name) {
+ Ok(formatted_name) => formatted_name,
+ Err(_) => return Err(Error{
+ msg: String::from("Illegal character in formatted name.") // If I see this right, this error should never occur.
+ }),
+ }
+ );
+ Ok(formatted_name)
}
} \ No newline at end of file