/* -*- 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 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; } SetFormulaDirtyContext::SetFormulaDirtyContext() : mnTabDeletedStart(-1), mnTabDeletedEnd(-1), mbClearTabDeletedFlag(false) {} } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */