summaryrefslogtreecommitdiff
path: root/sc/inc/columniterator.hxx
blob: c6a87b4e6b39611bd78434c3248f0b290b052948 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 */

#ifndef INCLUDED_SC_INC_COLUMNITERATOR_HXX
#define INCLUDED_SC_INC_COLUMNITERATOR_HXX

#include "column.hxx"

class ScColumnTextWidthIterator
{
    sc::CellTextAttrStoreType& mrCellTextAttrs;
    const size_t mnEnd;
    size_t mnCurPos;
    sc::CellTextAttrStoreType::iterator miBlockCur;
    sc::CellTextAttrStoreType::iterator miBlockEnd;
    sc::celltextattr_block::iterator miDataCur;
    sc::celltextattr_block::iterator miDataEnd;

public:
    ScColumnTextWidthIterator(const ScColumnTextWidthIterator&) = delete;
    const ScColumnTextWidthIterator& operator=(const ScColumnTextWidthIterator&) = delete;
    ScColumnTextWidthIterator(ScColumn& rCol, SCROW nStartRow, SCROW nEndRow);

    /**
     * @param rDoc document instance.
     * @param rStartPos position of the first cell from which to start
     *                  iteration. Note that the caller must ensure that this
     *                  position is valid; the constructor does not check its
     *                  validity.
     * @param nEndRow end row position.
     */
    ScColumnTextWidthIterator(ScDocument& rDoc, const ScAddress& rStartPos, SCROW nEndRow);

    void next();
    bool hasCell() const;
    SCROW getPos() const;
    sal_uInt16 getValue() const;
    void setValue(sal_uInt16 nVal);

private:
    void init(SCROW nStartRow, SCROW nEndRow);
    void getDataIterators(size_t nOffsetInBlock);
    void checkEndRow();
};

namespace sc {

/**
 * This iterator lets you iterate over cells over specified range in a
 * single column.  It does not modify the state of the cells, and therefore
 * is thread safe.
 */
class ColumnIterator
{
    CellStoreType::const_position_type maPos;
    CellStoreType::const_position_type maPosEnd;

public:
    ColumnIterator( const CellStoreType& rCells, SCROW nRow1, SCROW nRow2 );
    ~ColumnIterator();

    void next();

    SCROW getRow() const;

    bool hasCell() const;

    mdds::mtv::element_t getType() const;

    ScRefCellValue getCell() const;
};

}

#endif

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */