use super::*;
impl<N: Network> Parser for Input<N> {
#[inline]
fn parse(string: &str) -> ParserResult<Self> {
let (string, _) = Sanitizer::parse(string)?;
let (string, _) = tag(Self::type_name())(string)?;
let (string, _) = Sanitizer::parse_whitespaces(string)?;
let (string, register) = map_res(Register::parse, |register| {
match ®ister {
Register::Locator(..) => Ok(register),
Register::Member(..) => Err(error(format!("Input register {register} cannot be a register member"))),
}
})(string)?;
let (string, _) = Sanitizer::parse_whitespaces(string)?;
let (string, _) = tag("as")(string)?;
let (string, _) = Sanitizer::parse_whitespaces(string)?;
let (string, (plaintext_type, _)) = pair(PlaintextType::parse, tag(".public"))(string)?;
let (string, _) = Sanitizer::parse_whitespaces(string)?;
let (string, _) = tag(";")(string)?;
Ok((string, Self { register, plaintext_type }))
}
}
impl<N: Network> FromStr for Input<N> {
type Err = Error;
#[inline]
fn from_str(string: &str) -> Result<Self> {
match Self::parse(string) {
Ok((remainder, object)) => {
ensure!(remainder.is_empty(), "Failed to parse string. Found invalid character in: \"{remainder}\"");
Ok(object)
}
Err(error) => bail!("Failed to parse string. {error}"),
}
}
}
impl<N: Network> Debug for Input<N> {
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
Display::fmt(self, f)
}
}
impl<N: Network> Display for Input<N> {
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
write!(
f,
"{type_} {register} as {plaintext_type}.public;",
type_ = Self::type_name(),
register = self.register,
plaintext_type = self.plaintext_type
)
}
}
#[cfg(test)]
mod tests {
use super::*;
use console::network::Testnet3;
type CurrentNetwork = Testnet3;
#[test]
fn test_input_parse() -> Result<()> {
let input = Input::<CurrentNetwork>::parse("input r0 as field.public;").unwrap().1;
assert_eq!(input.register(), &Register::<CurrentNetwork>::Locator(0));
assert_eq!(input.plaintext_type(), &PlaintextType::<CurrentNetwork>::from_str("field")?);
let input = Input::<CurrentNetwork>::parse("input r1 as signature.public;").unwrap().1;
assert_eq!(input.register(), &Register::<CurrentNetwork>::Locator(1));
assert_eq!(input.plaintext_type(), &PlaintextType::<CurrentNetwork>::from_str("signature")?);
let input = Input::<CurrentNetwork>::parse("input r2 as token.public;").unwrap().1;
assert_eq!(input.register(), &Register::<CurrentNetwork>::Locator(2));
assert_eq!(input.plaintext_type(), &PlaintextType::<CurrentNetwork>::from_str("token")?);
Ok(())
}
#[test]
fn test_input_display() -> Result<()> {
let input = Input::<CurrentNetwork>::from_str("input r0 as field.public;")?;
assert_eq!("input r0 as field.public;", input.to_string());
let input = Input::<CurrentNetwork>::from_str("input r1 as signature.public;")?;
assert_eq!("input r1 as signature.public;", input.to_string());
let input = Input::<CurrentNetwork>::parse("input r2 as token.public;").unwrap().1;
assert_eq!(format!("{input}"), "input r2 as token.public;");
Ok(())
}
}