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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
|
/* -*- 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/.
*/
#include "refupdatecontext.hxx"
namespace sc {
void UpdatedRangeNames::setUpdatedName(SCTAB nTab, sal_uInt16 nIndex)
{
UpdatedNamesType::iterator it = maUpdatedNames.find(nTab);
if (it == maUpdatedNames.end())
{
// Insert a new container for this sheet index.
NameIndicesType aIndices;
std::pair<UpdatedNamesType::iterator,bool> r =
maUpdatedNames.insert(UpdatedNamesType::value_type(nTab, aIndices));
if (!r.second)
// Insertion failed for whatever reason.
return;
it = r.first;
}
NameIndicesType& rIndices = it->second;
rIndices.insert(nIndex);
}
bool UpdatedRangeNames::isNameUpdated(SCTAB nTab, sal_uInt16 nIndex) const
{
UpdatedNamesType::const_iterator it = maUpdatedNames.find(nTab);
if (it == maUpdatedNames.end())
return false;
const NameIndicesType& rIndices = it->second;
return rIndices.count(nIndex) > 0;
}
RefUpdateContext::RefUpdateContext(ScDocument& rDoc) :
mrDoc(rDoc), meMode(URM_INSDEL), mnColDelta(0), mnRowDelta(0), mnTabDelta(0) {}
bool RefUpdateContext::isInserted() const
{
return (meMode == URM_INSDEL) && (mnColDelta > 0 || mnRowDelta > 0 || mnTabDelta > 0);
}
bool RefUpdateContext::isDeleted() const
{
return (meMode == URM_INSDEL) && (mnColDelta < 0 || mnRowDelta < 0 || mnTabDelta < 0);
}
RefUpdateResult::RefUpdateResult() : mbValueChanged(false), mbReferenceModified(false), mbNameModified(false) {}
RefUpdateResult::RefUpdateResult(const RefUpdateResult& r) :
mbValueChanged(r.mbValueChanged),
mbReferenceModified(r.mbReferenceModified),
mbNameModified(r.mbNameModified) {}
RefUpdateInsertTabContext::RefUpdateInsertTabContext(SCTAB nInsertPos, SCTAB nSheets) :
mnInsertPos(nInsertPos), mnSheets(nSheets) {}
RefUpdateDeleteTabContext::RefUpdateDeleteTabContext(SCTAB nDeletePos, SCTAB nSheets) :
mnDeletePos(nDeletePos), mnSheets(nSheets) {}
RefUpdateMoveTabContext::RefUpdateMoveTabContext(SCTAB nOldPos, SCTAB nNewPos) :
mnOldPos(nOldPos), mnNewPos(nNewPos) {}
SCTAB RefUpdateMoveTabContext::getNewTab(SCTAB nOldTab) const
{
// Sheets below the lower bound or above the uppper bound will not change.
SCTAB nLowerBound = std::min(mnOldPos, mnNewPos);
SCTAB nUpperBound = std::max(mnOldPos, mnNewPos);
if (nOldTab < nLowerBound || nUpperBound < nOldTab)
// Outside the boundary. Nothing to adjust.
return nOldTab;
if (nOldTab == mnOldPos)
return mnNewPos;
// It's somewhere in between.
if (mnOldPos < mnNewPos)
{
// Moving a sheet to the right. The rest of the sheets shifts to the left.
return nOldTab - 1;
}
// Moving a sheet to the left. The rest of the sheets shifts to the right.
return nOldTab + 1;
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|