1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
// THIS IS A GENERATED FILE
// If anything in this file needs to be updated, it needs to be fixed in reso_dd_generator
use serde::{Deserialize, Serialize};

/// [RuleFormat Lookups](https://ddwiki.reso.org/display/DDW17/RuleFormat+Lookups)
#[derive(Debug, Clone, Eq, PartialEq)]
pub enum RuleFormat {
    /// "[$filter](https://ddwiki.reso.org/pages/viewpage.action?pageId=29246248)": Business rules expressed utilizing the OData $filter syntax.  The underlying structure of the rules are not defined at this time and may vary from source to source.
    Filter,

    /// "[JavaScript](https://ddwiki.reso.org/display/DDW17/JavaScript)": Business rules expressed utilizing the JavaScript language.  The underlying structure of the rules are not defined at this time and may vary from source to source.
    JavaScript,

    /// "[REBR](https://ddwiki.reso.org/display/DDW17/REBR)": Real Estate Business Rule (REBR) notation, based on  RuleSpeak structured notation, uses a predictable syntax to allow humans to clearly and unambiguously specify real estate business rules.  REBR is not machine consumable and design for human production and consumption.
    REBR,

    /// "[RetsValidation](https://ddwiki.reso.org/display/DDW17/RetsValidation)": Business rules expressed using the well defined RETS 1.9 Validation Expressions.  See section 11.4.7 of the RETS 1.9 Specification for additional details. https://www.reso.org/download/rets-1-9-specification/
    RetsValidation,

    /// A value that was not defined by the enumeration
    OpenEnumeration(String),
}

impl crate::ResoEnumeration for RuleFormat {
    fn from_str(s: &str) -> RuleFormat {
        match s {
            "$filter" => RuleFormat::Filter,

            "JavaScript" => RuleFormat::JavaScript,

            "REBR" => RuleFormat::REBR,

            "RetsValidation" => RuleFormat::RetsValidation,

            _ => RuleFormat::OpenEnumeration(s.into()),
        }
    }

    fn from_string(s: String) -> RuleFormat {
        match s.as_ref() {
            "$filter" => RuleFormat::Filter,

            "JavaScript" => RuleFormat::JavaScript,

            "REBR" => RuleFormat::REBR,

            "RetsValidation" => RuleFormat::RetsValidation,

            _ => RuleFormat::OpenEnumeration(s),
        }
    }

    fn to_str(&self) -> &str {
        match self {
            RuleFormat::Filter => "$filter",

            RuleFormat::JavaScript => "JavaScript",

            RuleFormat::REBR => "REBR",

            RuleFormat::RetsValidation => "RetsValidation",

            RuleFormat::OpenEnumeration(ref s) => s,
        }
    }

    fn into_string(self) -> String {
        match self {
            RuleFormat::Filter => "$filter".into(),

            RuleFormat::JavaScript => "JavaScript".into(),

            RuleFormat::REBR => "REBR".into(),

            RuleFormat::RetsValidation => "RetsValidation".into(),

            RuleFormat::OpenEnumeration(s) => s,
        }
    }

    fn fallback_value(&self) -> Option<&str> {
        match self {
            RuleFormat::OpenEnumeration(ref s) => Some(s),
            _ => None,
        }
    }
}

impl From<String> for RuleFormat {
    fn from(s: String) -> RuleFormat {
        match s.as_ref() {
            "$filter" => RuleFormat::Filter,

            "JavaScript" => RuleFormat::JavaScript,

            "REBR" => RuleFormat::REBR,

            "RetsValidation" => RuleFormat::RetsValidation,

            _ => RuleFormat::OpenEnumeration(s),
        }
    }
}

impl From<&str> for RuleFormat {
    fn from(s: &str) -> RuleFormat {
        match s {
            "$filter" => RuleFormat::Filter,

            "JavaScript" => RuleFormat::JavaScript,

            "REBR" => RuleFormat::REBR,

            "RetsValidation" => RuleFormat::RetsValidation,

            _ => RuleFormat::OpenEnumeration(s.into()),
        }
    }
}

impl<'a> From<&'a RuleFormat> for &'a str {
    fn from(s: &'a RuleFormat) -> &'a str {
        match s {
            RuleFormat::Filter => "$filter",

            RuleFormat::JavaScript => "JavaScript",

            RuleFormat::REBR => "REBR",

            RuleFormat::RetsValidation => "RetsValidation",

            RuleFormat::OpenEnumeration(s) => s,
        }
    }
}

impl Serialize for RuleFormat {
    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
    where
        S: serde::Serializer,
    {
        serializer.serialize_str(self.into())
    }
}

impl<'de> Deserialize<'de> for RuleFormat {
    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
    where
        D: serde::Deserializer<'de>,
    {
        let s = String::deserialize(deserializer)?;
        Ok(From::from(s))
    }
}