diff options
author | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2011-08-16 23:12:50 +0200 |
---|---|---|
committer | Markus Mohrhard <markus.mohrhard@googlemail.com> | 2011-08-16 23:12:50 +0200 |
commit | 74070a021389534b9e791980bd33ede45be9fd81 (patch) | |
tree | 0b95d9dbd70f4505c2631c2249b8dec5c258029e | |
parent | d7791df329a6bcf315506bb2ec4e6cc0f07309b9 (diff) |
rework 04d2e6469529b6187900659517d6f6dd5ea2cca5
only update range names in formulas if the documents are different or
the sheets are different
-rw-r--r-- | sc/source/core/data/cell.cxx | 39 | ||||
-rw-r--r-- | sc/source/core/data/table2.cxx | 2 |
2 files changed, 22 insertions, 19 deletions
diff --git a/sc/source/core/data/cell.cxx b/sc/source/core/data/cell.cxx index 1eb4433da878..4d030ccd6aea 100644 --- a/sc/source/core/data/cell.cxx +++ b/sc/source/core/data/cell.cxx @@ -131,7 +131,7 @@ ScBaseCell* lclCloneCell( const ScBaseCell& rSrcCell, ScDocument& rDestDoc, cons return 0; } -void adjustRangeName(ScToken* pToken, ScDocument& aNewDoc, ScDocument* pOldDoc, ScAddress aNewPos, ScAddress aOldPos) +void adjustRangeName(ScToken* pToken, ScDocument& rNewDoc, const ScDocument* pOldDoc, const ScAddress& aNewPos, const ScAddress& aOldPos) { bool bOldGlobal = static_cast<bool>(pToken->GetByte()); SCTAB aOldTab = aOldPos.Tab(); @@ -158,35 +158,35 @@ void adjustRangeName(ScToken* pToken, ScDocument& aNewDoc, ScDocument* pOldDoc, //find corresponding range name in new document //first search for local range name then global range names SCTAB aNewTab = aNewPos.Tab(); - ScRangeName* pRangeName = aNewDoc.GetRangeName(aNewTab); + ScRangeName* pRangeName = rNewDoc.GetRangeName(aNewTab); ScRangeData* pRangeData = NULL; bool bNewGlobal = false; //search local range names if (pRangeName) { - pRangeData = pRangeName->findByUpperName(aRangeName.toAsciiUpperCase()); + pRangeData = pRangeName->findByUpperName(ScGlobal::pCharClass->upper(aRangeName)); } //search global range names if (!pRangeData) { //even if it is not in the global scope we'll have a global range name bNewGlobal = true; - pRangeName = aNewDoc.GetRangeName(); + pRangeName = rNewDoc.GetRangeName(); if (pRangeName) - pRangeData = pRangeName->findByUpperName(aRangeName.toAsciiUpperCase()); + pRangeData = pRangeName->findByUpperName(ScGlobal::pCharClass->upper(aRangeName)); } //if no range name was found copy it if (!pRangeData) { - pRangeData = new ScRangeData(*pOldRangeData, &aNewDoc); - aNewDoc.GetRangeName()->insert(pRangeData); + pRangeData = new ScRangeData(*pOldRangeData, &rNewDoc); + rNewDoc.GetRangeName()->insert(pRangeData); } sal_Int32 nIndex = pRangeData->GetIndex(); pToken->SetIndex(nIndex); pToken->SetByte(bNewGlobal); } -void adjustDBRange(ScToken* pToken, ScDocument& aNewDoc, ScDocument* pOldDoc) +void adjustDBRange(ScToken* pToken, ScDocument& rNewDoc, const ScDocument* pOldDoc) { ScDBCollection* pOldDBCollection = pOldDoc->GetDBCollection(); if (!pOldDBCollection) @@ -198,10 +198,10 @@ void adjustDBRange(ScToken* pToken, ScDocument& aNewDoc, ScDocument* pOldDoc) rtl::OUString aDBName = pDBData->GetName(); //search in new document - ScDBCollection* pNewDBCollection = aNewDoc.GetDBCollection(); + ScDBCollection* pNewDBCollection = rNewDoc.GetDBCollection(); if (!pNewDBCollection) { - pNewDBCollection = new ScDBCollection(&aNewDoc); + pNewDBCollection = new ScDBCollection(&rNewDoc); } ScDBCollection::NamedDBs& aNewNamedDBs = pNewDBCollection->getNamedDBs(); ScDBData* pNewDBData = aNewNamedDBs.findByName(aDBName); @@ -855,16 +855,19 @@ ScFormulaCell::ScFormulaCell( const ScFormulaCell& rCell, ScDocument& rDoc, cons sal_Bool bClipMode = rCell.pDocument->IsClipboard(); //update ScNameTokens - if (!pDocument->IsClipboard()) + if (!pDocument->IsClipOrUndo() || rDoc.IsUndo()) { - ScToken* pToken = NULL; - while((pToken = static_cast<ScToken*>(pCode->GetNextName()))!= NULL) + if (!pDocument->IsClipboardSource() || aPos.Tab() != rCell.aPos.Tab()) { - OpCode eOpCode = pToken->GetOpCode(); - if (eOpCode == ocName) - adjustRangeName(pToken, rDoc, rCell.pDocument, aPos, rCell.aPos); - else if (eOpCode == ocDBArea) - adjustDBRange(pToken, rDoc, rCell.pDocument); + ScToken* pToken = NULL; + while((pToken = static_cast<ScToken*>(pCode->GetNextName()))!= NULL) + { + OpCode eOpCode = pToken->GetOpCode(); + if (eOpCode == ocName) + adjustRangeName(pToken, rDoc, rCell.pDocument, aPos, rCell.aPos); + else if (eOpCode == ocDBArea) + adjustDBRange(pToken, rDoc, rCell.pDocument); + } } } diff --git a/sc/source/core/data/table2.cxx b/sc/source/core/data/table2.cxx index a11d0c6e8f92..353063184f02 100644 --- a/sc/source/core/data/table2.cxx +++ b/sc/source/core/data/table2.cxx @@ -465,7 +465,7 @@ void ScTable::CopyToClip(SCCOL nCol1, SCROW nRow1, SCCOL nCol2, SCROW nRow2, { // copy content //local range names need to be copied first for formula cells - if (!pTable->mpRangeName) + if (!pTable->mpRangeName && mpRangeName) pTable->mpRangeName = new ScRangeName(*mpRangeName); SCCOL i; |