summaryrefslogtreecommitdiff
path: root/sc
diff options
context:
space:
mode:
authorMarkus Mohrhard <markus.mohrhard@googlemail.com>2011-09-24 15:11:02 +0200
committerMarkus Mohrhard <markus.mohrhard@googlemail.com>2011-09-24 16:09:43 +0200
commite9159d142a4f25bff88da3dd90e163135ae0bdfa (patch)
tree3f2f87b1da6078c4eae0b94ff2f7d399560ffb28 /sc
parent3b6fc983f4c29dbe59f19a3451b12ac17b88286f (diff)
handle local range names from name box/navigator correctly
Diffstat (limited to 'sc')
-rw-r--r--sc/source/core/tool/rangeutl.cxx30
1 files changed, 24 insertions, 6 deletions
diff --git a/sc/source/core/tool/rangeutl.cxx b/sc/source/core/tool/rangeutl.cxx
index e0a00dcf3814..d5af7ec99b0a 100644
--- a/sc/source/core/tool/rangeutl.cxx
+++ b/sc/source/core/tool/rangeutl.cxx
@@ -44,6 +44,8 @@
#include "externalrefmgr.hxx"
#include "compiler.hxx"
+#include <iostream>
+
using ::rtl::OUString;
using ::rtl::OUStringBuffer;
using ::formula::FormulaGrammar;
@@ -286,13 +288,29 @@ sal_Bool ScRangeUtil::MakeRangeFromName (
if( eScope==RUTL_NAMES )
{
- //first check for local range names
- ScRangeName* pRangeNames = pDoc->GetRangeName( nCurTab );
+ //first handle ui names like local1 (Sheet1), which point to a local range name
+ rtl::OUString aName(rName);
+ sal_Int32 nEndPos = aName.lastIndexOf(')');
+ sal_Int32 nStartPos = aName.lastIndexOfAsciiL(" (",2);
+ SCTAB nTable = nCurTab;
+ std::cout << "nStartPos: " << nStartPos << " nEndPos: " << nEndPos << std::endl;
+ if (nEndPos != -1 && nStartPos != -1)
+ {
+ rtl::OUString aSheetName = aName.copy(nStartPos+2, nEndPos-nStartPos-2);
+ if (pDoc->GetTable(aSheetName, nTable))
+ {
+ aName = aName.copy(0, nStartPos);
+ }
+ else
+ nTable = nCurTab;
+ }
+ //then check for local range names
+ ScRangeName* pRangeNames = pDoc->GetRangeName( nTable );
ScRangeData* pData = NULL;
if ( pRangeNames )
- pData = pRangeNames->findByName(rName);
+ pData = pRangeNames->findByName(aName);
if (!pData)
- pData = pDoc->GetRangeName()->findByName(rName);
+ pData = pDoc->GetRangeName()->findByName(aName);
if (pData)
{
String aStrArea;
@@ -301,7 +319,7 @@ sal_Bool ScRangeUtil::MakeRangeFromName (
pData->GetSymbol( aStrArea );
- if ( IsAbsArea( aStrArea, pDoc, nCurTab,
+ if ( IsAbsArea( aStrArea, pDoc, nTable,
NULL, &aStartPos, &aEndPos, rDetails ) )
{
nTab = aStartPos.Tab();
@@ -315,7 +333,7 @@ sal_Bool ScRangeUtil::MakeRangeFromName (
{
CutPosString( aStrArea, aStrArea );
- if ( IsAbsPos( aStrArea, pDoc, nCurTab,
+ if ( IsAbsPos( aStrArea, pDoc, nTable,
NULL, &aStartPos, rDetails ) )
{
nTab = aStartPos.Tab();