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
101
102
103
104
105
106
107
108
109
110
|
/* -*- 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 "tokenstringcontext.hxx"
#include "compiler.hxx"
#include "document.hxx"
#include "dbdata.hxx"
#include "externalrefmgr.hxx"
using namespace com::sun::star;
namespace sc {
namespace {
void insertAllNames( TokenStringContext::IndexNameMapType& rMap, const ScRangeName& rNames )
{
ScRangeName::const_iterator it = rNames.begin(), itEnd = rNames.end();
for (; it != itEnd; ++it)
{
const ScRangeData* pData = it->second;
rMap.insert(
TokenStringContext::IndexNameMapType::value_type(pData->GetIndex(), pData->GetName()));
}
}
}
TokenStringContext::TokenStringContext( const ScDocument* pDoc, formula::FormulaGrammar::Grammar eGram ) :
meGram(eGram),
mpRefConv(ScCompiler::GetRefConvention(formula::FormulaGrammar::extractRefConvention(eGram)))
{
ScCompiler aComp(NULL, ScAddress());
mxOpCodeMap = aComp.GetOpCodeMap(formula::FormulaGrammar::extractFormulaLanguage(eGram));
if (mxOpCodeMap)
maErrRef = mxOpCodeMap->getSymbol(ocErrRef);
if (!pDoc)
return;
// Fetch all sheet names.
maTabNames = pDoc->GetAllTableNames();
{
std::vector<OUString>::iterator it = maTabNames.begin(), itEnd = maTabNames.end();
for (; it != itEnd; ++it)
ScCompiler::CheckTabQuotes(*it, formula::FormulaGrammar::extractRefConvention(eGram));
}
// Fetch all named range names.
const ScRangeName* pNames = pDoc->GetRangeName();
if (pNames)
// global names
insertAllNames(maGlobalRangeNames, *pNames);
{
ScRangeName::TabNameCopyMap aTabRangeNames;
pDoc->GetAllTabRangeNames(aTabRangeNames);
ScRangeName::TabNameCopyMap::const_iterator it = aTabRangeNames.begin(), itEnd = aTabRangeNames.end();
for (; it != itEnd; ++it)
{
const ScRangeName* pSheetNames = it->second;
if (!pSheetNames)
continue;
SCTAB nTab = it->first;
IndexNameMapType aNames;
insertAllNames(aNames, *pSheetNames);
maSheetRangeNames.insert(TabIndexMapType::value_type(nTab, aNames));
}
}
// Fetch all named database ranges names.
const ScDBCollection* pDBs = pDoc->GetDBCollection();
if (pDBs)
{
const ScDBCollection::NamedDBs& rNamedDBs = pDBs->getNamedDBs();
ScDBCollection::NamedDBs::const_iterator it = rNamedDBs.begin(), itEnd = rNamedDBs.end();
for (; it != itEnd; ++it)
{
const ScDBData& rData = *it;
maNamedDBs.insert(IndexNameMapType::value_type(rData.GetIndex(), rData.GetName()));
}
}
// Fetch all relevant bits for external references.
if (pDoc->HasExternalRefManager())
{
const ScExternalRefManager* pRefMgr = pDoc->GetExternalRefManager();
maExternalFileNames = pRefMgr->getAllCachedExternalFileNames();
for (size_t i = 0, n = maExternalFileNames.size(); i < n; ++i)
{
sal_uInt16 nFileId = static_cast<sal_uInt16>(i);
std::vector<OUString> aTabNames;
pRefMgr->getAllCachedTableNames(nFileId, aTabNames);
if (!aTabNames.empty())
maExternalCachedTabNames.insert(
IndexNamesMapType::value_type(nFileId, aTabNames));
}
}
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|