diff options
Diffstat (limited to 'src/stanza')
| -rw-r--r-- | src/stanza/client/mod.rs | 27 | 
1 files changed, 20 insertions, 7 deletions
| diff --git a/src/stanza/client/mod.rs b/src/stanza/client/mod.rs index 25d7b56..2b063d6 100644 --- a/src/stanza/client/mod.rs +++ b/src/stanza/client/mod.rs @@ -1,7 +1,7 @@  use iq::Iq;  use message::Message;  use peanuts::{ -    element::{FromElement, IntoElement}, +    element::{Content, ContentBuilder, FromContent, FromElement, IntoContent, IntoElement},      DeserializeError,  };  use presence::Presence; @@ -20,6 +20,18 @@ pub enum Stanza {      Presence(Presence),      Iq(Iq),      Error(StreamError), +    OtherContent(Content), +} + +impl FromContent for Stanza { +    fn from_content(content: Content) -> peanuts::element::DeserializeResult<Self> { +        match content { +            Content::Element(element) => Ok(Stanza::from_element(element)?), +            Content::Text(_) => Ok(Stanza::OtherContent(content)), +            Content::PI => Ok(Stanza::OtherContent(content)), +            Content::Comment(_) => Ok(Stanza::OtherContent(content)), +        } +    }  }  impl FromElement for Stanza { @@ -36,13 +48,14 @@ impl FromElement for Stanza {      }  } -impl IntoElement for Stanza { -    fn builder(&self) -> peanuts::element::ElementBuilder { +impl IntoContent for Stanza { +    fn builder(&self) -> peanuts::element::ContentBuilder {          match self { -            Stanza::Message(message) => message.builder(), -            Stanza::Presence(presence) => presence.builder(), -            Stanza::Iq(iq) => iq.builder(), -            Stanza::Error(error) => error.builder(), +            Stanza::Message(message) => <Message as IntoContent>::builder(message), +            Stanza::Presence(presence) => <Presence as IntoContent>::builder(presence), +            Stanza::Iq(iq) => <Iq as IntoContent>::builder(iq), +            Stanza::Error(error) => <StreamError as IntoContent>::builder(error), +            Stanza::OtherContent(_content) => ContentBuilder::Comment("other-content".to_string()),          }      }  } | 
