xlnt/source/range.cpp

255 lines
7.2 KiB
C++
Raw Normal View History

2014-08-14 06:56:34 +08:00
#include <xlnt/worksheet/range.hpp>
#include <xlnt/cell/cell.hpp>
#include <xlnt/worksheet/range_reference.hpp>
#include <xlnt/worksheet/worksheet.hpp>
2014-05-22 05:48:51 +08:00
namespace xlnt {
template<>
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_];
}
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();
past_end.set_row(past_end.get_row() + 1);
2014-07-24 04:00:09 +08:00
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(past_end.get_row() + 1);
2014-07-24 04:00:09 +08:00
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());
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());
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() - ref_.get_top_left().get_row() + 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() + (int)vector_index,
2014-07-24 04:00:09 +08:00
ref_.get_bottom_right().get_column_index(),
ref_.get_top_left().get_row() + (int)vector_index);
2014-07-24 04:00:09 +08:00
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(),
2014-07-24 04:00:09 +08:00
ref_.get_top_left().get_column_index() + (int)vector_index,
ref_.get_bottom_right().get_row());
2014-07-24 04:00:09 +08:00
return cell_vector(ws_, reference, order_);
2014-05-22 05:48:51 +08:00
}
bool range::contains(const cell_reference &ref)
{
return ref_.get_top_left().get_column_index() <= ref.get_column_index() && ref_.get_bottom_right().get_column_index() >= ref.get_column_index() && ref_.get_top_left().get_row() <= ref.get_row() && ref_.get_bottom_right().get_row() >= ref.get_row();
}
2014-05-22 05:48:51 +08:00
cell range::get_cell(const cell_reference &ref)
{
return (*this)[ref.get_row()][ref.get_column_index()];
2014-05-22 05:48:51 +08:00
}
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());
2014-07-24 04:00:09 +08:00
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());
2014-07-24 04:00:09 +08:00
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() + 1;
2014-07-24 04:00:09 +08:00
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());
cell_reference bottom_right(past_end_column_index, ref_.get_bottom_right().get_row());
2014-07-24 04:00:09 +08:00
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());
2014-07-24 04:00:09 +08:00
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());
2014-07-24 04:00:09 +08:00
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() + 1;
2014-07-24 04:00:09 +08:00
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());
cell_reference bottom_right(past_end_column_index, ref_.get_bottom_right().get_row());
2014-07-24 04:00:09 +08:00
return const_iterator(ws_, range_reference(top_right, bottom_right), order_);
2014-05-22 05:48:51 +08:00
}
template<>
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(),
2014-07-24 04:00:09 +08:00
range_.get_bottom_right().get_column_index(),
current_cell_.get_row());
2014-07-24 04:00:09 +08:00
return cell_vector(ws_, reference, order_);
}
range_reference reference(current_cell_.get_column_index(),
range_.get_top_left().get_row(),
2014-07-24 04:00:09 +08:00
current_cell_.get_column_index(),
range_.get_bottom_right().get_row());
2014-07-24 04:00:09 +08:00
return cell_vector(ws_, reference, order_);
2014-05-22 05:48:51 +08:00
}
} // namespace xlnt