use super::BooleanValue;
use super::FromMarker;
use super::ToMarker;
use crate::reader::driver::*;
use crate::writer::driver::*;
use quick_xml::events::{BytesStart, Event};
use quick_xml::Reader;
use quick_xml::Writer;
use std::io::Cursor;
#[derive(Clone, Default, Debug)]
pub struct ObjectAnchor {
move_with_cells: BooleanValue,
from_marker: FromMarker,
to_marker: ToMarker,
}
impl ObjectAnchor {
#[inline]
pub fn get_move_with_cells(&self) -> &bool {
self.move_with_cells.get_value()
}
#[inline]
pub fn set_move_with_cells(&mut self, value: bool) -> &mut Self {
self.move_with_cells.set_value(value);
self
}
#[inline]
pub fn get_from_marker(&self) -> &FromMarker {
&self.from_marker
}
#[inline]
pub fn get_from_marker_mut(&mut self) -> &mut FromMarker {
&mut self.from_marker
}
#[inline]
pub fn set_from_marker(&mut self, value: FromMarker) -> &mut Self {
self.from_marker = value;
self
}
#[inline]
pub fn get_to_marker(&self) -> &ToMarker {
&self.to_marker
}
#[inline]
pub fn get_to_marker_mut(&mut self) -> &mut ToMarker {
&mut self.to_marker
}
#[inline]
pub fn set_to_marker(&mut self, value: ToMarker) -> &mut Self {
self.to_marker = value;
self
}
#[inline]
pub(crate) fn _adjustment_insert_row(&mut self, num_rows: &usize) {
self.from_marker._adjustment_insert_row(num_rows);
self.to_marker._adjustment_insert_row(num_rows);
}
#[inline]
pub(crate) fn _adjustment_insert_column(&mut self, num_cols: &usize) {
self.from_marker._adjustment_insert_column(num_cols);
self.to_marker._adjustment_insert_column(num_cols);
}
#[inline]
pub(crate) fn _adjustment_remove_row(&mut self, num_rows: &usize) {
self.from_marker._adjustment_remove_row(num_rows);
self.to_marker._adjustment_remove_row(num_rows);
}
#[inline]
pub(crate) fn _adjustment_remove_column(&mut self, num_cols: &usize) {
self.from_marker._adjustment_remove_column(num_cols);
self.to_marker._adjustment_remove_column(num_cols);
}
pub(crate) fn set_attributes<R: std::io::BufRead>(
&mut self,
reader: &mut Reader<R>,
e: &BytesStart,
) {
set_string_from_xml!(self, e, move_with_cells, "moveWithCells");
xml_read_loop!(
reader,
Event::Start(ref e) => {
match e.name().into_inner() {
b"from" => {
self.from_marker.set_attributes(reader, e);
}
b"xdr:from" => {
self.from_marker.set_attributes(reader, e);
}
b"to" => {
self.to_marker.set_attributes(reader, e);
}
b"xdr:to" => {
self.to_marker.set_attributes(reader, e);
}
_ => (),
}
},
Event::End(ref e) => {
if e.name().into_inner() == b"anchor" {
return
}
},
Event::Eof => panic!("Error: Could not find {} end element", "anchor")
);
}
pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
let mut attributes: Vec<(&str, &str)> = Vec::new();
if self.move_with_cells.has_value() {
attributes.push(("moveWithCells", self.move_with_cells.get_value_string()));
}
write_start_tag(writer, "anchor", attributes, false);
self.from_marker.write_to(writer);
self.to_marker.write_to(writer);
write_end_tag(writer, "anchor");
}
}