diff options
author | 2024-12-04 02:36:05 +0000 | |
---|---|---|
committer | 2024-12-04 02:36:05 +0000 | |
commit | 1d831b4c4e730a7a7a4556e6c71aecc88d73d9ee (patch) | |
tree | f411c459be3f47932029f7677002ae0f9ac43fae | |
parent | 692a9ebce8eb37bbcd360a100a4c1395fa803e61 (diff) | |
download | peanuts-1d831b4c4e730a7a7a4556e6c71aecc88d73d9ee.tar.gz peanuts-1d831b4c4e730a7a7a4556e6c71aecc88d73d9ee.tar.bz2 peanuts-1d831b4c4e730a7a7a4556e6c71aecc88d73d9ee.zip |
add write function and remove todo Sink impl
-rw-r--r-- | src/writer.rs | 38 |
1 files changed, 7 insertions, 31 deletions
diff --git a/src/writer.rs b/src/writer.rs index 25e19fb..5f9f3fd 100644 --- a/src/writer.rs +++ b/src/writer.rs @@ -1,4 +1,4 @@ -use std::{collections::HashSet, str::FromStr}; +use std::{collections::HashSet, pin::pin, str::FromStr}; use async_recursion::async_recursion; use futures::Sink; @@ -6,7 +6,7 @@ use tokio::io::{AsyncWrite, AsyncWriteExt}; use crate::{ declaration::{Declaration, VersionInfo}, - element::{escape_str, Content, Element, IntoElement, Name, NamespaceDeclaration}, + element::{escape_str, Content, Element, IntoContent, IntoElement, Name, NamespaceDeclaration}, error::Error, xml::{self, composers::Composer, parsers_complete::Parser, ETag, XMLDecl}, Result, XMLNS_NS, XML_NS, @@ -79,6 +79,11 @@ impl<W: AsyncWrite + Unpin + Send> Writer<W> { Ok(()) } + pub async fn write(&mut self, into_content: &impl IntoContent) -> Result<()> { + let content = into_content.into_content(); + Ok(self.write_content(&content).await?) + } + #[async_recursion] pub async fn write_element(&mut self, element: &Element) -> Result<()> { if element.content.is_empty() { @@ -357,35 +362,6 @@ impl<W: AsyncWrite + Unpin + Send> Writer<W> { } } -impl<W: AsyncWrite, E: Into<Element>> Sink<E> for Writer<W> { - type Error = Error; - - fn poll_ready( - self: std::pin::Pin<&mut Self>, - cx: &mut std::task::Context<'_>, - ) -> std::task::Poll<Result<()>> { - todo!() - } - - fn start_send(self: std::pin::Pin<&mut Self>, item: E) -> Result<()> { - todo!() - } - - fn poll_flush( - self: std::pin::Pin<&mut Self>, - cx: &mut std::task::Context<'_>, - ) -> std::task::Poll<Result<()>> { - todo!() - } - - fn poll_close( - self: std::pin::Pin<&mut Self>, - cx: &mut std::task::Context<'_>, - ) -> std::task::Poll<Result<()>> { - todo!() - } -} - #[cfg(test)] mod test { use crate::{ |