xlnt/source/range.cpp

432 lines
11 KiB
C++
Raw Normal View History

2014-06-06 04:19:31 +08:00
#include "worksheet/range.hpp"
#include "cell/cell.hpp"
#include "worksheet/range_reference.hpp"
#include "worksheet/worksheet.hpp"
2014-05-22 05:48:51 +08:00
namespace xlnt {
cell_vector::iterator::iterator(worksheet ws, const cell_reference &start_cell, major_order order = major_order::row)
2014-05-22 05:48:51 +08:00
: ws_(ws),
current_cell_(start_cell),
range_(start_cell.to_range()),
order_(order)
2014-05-22 05:48:51 +08:00
{
}
2014-07-20 04:59:05 +08:00
cell_vector::iterator::~iterator()
2014-05-22 05:48:51 +08:00
{
}
2014-07-20 04:59:05 +08:00
bool cell_vector::iterator::operator==(const iterator &rhs)
2014-05-22 05:48:51 +08:00
{
return ws_ == rhs.ws_
&& current_cell_ == rhs.current_cell_
&& order_ == rhs.order_;
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell_vector::iterator cell_vector::iterator::operator++(int)
2014-05-22 05:48:51 +08:00
{
iterator old = *this;
++*this;
return old;
}
2014-07-20 04:59:05 +08:00
cell_vector::iterator &cell_vector::iterator::operator++()
2014-05-22 05:48:51 +08:00
{
if(order_ == major_order::row)
{
current_cell_.set_column_index(current_cell_.get_column_index() + 1);
}
else
{
current_cell_.set_row_index(current_cell_.get_row_index() + 1);
}
2014-05-22 05:48:51 +08:00
return *this;
}
2014-07-20 04:59:05 +08:00
cell cell_vector::iterator::operator*()
2014-05-22 05:48:51 +08:00
{
return ws_[current_cell_];
}
cell_vector::const_iterator::const_iterator(worksheet ws, const cell_reference &start_cell, major_order order = major_order::row)
2014-05-22 05:48:51 +08:00
: ws_(ws),
current_cell_(start_cell),
range_(start_cell.to_range()),
order_(order)
2014-05-22 05:48:51 +08:00
{
}
2014-07-20 04:59:05 +08:00
cell_vector::const_iterator::~const_iterator()
2014-05-22 05:48:51 +08:00
{
}
2014-07-20 04:59:05 +08:00
bool cell_vector::const_iterator::operator==(const const_iterator &rhs)
2014-05-22 05:48:51 +08:00
{
return ws_ == rhs.ws_
&& rhs.current_cell_ == current_cell_
&& rhs.order_ == order_;
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell_vector::const_iterator cell_vector::const_iterator::operator++(int)
2014-05-22 05:48:51 +08:00
{
const_iterator old = *this;
++*this;
return old;
}
2014-07-20 04:59:05 +08:00
cell_vector::const_iterator &cell_vector::const_iterator::operator++()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
current_cell_.set_column_index(current_cell_.get_column_index() + 1);
}
else
{
current_cell_.set_row_index(current_cell_.get_row_index() + 1);
}
2014-05-22 05:48:51 +08:00
return *this;
}
2014-07-20 04:59:05 +08:00
const cell cell_vector::const_iterator::operator*()
2014-05-22 05:48:51 +08:00
{
const worksheet ws_const = ws_;
return ws_const[current_cell_];
}
2014-07-20 04:59:05 +08:00
cell_vector::iterator cell_vector::begin()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
return iterator(ws_, ref_.get_top_left(), order_);
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell_vector::iterator cell_vector::end()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
auto past_end = ref_.get_bottom_right();
past_end.set_column_index(past_end.get_column_index() + 1);
return iterator(ws_, past_end, order_);
}
2014-05-22 05:48:51 +08:00
auto past_end = ref_.get_bottom_right();
2014-07-24 04:00:09 +08:00
past_end.set_row_index(past_end.get_row_index() + 1);
return iterator(ws_, past_end, order_);
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell_vector::const_iterator cell_vector::cbegin() const
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
return const_iterator(ws_, ref_.get_top_left(), order_);
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell_vector::const_iterator cell_vector::cend() const
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
auto past_end = ref_.get_bottom_right();
past_end.set_column_index(past_end.get_column_index() + 1);
return const_iterator(ws_, past_end, order_);
}
auto past_end = ref_.get_bottom_right();
past_end.set_row_index(past_end.get_row_index() + 1);
return const_iterator(ws_, past_end, order_);
2014-05-22 05:48:51 +08:00
}
2014-07-24 04:00:09 +08:00
cell cell_vector::operator[](std::size_t cell_index)
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
return get_cell(cell_index);
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
std::size_t cell_vector::num_cells() const
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
return ref_.get_width() + 1;
}
return ref_.get_height() + 1;
2014-05-22 05:48:51 +08:00
}
cell_vector::cell_vector(worksheet ws, const range_reference &reference, major_order order)
2014-05-22 05:48:51 +08:00
: ws_(ws),
ref_(reference),
order_(order)
2014-05-22 05:48:51 +08:00
{
}
2014-07-20 04:59:05 +08:00
cell cell_vector::front()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
return get_cell(ref_.get_top_left().get_column_index());
}
return get_cell(ref_.get_top_left().get_row_index());
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell cell_vector::back()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
return get_cell(ref_.get_bottom_right().get_column_index());
}
return get_cell(ref_.get_top_left().get_row_index());
2014-05-22 05:48:51 +08:00
}
2014-07-24 04:00:09 +08:00
cell cell_vector::get_cell(std::size_t index)
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
return ws_.get_cell(ref_.get_top_left().make_offset((int)index, 0));
}
2014-07-25 05:31:46 +08:00
return ws_.get_cell(ref_.get_top_left().make_offset(0, (int)index));
2014-07-24 04:00:09 +08:00
}
2014-05-22 05:48:51 +08:00
range::range(worksheet ws, const range_reference &reference, major_order order)
2014-05-22 05:48:51 +08:00
: ws_(ws),
ref_(reference),
order_(order)
2014-05-22 05:48:51 +08:00
{
}
range::~range()
{
}
2014-07-20 04:59:05 +08:00
cell_vector range::operator[](std::size_t index)
2014-05-22 05:48:51 +08:00
{
2014-07-20 04:59:05 +08:00
return get_vector(index);
2014-05-22 05:48:51 +08:00
}
range_reference range::get_reference() const
{
return ref_;
}
2014-07-20 04:59:05 +08:00
std::size_t range::length() const
2014-05-22 05:48:51 +08:00
{
if(order_ == major_order::row)
{
return ref_.get_bottom_right().get_row_index() - ref_.get_top_left().get_row_index() + 1;
}
return ref_.get_bottom_right().get_column_index() - ref_.get_top_left().get_column_index() + 1;
2014-05-22 05:48:51 +08:00
}
bool range::operator==(const range &comparand) const
{
return ref_ == comparand.ref_
2014-07-24 04:00:09 +08:00
&& ws_ == comparand.ws_
&& order_ == comparand.order_;
2014-05-22 05:48:51 +08:00
}
2014-07-20 04:59:05 +08:00
cell_vector range::get_vector(std::size_t vector_index)
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
range_reference reference(ref_.get_top_left().get_column_index(),
ref_.get_top_left().get_row_index() + (int)vector_index,
ref_.get_bottom_right().get_column_index(),
ref_.get_top_left().get_row_index() + (int)vector_index);
return cell_vector(ws_, reference, order_);
}
range_reference reference(ref_.get_top_left().get_column_index() + (int)vector_index,
ref_.get_top_left().get_row_index(),
ref_.get_top_left().get_column_index() + (int)vector_index,
ref_.get_bottom_right().get_row_index());
return cell_vector(ws_, reference, order_);
2014-05-22 05:48:51 +08:00
}
cell range::get_cell(const cell_reference &ref)
{
return (*this)[ref.get_row_index()][ref.get_column_index()];
}
range::iterator range::begin()
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
cell_reference top_right(ref_.get_bottom_right().get_column_index(),
ref_.get_top_left().get_row_index());
range_reference row_range(ref_.get_top_left(), top_right);
return iterator(ws_, row_range, order_);
}
cell_reference bottom_left(ref_.get_top_left().get_column_index(),
ref_.get_bottom_right().get_row_index());
range_reference row_range(ref_.get_top_left(), bottom_left);
return iterator(ws_, row_range, order_);
2014-05-22 05:48:51 +08:00
}
range::iterator range::end()
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
auto past_end_row_index = ref_.get_bottom_right().get_row_index() + 1;
cell_reference bottom_left(ref_.get_top_left().get_column_index(), past_end_row_index);
cell_reference bottom_right(ref_.get_bottom_right().get_column_index(), past_end_row_index);
return iterator(ws_, range_reference(bottom_left, bottom_right), order_);
}
auto past_end_column_index = ref_.get_bottom_right().get_column_index() + 1;
cell_reference top_right(past_end_column_index, ref_.get_top_left().get_row_index());
cell_reference bottom_right(past_end_column_index, ref_.get_bottom_right().get_row_index());
return iterator(ws_, range_reference(top_right, bottom_right), order_);
2014-05-22 05:48:51 +08:00
}
range::const_iterator range::cbegin() const
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
cell_reference top_right(ref_.get_bottom_right().get_column_index(),
ref_.get_top_left().get_row_index());
range_reference row_range(ref_.get_top_left(), top_right);
return const_iterator(ws_, row_range, order_);
}
cell_reference bottom_left(ref_.get_top_left().get_column_index(),
ref_.get_bottom_right().get_row_index());
range_reference row_range(ref_.get_top_left(), bottom_left);
return const_iterator(ws_, row_range, order_);
2014-05-22 05:48:51 +08:00
}
range::const_iterator range::cend() const
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
auto past_end_row_index = ref_.get_bottom_right().get_row_index() + 1;
cell_reference bottom_left(ref_.get_top_left().get_column_index(), past_end_row_index);
cell_reference bottom_right(ref_.get_bottom_right().get_column_index(), past_end_row_index);
return const_iterator(ws_, range_reference(bottom_left, bottom_right), order_);
}
auto past_end_column_index = ref_.get_bottom_right().get_column_index() + 1;
cell_reference top_right(past_end_column_index, ref_.get_top_left().get_row_index());
cell_reference bottom_right(past_end_column_index, ref_.get_bottom_right().get_row_index());
return const_iterator(ws_, range_reference(top_right, bottom_right), order_);
2014-05-22 05:48:51 +08:00
}
range::iterator::iterator(worksheet ws, const range_reference &start_cell, major_order order = major_order::row)
2014-05-22 05:48:51 +08:00
: ws_(ws),
current_cell_(start_cell.get_top_left()),
range_(start_cell),
order_(order)
2014-05-22 05:48:51 +08:00
{
}
range::iterator::~iterator()
{
}
bool range::iterator::operator==(const iterator &rhs)
{
return ws_ == rhs.ws_
2014-07-24 04:00:09 +08:00
&& current_cell_ == rhs.current_cell_
&& order_ == rhs.order_;
2014-05-22 05:48:51 +08:00
}
range::iterator range::iterator::operator++(int)
{
iterator old = *this;
++*this;
return old;
}
range::iterator &range::iterator::operator++()
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
current_cell_.set_row_index(current_cell_.get_row_index() + 1);
}
else
{
current_cell_.set_column_index(current_cell_.get_column_index() + 1);
}
2014-05-22 05:48:51 +08:00
return *this;
}
2014-07-20 04:59:05 +08:00
cell_vector range::iterator::operator*()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
range_reference reference(range_.get_top_left().get_column_index(),
current_cell_.get_row_index(),
range_.get_bottom_right().get_column_index(),
current_cell_.get_row_index());
return cell_vector(ws_, reference, order_);
}
range_reference reference(current_cell_.get_column_index(),
range_.get_top_left().get_row_index(),
current_cell_.get_column_index(),
range_.get_bottom_right().get_row_index());
return cell_vector(ws_, reference, order_);
2014-05-22 05:48:51 +08:00
}
range::const_iterator::const_iterator(worksheet ws, const range_reference &start_cell, major_order order = major_order::row)
: ws_(ws),
current_cell_(start_cell.get_top_left()),
range_(start_cell),
order_(order)
2014-05-22 05:48:51 +08:00
{
}
range::const_iterator::~const_iterator()
{
}
bool range::const_iterator::operator==(const const_iterator &rhs)
{
return ws_ == rhs.ws_
2014-07-24 04:00:09 +08:00
&& rhs.current_cell_ == current_cell_
&& order_ == rhs.order_;
2014-05-22 05:48:51 +08:00
}
range::const_iterator range::const_iterator::operator++(int)
{
const_iterator old = *this;
++*this;
return old;
}
range::const_iterator &range::const_iterator::operator++()
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
current_cell_.set_row_index(current_cell_.get_row_index() + 1);
}
else
{
current_cell_.set_column_index(current_cell_.get_column_index() + 1);
}
2014-05-22 05:48:51 +08:00
return *this;
}
2014-07-20 04:59:05 +08:00
const cell_vector range::const_iterator::operator*()
2014-05-22 05:48:51 +08:00
{
2014-07-24 04:00:09 +08:00
if(order_ == major_order::row)
{
range_reference reference(range_.get_top_left().get_column_index(),
current_cell_.get_row_index(),
range_.get_bottom_right().get_column_index(),
current_cell_.get_row_index());
return cell_vector(ws_, reference, order_);
}
range_reference reference(current_cell_.get_column_index(),
range_.get_top_left().get_row_index(),
current_cell_.get_column_index(),
range_.get_bottom_right().get_row_index());
return cell_vector(ws_, reference, order_);
2014-05-22 05:48:51 +08:00
}
} // namespace xlnt