Implement Validator
to get a static (compile-time-optimized) validator usable both with method-syntax and function-syntax styles. Dynamic validator to be implemented as (if) need arises.
* Sample 3-stage validator *
Mutating validators require owning datatypes (eg. String):
```rust
impl Validator
//value contains data?
.and_then(|v| match !v.is_empty() {
true => Ok(v),
false => Err(Error::EmptyValue(VAL_ERR_EMPTY_VALUE.to_string())),
})
//ensure value defines whole bytes (contains a multiple-of-three number of base-64 digits)
.and_then(|v| v += "=="[..v.len() % 3])
//value contains only valid base-64 characters?
.and_then(|v| match v.chars()
.all(|c| c.is_hex_char()) {
true => Ok(v),
false => Err(Error::IllegalValue((VAL_ERR_ILLEGAL_BASE_64_DIGIT.to_string()))),
})
//value passes validation
.and_then(|v| Ok(v))
}
} ```
Non-mutating validators can use any datatypes:
```rust
impl
//value contains data?
.and_then(|v| match !v.is_empty() {
true => Ok(v),
false => Err(Error::EmptyValue(VAL_ERR_EMPTY_VALUE.to_string())),
})
//value defines whole bytes (contains an even number of hex digits)?
.and_then(|v| match v.len() % 2 == 0 {
true => Ok(v),
false => Err(Error::InvalidSize(VAL_ERR_INVALID_SIZE.to_string())),
})
//value contains only valid hexadecimal characters?
.and_then(|v| match v.chars()
.all(|c| c.is_hex_char()) {
true => Ok(v),
false => Err(Error::IllegalValue((VAL_ERR_ILLEGAL_HEX_DIGIT.to_string()))),
})?;
Ok(value)
}
} ```
Invoke validators as follows: ```rust let hexvalue = "123456"; let base64_value = "123456";
// Method syntax
let hexresult1 = hexvalue.validate::
// Function syntax
let hexresult2 = Validate::