andre@1: /**************************************************************************** andre@1: ** Copyright (c) 2013-2014 Debao Zhang andre@1: ** All right reserved. andre@1: ** andre@1: ** Permission is hereby granted, free of charge, to any person obtaining andre@1: ** a copy of this software and associated documentation files (the andre@1: ** "Software"), to deal in the Software without restriction, including andre@1: ** without limitation the rights to use, copy, modify, merge, publish, andre@1: ** distribute, sublicense, and/or sell copies of the Software, and to andre@1: ** permit persons to whom the Software is furnished to do so, subject to andre@1: ** the following conditions: andre@1: ** andre@1: ** The above copyright notice and this permission notice shall be andre@1: ** included in all copies or substantial portions of the Software. andre@1: ** andre@1: ** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, andre@1: ** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF andre@1: ** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND andre@1: ** NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE andre@1: ** LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION andre@1: ** OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION andre@1: ** WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. andre@1: ** andre@1: ****************************************************************************/ andre@1: #ifndef QXLSX_XLSXCELLRANGE_H andre@1: #define QXLSX_XLSXCELLRANGE_H andre@1: #include "xlsxglobal.h" andre@1: #include "xlsxcellreference.h" andre@1: andre@1: QT_BEGIN_NAMESPACE_XLSX andre@1: andre@1: class Q_XLSX_EXPORT CellRange andre@1: { andre@1: public: andre@1: CellRange(); andre@1: CellRange(int firstRow, int firstColumn, int lastRow, int lastColumn); andre@1: CellRange(const CellReference &topLeft, const CellReference &bottomRight); andre@1: CellRange(const QString &range); andre@1: CellRange(const char *range); andre@1: CellRange(const CellRange &other); andre@1: ~CellRange(); andre@1: andre@1: QString toString(bool row_abs=false, bool col_abs=false) const; andre@1: bool isValid() const; andre@1: inline void setFirstRow(int row) { top = row; } andre@1: inline void setLastRow(int row) { bottom = row; } andre@1: inline void setFirstColumn(int col) { left = col; } andre@1: inline void setLastColumn(int col) { right = col; } andre@1: inline int firstRow() const { return top; } andre@1: inline int lastRow() const { return bottom; } andre@1: inline int firstColumn() const { return left; } andre@1: inline int lastColumn() const { return right; } andre@1: inline int rowCount() const { return bottom - top + 1; } andre@1: inline int columnCount() const { return right - left + 1; } andre@1: inline CellReference topLeft() const { return CellReference(top, left); } andre@1: inline CellReference topRight() const { return CellReference(top, right); } andre@1: inline CellReference bottomLeft() const { return CellReference(bottom, left); } andre@1: inline CellReference bottomRight() const { return CellReference(bottom, right); } andre@1: andre@1: inline bool operator ==(const CellRange &other) const andre@1: { andre@1: return top==other.top && bottom==other.bottom andre@1: && left == other.left && right == other.right; andre@1: } andre@1: inline bool operator !=(const CellRange &other) const andre@1: { andre@1: return top!=other.top || bottom!=other.bottom andre@1: || left != other.left || right != other.right; andre@1: } andre@1: private: andre@1: void init(const QString &range); andre@1: int top, left, bottom, right; andre@1: }; andre@1: andre@1: QT_END_NAMESPACE_XLSX andre@1: andre@1: Q_DECLARE_TYPEINFO(QXlsx::CellRange, Q_MOVABLE_TYPE); andre@1: andre@1: #endif // QXLSX_XLSXCELLRANGE_H