/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #include "clipparam.hxx" using ::std::vector; ScClipParam::ScClipParam() : meDirection(Unspecified), mbCutMode(false), mnSourceDocID(0) { } ScClipParam::ScClipParam(const ScRange& rRange, bool bCutMode) : meDirection(Unspecified), mbCutMode(bCutMode), mnSourceDocID(0) { maRanges.Append(rRange); } ScClipParam::ScClipParam(const ScClipParam& r) : maRanges(r.maRanges), meDirection(r.meDirection), mbCutMode(r.mbCutMode), mnSourceDocID(r.mnSourceDocID), maProtectedChartRangesVector(r.maProtectedChartRangesVector) { } bool ScClipParam::isMultiRange() const { return maRanges.size() > 1; } SCCOL ScClipParam::getPasteColSize() { if (maRanges.empty()) return 0; switch (meDirection) { case ScClipParam::Column: { SCCOL nColSize = 0; for ( size_t i = 0, nListSize = maRanges.size(); i < nListSize; ++i ) { ScRange* p = maRanges[ i ]; nColSize += p->aEnd.Col() - p->aStart.Col() + 1; } return nColSize; } case ScClipParam::Row: { // We assume that all ranges have identical column size. const ScRange& rRange = *maRanges.front(); return rRange.aEnd.Col() - rRange.aStart.Col() + 1; } case ScClipParam::Unspecified: default: ; } return 0; } SCROW ScClipParam::getPasteRowSize() { if (maRanges.empty()) return 0; switch (meDirection) { case ScClipParam::Column: { // We assume that all ranges have identical row size. const ScRange& rRange = *maRanges.front(); return rRange.aEnd.Row() - rRange.aStart.Row() + 1; } case ScClipParam::Row: { SCROW nRowSize = 0; for ( size_t i = 0, nListSize = maRanges.size(); i < nListSize; ++i ) { ScRange* p = maRanges[ i ]; nRowSize += p->aEnd.Row() - p->aStart.Row() + 1; } return nRowSize; } case ScClipParam::Unspecified: default: ; } return 0; } ScRange ScClipParam::getWholeRange() const { ScRange aWhole; bool bFirst = true; for ( size_t i = 0, n = maRanges.size(); i < n; ++i ) { const ScRange* p = maRanges[i]; if (bFirst) { aWhole = *p; bFirst = false; continue; } if (aWhole.aStart.Col() > p->aStart.Col()) aWhole.aStart.SetCol(p->aStart.Col()); if (aWhole.aStart.Row() > p->aStart.Row()) aWhole.aStart.SetRow(p->aStart.Row()); if (aWhole.aEnd.Col() < p->aEnd.Col()) aWhole.aEnd.SetCol(p->aEnd.Col()); if (aWhole.aEnd.Row() < p->aEnd.Row()) aWhole.aEnd.SetRow(p->aEnd.Row()); } return aWhole; } void ScClipParam::transpose() { switch (meDirection) { case Column: meDirection = ScClipParam::Row; break; case Row: meDirection = ScClipParam::Column; break; case Unspecified: default: ; } ScRangeList aNewRanges; if (!maRanges.empty()) { ScRange* p = maRanges.front(); SCCOL nColOrigin = p->aStart.Col(); SCROW nRowOrigin = p->aStart.Row(); for ( size_t i = 0, n = maRanges.size(); i < n; ++i ) { p = maRanges[ i ]; SCCOL nColDelta = p->aStart.Col() - nColOrigin; SCROW nRowDelta = p->aStart.Row() - nRowOrigin; SCCOL nCol1 = 0; SCCOL nCol2 = static_cast(p->aEnd.Row() - p->aStart.Row()); SCROW nRow1 = 0; SCROW nRow2 = static_cast(p->aEnd.Col() - p->aStart.Col()); nCol1 += static_cast(nRowDelta); nCol2 += static_cast(nRowDelta); nRow1 += static_cast(nColDelta); nRow2 += static_cast(nColDelta); aNewRanges.push_back( new ScRange(nCol1, nRow1, p->aStart.Tab(), nCol2, nRow2, p->aStart.Tab() ) ); } } maRanges = aNewRanges; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */