use std::io::Cursor;
use quick_xml::{
Reader,
Writer,
events::{
BytesStart,
Event,
},
};
use super::Outline;
use crate::{
reader::driver::xml_read_loop,
writer::driver::{
write_end_tag,
write_start_tag,
},
};
#[derive(Clone, Default, Debug)]
pub struct LineStyleList {
outline_collection: Vec<Outline>,
}
impl LineStyleList {
#[inline]
#[must_use]
pub fn outline_collection(&self) -> &[Outline] {
&self.outline_collection
}
#[inline]
#[must_use]
#[deprecated(since = "3.0.0", note = "Use outline_collection()")]
pub fn get_outline_collection(&self) -> &[Outline] {
self.outline_collection()
}
#[inline]
pub fn outline_collection_mut(&mut self) -> &mut Vec<Outline> {
&mut self.outline_collection
}
#[inline]
#[deprecated(since = "3.0.0", note = "Use outline_collection_mut()")]
pub fn get_outline_collection_mut(&mut self) -> &mut Vec<Outline> {
self.outline_collection_mut()
}
#[inline]
pub fn set_outline_collection(&mut self, value: impl Into<Vec<Outline>>) -> &mut Self {
self.outline_collection = value.into();
self
}
#[inline]
pub fn add_outline_collection(&mut self, value: Outline) -> &mut Self {
self.outline_collection.push(value);
self
}
pub(crate) fn set_attributes<R: std::io::BufRead>(
&mut self,
reader: &mut Reader<R>,
_e: &BytesStart,
) {
xml_read_loop!(
reader,
Event::Start(ref e) => {
if e.name().into_inner() == b"a:ln" {
let mut obj = Outline::default();
obj.set_attributes(reader, e);
self.outline_collection.push(obj);
}
},
Event::End(ref e) => {
if e.name().into_inner() == b"a:lnStyleLst" {
return
}
},
Event::Eof => panic!("Error: Could not find {} end element", "lnStyleLst")
);
}
pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
write_start_tag(writer, "a:lnStyleLst", vec![], false);
for v in &self.outline_collection {
v.write_to(writer);
}
write_end_tag(writer, "a:lnStyleLst");
}
}