Files
libreoffice/sc/source/core/tool/tokenstringcontext.cxx
Eike Rathke 8898a23595 assert OpCodeMap and fallback-init maErrRef
Change-Id: I1e289c6891f3d0273104a909428a4aa0daeb738f
2016-05-10 13:21:49 +02:00

147 lines
4.6 KiB
C++

/* -*- 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"
#include "globstr.hrc"
using namespace com::sun::star;
namespace sc {
namespace {
void insertAllNames( TokenStringContext::IndexNameMapType& rMap, const ScRangeName& rNames )
{
for (auto const& it : rNames)
{
const ScRangeData *const pData = it.second.get();
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(nullptr, ScAddress());
mxOpCodeMap = aComp.GetOpCodeMap(formula::FormulaGrammar::extractFormulaLanguage(eGram));
if (mxOpCodeMap)
maErrRef = mxOpCodeMap->getSymbol(ocErrRef);
else
{
assert(!"TokenStringContext - no OpCodeMap?!?");
maErrRef = ScGlobal::GetRscString(STR_NO_REF_TABLE);
}
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));
}
}
}
CompileFormulaContext::CompileFormulaContext( ScDocument* pDoc ) :
mpDoc(pDoc), meGram(pDoc->GetGrammar())
{
updateTabNames();
}
CompileFormulaContext::CompileFormulaContext( ScDocument* pDoc, formula::FormulaGrammar::Grammar eGram ) :
mpDoc(pDoc), meGram(eGram)
{
updateTabNames();
}
void CompileFormulaContext::updateTabNames()
{
// Fetch all sheet names.
maTabNames = mpDoc->GetAllTableNames();
{
std::vector<OUString>::iterator it = maTabNames.begin(), itEnd = maTabNames.end();
for (; it != itEnd; ++it)
ScCompiler::CheckTabQuotes(*it, formula::FormulaGrammar::extractRefConvention(meGram));
}
}
void CompileFormulaContext::setGrammar( formula::FormulaGrammar::Grammar eGram )
{
bool bUpdate = (meGram != eGram);
meGram = eGram;
if (bUpdate)
updateTabNames();
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */