umya_spreadsheet/structs/vml/spreadsheet/
auto_size_picture.rs

1use crate::reader::driver::*;
2use crate::structs::TrueFalseBlankValue;
3use crate::writer::driver::*;
4use quick_xml::events::{BytesStart, Event};
5use quick_xml::Reader;
6use quick_xml::Writer;
7use std::io::Cursor;
8
9#[derive(Clone, Default, Debug)]
10pub struct AutoSizePicture {
11    value: TrueFalseBlankValue,
12}
13
14impl AutoSizePicture {
15    #[inline]
16    pub fn get_value(&self) -> Option<&bool> {
17        self.value.get_value()
18    }
19
20    #[inline]
21    pub fn set_value(&mut self, value: bool) -> &mut Self {
22        self.value.set_value(value);
23        self
24    }
25
26    #[inline]
27    pub(crate) fn set_attributes<R: std::io::BufRead>(
28        &mut self,
29        reader: &mut Reader<R>,
30        _e: &BytesStart,
31        empty_flag: bool,
32    ) {
33        if empty_flag {
34            return;
35        }
36
37        xml_read_loop!(
38            reader,
39            Event::Text(e) => {
40                self.value.set_value_string(e.unescape().unwrap());
41            },
42            Event::End(ref e) => {
43                if e.name().0 == b"x:AutoPict" {
44                    return
45                }
46            },
47            Event::Eof => panic!("Error: Could not find {} end element", "x:AutoPict")
48        );
49    }
50
51    #[inline]
52    pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
53        // x:AutoPict
54        if self.value.has_value() {
55            write_start_tag(writer, "x:AutoPict", vec![], false);
56            write_text_node(writer, self.value.get_value_string2());
57            write_end_tag(writer, "x:AutoPict");
58        } else {
59            write_start_tag(writer, "x:AutoPict", vec![], true);
60        }
61    }
62}