1*b1cdbd2cSJim Jagielski /************************************************************** 2*b1cdbd2cSJim Jagielski * 3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one 4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file 5*b1cdbd2cSJim Jagielski * distributed with this work for additional information 6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file 7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the 8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance 9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at 10*b1cdbd2cSJim Jagielski * 11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0 12*b1cdbd2cSJim Jagielski * 13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing, 14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an 15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the 17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations 18*b1cdbd2cSJim Jagielski * under the License. 19*b1cdbd2cSJim Jagielski * 20*b1cdbd2cSJim Jagielski *************************************************************/ 21*b1cdbd2cSJim Jagielski 22*b1cdbd2cSJim Jagielski 23*b1cdbd2cSJim Jagielski 24*b1cdbd2cSJim Jagielski #ifndef _SVX_CELLTYPES_HXX_ 25*b1cdbd2cSJim Jagielski #define _SVX_CELLTYPES_HXX_ 26*b1cdbd2cSJim Jagielski 27*b1cdbd2cSJim Jagielski #include <rtl/ref.hxx> 28*b1cdbd2cSJim Jagielski #include <vector> 29*b1cdbd2cSJim Jagielski 30*b1cdbd2cSJim Jagielski namespace sdr { namespace table { 31*b1cdbd2cSJim Jagielski 32*b1cdbd2cSJim Jagielski class Cell; 33*b1cdbd2cSJim Jagielski class TableModel; 34*b1cdbd2cSJim Jagielski class TableRow; 35*b1cdbd2cSJim Jagielski class TableColumn; 36*b1cdbd2cSJim Jagielski class TableRows; 37*b1cdbd2cSJim Jagielski class TableColumns; 38*b1cdbd2cSJim Jagielski typedef rtl::Reference< Cell > CellRef; 39*b1cdbd2cSJim Jagielski typedef rtl::Reference< TableModel > TableModelRef; 40*b1cdbd2cSJim Jagielski typedef rtl::Reference< TableRow > TableRowRef; 41*b1cdbd2cSJim Jagielski typedef rtl::Reference< TableColumn > TableColumnRef; 42*b1cdbd2cSJim Jagielski typedef rtl::Reference< TableRows > TableRowsRef; 43*b1cdbd2cSJim Jagielski typedef rtl::Reference< TableColumns > TableColumnsRef; 44*b1cdbd2cSJim Jagielski typedef std::vector< CellRef > CellVector; 45*b1cdbd2cSJim Jagielski typedef std::vector< TableRowRef > RowVector; 46*b1cdbd2cSJim Jagielski typedef std::vector< TableColumnRef > ColumnVector; 47*b1cdbd2cSJim Jagielski 48*b1cdbd2cSJim Jagielski class TableDesignUser 49*b1cdbd2cSJim Jagielski { 50*b1cdbd2cSJim Jagielski public: 51*b1cdbd2cSJim Jagielski virtual bool isInUse() = 0; 52*b1cdbd2cSJim Jagielski }; 53*b1cdbd2cSJim Jagielski 54*b1cdbd2cSJim Jagielski template< typename T > 55*b1cdbd2cSJim Jagielski class RangeIterator 56*b1cdbd2cSJim Jagielski { 57*b1cdbd2cSJim Jagielski public: 58*b1cdbd2cSJim Jagielski /** creates an iterator from rStart (including) to rEnd (excluding) if 59*b1cdbd2cSJim Jagielski bForeward is true or from nEnd (excluding to nStart (including). 60*b1cdbd2cSJim Jagielski rStart must be <= rEnd. 61*b1cdbd2cSJim Jagielski */ RangeIterator(const T & rStart,const T & rEnd,bool bForeward=true)62*b1cdbd2cSJim Jagielski RangeIterator( const T& rStart, const T& rEnd, bool bForeward = true ) 63*b1cdbd2cSJim Jagielski { 64*b1cdbd2cSJim Jagielski if( bForeward ) 65*b1cdbd2cSJim Jagielski { 66*b1cdbd2cSJim Jagielski maIter = rStart; 67*b1cdbd2cSJim Jagielski maEnd = rEnd; 68*b1cdbd2cSJim Jagielski } 69*b1cdbd2cSJim Jagielski else 70*b1cdbd2cSJim Jagielski { 71*b1cdbd2cSJim Jagielski maIter = rEnd-1; 72*b1cdbd2cSJim Jagielski maEnd = rStart-1; 73*b1cdbd2cSJim Jagielski } 74*b1cdbd2cSJim Jagielski } 75*b1cdbd2cSJim Jagielski 76*b1cdbd2cSJim Jagielski /* returns true if the next call to next() will return true also. */ hasNext() const77*b1cdbd2cSJim Jagielski bool hasNext() const 78*b1cdbd2cSJim Jagielski { 79*b1cdbd2cSJim Jagielski return maIter != maEnd; 80*b1cdbd2cSJim Jagielski } 81*b1cdbd2cSJim Jagielski 82*b1cdbd2cSJim Jagielski /* iterates in the configured direction and returns true if rValue 83*b1cdbd2cSJim Jagielski now contains a valid positon in the range of this iterator */ next(T & rValue)84*b1cdbd2cSJim Jagielski bool next( T& rValue ) 85*b1cdbd2cSJim Jagielski { 86*b1cdbd2cSJim Jagielski if( maIter == maEnd ) 87*b1cdbd2cSJim Jagielski return false; 88*b1cdbd2cSJim Jagielski 89*b1cdbd2cSJim Jagielski rValue = maIter; 90*b1cdbd2cSJim Jagielski if( maIter < maEnd ) 91*b1cdbd2cSJim Jagielski maIter++; 92*b1cdbd2cSJim Jagielski else 93*b1cdbd2cSJim Jagielski maIter--; 94*b1cdbd2cSJim Jagielski return true; 95*b1cdbd2cSJim Jagielski } 96*b1cdbd2cSJim Jagielski 97*b1cdbd2cSJim Jagielski private: 98*b1cdbd2cSJim Jagielski T maEnd; 99*b1cdbd2cSJim Jagielski T maIter; 100*b1cdbd2cSJim Jagielski }; 101*b1cdbd2cSJim Jagielski 102*b1cdbd2cSJim Jagielski } } 103*b1cdbd2cSJim Jagielski 104*b1cdbd2cSJim Jagielski #endif 105*b1cdbd2cSJim Jagielski 106