umya-spreadsheet 2.3.3

umya-spreadsheet is a library written in pure Rust to read and write xlsx file.
Documentation
// from
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 FromMarker {
    col: usize,
    col_off: usize,
    row: usize,
    row_off: usize,
}

impl FromMarker {
    #[inline]
    pub fn get_col(&self) -> &usize {
        &self.col
    }

    #[inline]
    pub fn set_col(&mut self, value: usize) -> &mut FromMarker {
        self.col = value;
        self
    }

    #[inline]
    pub fn get_col_off(&self) -> &usize {
        &self.col_off
    }

    #[inline]
    pub fn set_col_off(&mut self, value: usize) -> &mut FromMarker {
        self.col_off = value;
        self
    }

    #[inline]
    pub fn get_row(&self) -> &usize {
        &self.row
    }

    #[inline]
    pub fn set_row(&mut self, value: usize) -> &mut FromMarker {
        self.row = value;
        self
    }

    #[inline]
    pub fn get_row_off(&self) -> &usize {
        &self.row_off
    }

    #[inline]
    pub fn set_row_off(&mut self, value: usize) -> &mut FromMarker {
        self.row_off = value;
        self
    }

    #[inline]
    pub(crate) fn _adjustment_insert_row(&mut self, num_rows: &usize) {
        self.row += num_rows;
    }

    #[inline]
    pub(crate) fn _adjustment_insert_column(&mut self, num_cols: &usize) {
        self.col += num_cols;
    }

    #[inline]
    pub(crate) fn _adjustment_remove_row(&mut self, num_rows: &usize) {
        self.row = if &self.row > num_rows {
            self.row - num_rows
        } else {
            1
        };
    }

    #[inline]
    pub(crate) fn _adjustment_remove_column(&mut self, num_cols: &usize) {
        self.col = if &self.col > num_cols {
            self.col - num_cols
        } else {
            1
        };
    }

    pub(crate) fn set_attributes<R: std::io::BufRead>(
        &mut self,
        reader: &mut Reader<R>,
        _e: &BytesStart,
    ) {
        let mut string_value: String = String::new();
        xml_read_loop!(
            reader,
            Event::Text(e) => string_value = e.unescape().unwrap().to_string(),
            Event::End(ref e) => match e.name().into_inner() {
                b"xdr:col" => {
                    self.col = string_value.parse::<usize>().unwrap();
                }
                b"xdr:colOff" => {
                    self.col_off = string_value.parse::<usize>().unwrap();
                }
                b"xdr:row" => {
                    self.row = string_value.parse::<usize>().unwrap();
                }
                b"xdr:rowOff" => {
                    self.row_off = string_value.parse::<usize>().unwrap();
                }
                b"from" => return,
                _ => (),
            },
            Event::Eof => panic!("Error: Could not find {} end element", "from")
        );
    }

    pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
        // from
        write_start_tag(writer, "from", vec![], false);

        // xdr:col
        write_start_tag(writer, "xdr:col", vec![], false);
        write_text_node(writer, &self.col.to_string());
        write_end_tag(writer, "xdr:col");

        // xdr:colOff
        write_start_tag(writer, "xdr:colOff", vec![], false);
        write_text_node(writer, &self.col_off.to_string());
        write_end_tag(writer, "xdr:colOff");

        // xdr:row
        write_start_tag(writer, "xdr:row", vec![], false);
        write_text_node(writer, &self.row.to_string());
        write_end_tag(writer, "xdr:row");

        // xdr:rowOff
        write_start_tag(writer, "xdr:rowOff", vec![], false);
        write_text_node(writer, &self.row_off.to_string());
        write_end_tag(writer, "xdr:rowOff");

        write_end_tag(writer, "from");
    }
}