/* -*- 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/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include "olinefun.hxx" #include "docsh.hxx" #include "olinetab.hxx" #include "undodat.hxx" #include "globstr.hrc" #include "sc.hrc" static void lcl_InvalidateOutliner( SfxBindings* pBindings ) { if ( pBindings ) { pBindings->Invalidate( SID_OUTLINE_SHOW ); pBindings->Invalidate( SID_OUTLINE_HIDE ); pBindings->Invalidate( SID_OUTLINE_REMOVE ); pBindings->Invalidate( SID_STATUS_SUM ); // wegen ein-/ausblenden pBindings->Invalidate( SID_ATTR_SIZE ); } } //! PaintWidthHeight zur DocShell verschieben? static void lcl_PaintWidthHeight( ScDocShell& rDocShell, SCTAB nTab, bool bColumns, SCCOLROW nStart, SCCOLROW nEnd ) { ScDocument* pDoc = rDocShell.GetDocument(); sal_uInt16 nParts = PAINT_GRID; SCCOL nStartCol = 0; SCROW nStartRow = 0; SCCOL nEndCol = MAXCOL; // fuer Test auf Merge SCROW nEndRow = MAXROW; if ( bColumns ) { nParts |= PAINT_TOP; nStartCol = static_cast(nStart); nEndCol = static_cast(nEnd); } else { nParts |= PAINT_LEFT; nStartRow = nStart; nEndRow = nEnd; } if (pDoc->HasAttrib( nStartCol,nStartRow,nTab, nEndCol,nEndRow,nTab, HASATTR_MERGED | HASATTR_OVERLAPPED )) { nStartCol = 0; nStartRow = 0; } rDocShell.PostPaint( nStartCol,nStartRow,nTab, MAXCOL,MAXROW,nTab, nParts ); } bool ScOutlineDocFunc::MakeOutline( const ScRange& rRange, bool bColumns, bool bRecord, bool bApi ) { bool bSuccess = false; SCCOL nStartCol = rRange.aStart.Col(); SCROW nStartRow = rRange.aStart.Row(); SCCOL nEndCol = rRange.aEnd.Col(); SCROW nEndRow = rRange.aEnd.Row(); SCTAB nTab = rRange.aStart.Tab(); ScDocument* pDoc = rDocShell.GetDocument(); ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab, true ); ScOutlineTable* pUndoTab = NULL; if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; if (bRecord) pUndoTab = new ScOutlineTable( *pTable ); ScOutlineArray* pArray = bColumns ? pTable->GetColArray() : pTable->GetRowArray(); bool bRes; bool bSize = false; if ( bColumns ) bRes = pArray->Insert( nStartCol, nEndCol, bSize ); else bRes = pArray->Insert( nStartRow, nEndRow, bSize ); if ( bRes ) { if (bRecord) { rDocShell.GetUndoManager()->AddUndoAction( new ScUndoMakeOutline( &rDocShell, nStartCol,nStartRow,nTab,nEndCol,nEndRow,nTab, pUndoTab, bColumns, true ) ); } if (pDoc->IsStreamValid(nTab)) pDoc->SetStreamValid(nTab, false); sal_uInt16 nParts = 0; // Datenbereich nicht geaendert if ( bColumns ) nParts |= PAINT_TOP; else nParts |= PAINT_LEFT; if ( bSize ) nParts |= PAINT_SIZE; rDocShell.PostPaint( 0,0,nTab, MAXCOL,MAXROW,nTab, nParts ); rDocShell.SetDocumentModified(); lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); bSuccess = true; } else { if (!bApi) rDocShell.ErrorMessage(STR_MSSG_MAKEOUTLINE_0); // "Gruppierung nicht moeglich" delete pUndoTab; } return bSuccess; } bool ScOutlineDocFunc::RemoveOutline( const ScRange& rRange, bool bColumns, bool bRecord, bool bApi ) { bool bDone = false; SCCOL nStartCol = rRange.aStart.Col(); SCROW nStartRow = rRange.aStart.Row(); SCCOL nEndCol = rRange.aEnd.Col(); SCROW nEndRow = rRange.aEnd.Row(); SCTAB nTab = rRange.aStart.Tab(); ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); if (pTable) { ScOutlineTable* pUndoTab = NULL; if (bRecord) pUndoTab = new ScOutlineTable( *pTable ); ScOutlineArray* pArray = bColumns ? pTable->GetColArray() : pTable->GetRowArray(); bool bRes; bool bSize = false; if ( bColumns ) bRes = pArray->Remove( nStartCol, nEndCol, bSize ); else bRes = pArray->Remove( nStartRow, nEndRow, bSize ); if ( bRes ) { if (bRecord) { rDocShell.GetUndoManager()->AddUndoAction( new ScUndoMakeOutline( &rDocShell, nStartCol,nStartRow,nTab, nEndCol,nEndRow,nTab, pUndoTab, bColumns, false ) ); } if (pDoc->IsStreamValid(nTab)) pDoc->SetStreamValid(nTab, false); sal_uInt16 nParts = 0; // Datenbereich nicht geaendert if ( bColumns ) nParts |= PAINT_TOP; else nParts |= PAINT_LEFT; if ( bSize ) nParts |= PAINT_SIZE; rDocShell.PostPaint( 0,0,nTab, MAXCOL,MAXROW,nTab, nParts ); rDocShell.SetDocumentModified(); bDone = true; lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); // es wird nicht wieder eingeblendet -> kein UpdatePageBreaks } else delete pUndoTab; } if (!bDone && !bApi) rDocShell.ErrorMessage(STR_MSSG_REMOVEOUTLINE_0); // "Aufheben nicht moeglich" return bDone; } bool ScOutlineDocFunc::RemoveAllOutlines( SCTAB nTab, bool bRecord ) { bool bSuccess = false; ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); if (pTable) { if (bRecord) { SCCOLROW nCol1, nCol2, nRow1, nRow2; pTable->GetColArray()->GetRange( nCol1, nCol2 ); pTable->GetRowArray()->GetRange( nRow1, nRow2 ); SCCOL nStartCol = static_cast(nCol1); SCROW nStartRow = nRow1; SCCOL nEndCol = static_cast(nCol2); SCROW nEndRow = nRow2; ScDocument* pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); pUndoDoc->InitUndo( pDoc, nTab, nTab, true, true ); pDoc->CopyToDocument( nStartCol, 0, nTab, nEndCol, MAXROW, nTab, IDF_NONE, false, pUndoDoc ); pDoc->CopyToDocument( 0, nStartRow, nTab, MAXCOL, nEndRow, nTab, IDF_NONE, false, pUndoDoc ); ScOutlineTable* pUndoTab = new ScOutlineTable( *pTable ); rDocShell.GetUndoManager()->AddUndoAction( new ScUndoRemoveAllOutlines( &rDocShell, nStartCol, nStartRow, nTab, nEndCol, nEndRow, nTab, pUndoDoc, pUndoTab ) ); } SelectLevel( nTab, true, pTable->GetColArray()->GetDepth(), false, false ); SelectLevel( nTab, false, pTable->GetRowArray()->GetDepth(), false, false ); pDoc->SetOutlineTable( nTab, NULL ); pDoc->UpdatePageBreaks( nTab ); if (pDoc->IsStreamValid(nTab)) pDoc->SetStreamValid(nTab, false); rDocShell.PostPaint( 0,0,nTab, MAXCOL,MAXROW,nTab, PAINT_GRID | PAINT_LEFT | PAINT_TOP | PAINT_SIZE ); rDocShell.SetDocumentModified(); lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); bSuccess = true; } return bSuccess; } bool ScOutlineDocFunc::AutoOutline( const ScRange& rRange, bool bRecord ) { SCCOL nStartCol = rRange.aStart.Col(); SCROW nStartRow = rRange.aStart.Row(); SCCOL nEndCol = rRange.aEnd.Col(); SCROW nEndRow = rRange.aEnd.Row(); SCTAB nTab = rRange.aStart.Tab(); ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); ScDocument* pUndoDoc = NULL; ScOutlineTable* pUndoTab = NULL; if ( pTable ) { if ( bRecord ) { pUndoTab = new ScOutlineTable( *pTable ); SCCOLROW nCol1, nCol2, nRow1, nRow2; pTable->GetColArray()->GetRange( nCol1, nCol2 ); pTable->GetRowArray()->GetRange( nRow1, nRow2 ); SCCOL nOutStartCol = static_cast(nCol1); SCROW nOutStartRow = nRow1; SCCOL nOutEndCol = static_cast(nCol2); SCROW nOutEndRow = nRow2; pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); pUndoDoc->InitUndo( pDoc, nTab, nTab, true, true ); pDoc->CopyToDocument( nOutStartCol, 0, nTab, nOutEndCol, MAXROW, nTab, IDF_NONE, false, pUndoDoc ); pDoc->CopyToDocument( 0, nOutStartRow, nTab, MAXCOL, nOutEndRow, nTab, IDF_NONE, false, pUndoDoc ); } // einblenden SelectLevel( nTab, true, pTable->GetColArray()->GetDepth(), false, false ); SelectLevel( nTab, false, pTable->GetRowArray()->GetDepth(), false, false ); pDoc->SetOutlineTable( nTab, NULL ); } pDoc->DoAutoOutline( nStartCol,nStartRow, nEndCol,nEndRow, nTab ); if (bRecord) { rDocShell.GetUndoManager()->AddUndoAction( new ScUndoAutoOutline( &rDocShell, nStartCol, nStartRow, nTab, nEndCol, nEndRow, nTab, pUndoDoc, pUndoTab ) ); } if (pDoc->IsStreamValid(nTab)) pDoc->SetStreamValid(nTab, false); rDocShell.PostPaint( 0,0,nTab, MAXCOL,MAXROW,nTab, PAINT_LEFT | PAINT_TOP | PAINT_SIZE ); rDocShell.SetDocumentModified(); lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); return true; } bool ScOutlineDocFunc::SelectLevel( SCTAB nTab, bool bColumns, sal_uInt16 nLevel, bool bRecord, bool bPaint ) { ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); // ist schon da if (!pTable) return false; ScOutlineArray* pArray = bColumns ? pTable->GetColArray() : pTable->GetRowArray(); if (!pArray) return false; SCCOLROW nStart, nEnd; pArray->GetRange( nStart, nEnd ); if ( bRecord ) { ScOutlineTable* pUndoTab = new ScOutlineTable( *pTable ); ScDocument* pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); if (bColumns) { pUndoDoc->InitUndo( pDoc, nTab, nTab, true, false ); pDoc->CopyToDocument( static_cast(nStart), 0, nTab, static_cast(nEnd), MAXROW, nTab, IDF_NONE, false, pUndoDoc ); } else { pUndoDoc->InitUndo( pDoc, nTab, nTab, false, true ); pDoc->CopyToDocument( 0, nStart, nTab, MAXCOL, nEnd, nTab, IDF_NONE, false, pUndoDoc ); } rDocShell.GetUndoManager()->AddUndoAction( new ScUndoOutlineLevel( &rDocShell, nStart, nEnd, nTab, //! start und end berechnen pUndoDoc, pUndoTab, bColumns, nLevel ) ); } ScSubOutlineIterator aIter( pArray ); // alle Eintraege ScOutlineEntry* pEntry; while ((pEntry=aIter.GetNext()) != NULL) { sal_uInt16 nThisLevel = aIter.LastLevel(); bool bShow = (nThisLevel < nLevel); if (bShow) // einblenden { pEntry->SetHidden( false ); pEntry->SetVisible( true ); } else if ( nThisLevel == nLevel ) // ausblenden { pEntry->SetHidden( true ); pEntry->SetVisible( true ); } else // verdeckt { pEntry->SetVisible( false ); } SCCOLROW nThisStart = pEntry->GetStart(); SCCOLROW nThisEnd = pEntry->GetEnd(); for (SCCOLROW i=nThisStart; i<=nThisEnd; i++) { if ( bColumns ) pDoc->ShowCol( static_cast(i), nTab, bShow ); else { // show several rows together, don't show filtered rows SCROW nFilterEnd = i; bool bFiltered = pDoc->RowFiltered( i, nTab, NULL, &nFilterEnd ); nFilterEnd = std::min( nThisEnd, nFilterEnd ); if ( !bShow || !bFiltered ) pDoc->ShowRows( i, nFilterEnd, nTab, bShow ); i = nFilterEnd; } } } pDoc->SetDrawPageSize(nTab); pDoc->UpdatePageBreaks( nTab ); if (bPaint) lcl_PaintWidthHeight( rDocShell, nTab, bColumns, nStart, nEnd ); rDocShell.SetDocumentModified(); lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); return true; } bool ScOutlineDocFunc::ShowMarkedOutlines( const ScRange& rRange, bool bRecord ) { bool bDone = false; SCCOL nStartCol = rRange.aStart.Col(); SCROW nStartRow = rRange.aStart.Row(); SCCOL nEndCol = rRange.aEnd.Col(); SCROW nEndRow = rRange.aEnd.Row(); SCTAB nTab = rRange.aStart.Tab(); ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); if (pTable) { ScOutlineArray* pArray; ScOutlineEntry* pEntry; SCCOLROW nStart; SCCOLROW nEnd; SCCOLROW nMin; SCCOLROW nMax; SCCOLROW i; if ( bRecord ) { ScOutlineTable* pUndoTab = new ScOutlineTable( *pTable ); ScDocument* pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); pUndoDoc->InitUndo( pDoc, nTab, nTab, true, true ); pDoc->CopyToDocument( nStartCol, 0, nTab, nEndCol, MAXROW, nTab, IDF_NONE, false, pUndoDoc ); pDoc->CopyToDocument( 0, nStartRow, nTab, MAXCOL, nEndRow, nTab, IDF_NONE, false, pUndoDoc ); rDocShell.GetUndoManager()->AddUndoAction( new ScUndoOutlineBlock( &rDocShell, nStartCol, nStartRow, nTab, nEndCol, nEndRow, nTab, pUndoDoc, pUndoTab, true ) ); } // Spalten nMin=MAXCOL; nMax=0; pArray = pTable->GetColArray(); ScSubOutlineIterator aColIter( pArray ); while ((pEntry=aColIter.GetNext()) != NULL) { nStart = pEntry->GetStart(); nEnd = pEntry->GetEnd(); if ( nStart>=nStartCol && nEnd<=nEndCol ) { pEntry->SetHidden( false ); pEntry->SetVisible( true ); if (nStartnMax) nMax=nEnd; } } for ( i=nMin; i<=nMax; i++ ) pDoc->ShowCol( static_cast(i), nTab, true ); // Zeilen nMin=MAXROW; nMax=0; pArray = pTable->GetRowArray(); ScSubOutlineIterator aRowIter( pArray ); while ((pEntry=aRowIter.GetNext()) != NULL) { nStart = pEntry->GetStart(); nEnd = pEntry->GetEnd(); if ( nStart>=nStartRow && nEnd<=nEndRow ) { pEntry->SetHidden( false ); pEntry->SetVisible( true ); if (nStartnMax) nMax=nEnd; } } for ( i=nMin; i<=nMax; i++ ) { // show several rows together, don't show filtered rows SCROW nFilterEnd = i; bool bFiltered = pDoc->RowFiltered( i, nTab, NULL, &nFilterEnd ); nFilterEnd = std::min( nMax, nFilterEnd ); if ( !bFiltered ) pDoc->ShowRows( i, nFilterEnd, nTab, true ); i = nFilterEnd; } pDoc->SetDrawPageSize(nTab); pDoc->UpdatePageBreaks( nTab ); rDocShell.PostPaint( 0,0,nTab, MAXCOL,MAXROW,nTab, PAINT_GRID | PAINT_LEFT | PAINT_TOP ); rDocShell.SetDocumentModified(); bDone = true; lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); } return bDone; } bool ScOutlineDocFunc::HideMarkedOutlines( const ScRange& rRange, bool bRecord ) { bool bDone = false; SCCOL nStartCol = rRange.aStart.Col(); SCROW nStartRow = rRange.aStart.Row(); SCCOL nEndCol = rRange.aEnd.Col(); SCROW nEndRow = rRange.aEnd.Row(); SCTAB nTab = rRange.aStart.Tab(); ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); if (pTable) { const ScOutlineEntry* pEntry; size_t nColLevel; size_t nRowLevel; sal_uInt16 nCount; SCCOLROW nStart; SCCOLROW nEnd; sal_uInt16 i; SCCOLROW nEffStartCol = nStartCol; SCCOLROW nEffEndCol = nEndCol; ScOutlineArray* pColArray = pTable->GetColArray(); pColArray->FindTouchedLevel( nStartCol, nEndCol, nColLevel ); pColArray->ExtendBlock( nColLevel, nEffStartCol, nEffEndCol ); SCCOLROW nEffStartRow = nStartRow; SCCOLROW nEffEndRow = nEndRow; ScOutlineArray* pRowArray = pTable->GetRowArray(); pRowArray->FindTouchedLevel( nStartRow, nEndRow, nRowLevel ); pRowArray->ExtendBlock( nRowLevel, nEffStartRow, nEffEndRow ); if ( bRecord ) { ScOutlineTable* pUndoTab = new ScOutlineTable( *pTable ); ScDocument* pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); pUndoDoc->InitUndo( pDoc, nTab, nTab, true, true ); pDoc->CopyToDocument( static_cast(nEffStartCol), 0, nTab, static_cast(nEffEndCol), MAXROW, nTab, IDF_NONE, false, pUndoDoc ); pDoc->CopyToDocument( 0, nEffStartRow, nTab, MAXCOL, nEffEndRow, nTab, IDF_NONE, false, pUndoDoc ); rDocShell.GetUndoManager()->AddUndoAction( new ScUndoOutlineBlock( &rDocShell, nStartCol, nStartRow, nTab, nEndCol, nEndRow, nTab, pUndoDoc, pUndoTab, false ) ); } // Spalten nCount = pColArray->GetCount(nColLevel); for ( i=0; iGetEntry(nColLevel,i); nStart = pEntry->GetStart(); nEnd = pEntry->GetEnd(); if ( static_cast(nStartCol)<=nEnd && static_cast(nEndCol)>=nStart ) HideOutline( nTab, true, nColLevel, i, false, false ); } // Zeilen nCount = pRowArray->GetCount(nRowLevel); for ( i=0; iGetEntry(nRowLevel,i); nStart = pEntry->GetStart(); nEnd = pEntry->GetEnd(); if ( nStartRow<=nEnd && nEndRow>=nStart ) HideOutline( nTab, false, nRowLevel, i, false, false ); } pDoc->SetDrawPageSize(nTab); pDoc->UpdatePageBreaks( nTab ); rDocShell.PostPaint( 0,0,nTab, MAXCOL,MAXROW,nTab, PAINT_GRID | PAINT_LEFT | PAINT_TOP ); rDocShell.SetDocumentModified(); bDone = true; lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); } return bDone; } bool ScOutlineDocFunc::ShowOutline( SCTAB nTab, bool bColumns, sal_uInt16 nLevel, sal_uInt16 nEntry, bool bRecord, bool bPaint ) { ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); ScOutlineArray* pArray = bColumns ? pTable->GetColArray() : pTable->GetRowArray(); ScOutlineEntry* pEntry = pArray->GetEntry( nLevel, nEntry ); SCCOLROW nStart = pEntry->GetStart(); SCCOLROW nEnd = pEntry->GetEnd(); if ( bRecord ) { ScDocument* pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); if (bColumns) { pUndoDoc->InitUndo( pDoc, nTab, nTab, true, false ); pDoc->CopyToDocument( static_cast(nStart), 0, nTab, static_cast(nEnd), MAXROW, nTab, IDF_NONE, false, pUndoDoc ); } else { pUndoDoc->InitUndo( pDoc, nTab, nTab, false, true ); pDoc->CopyToDocument( 0, nStart, nTab, MAXCOL, nEnd, nTab, IDF_NONE, false, pUndoDoc ); } rDocShell.GetUndoManager()->AddUndoAction( new ScUndoDoOutline( &rDocShell, nStart, nEnd, nTab, pUndoDoc, //! start und end berechnen bColumns, nLevel, nEntry, true ) ); } pEntry->SetHidden(false); SCCOLROW i; for ( i = nStart; i <= nEnd; i++ ) { if ( bColumns ) pDoc->ShowCol( static_cast(i), nTab, true ); else { // show several rows together, don't show filtered rows SCROW nFilterEnd = i; bool bFiltered = pDoc->RowFiltered( i, nTab, NULL, &nFilterEnd ); nFilterEnd = std::min( nEnd, nFilterEnd ); if ( !bFiltered ) pDoc->ShowRows( i, nFilterEnd, nTab, true ); i = nFilterEnd; } } ScSubOutlineIterator aIter( pArray, nLevel, nEntry ); while ((pEntry=aIter.GetNext()) != NULL) { if ( pEntry->IsHidden() ) { SCCOLROW nSubStart = pEntry->GetStart(); SCCOLROW nSubEnd = pEntry->GetEnd(); if ( bColumns ) for ( i = nSubStart; i <= nSubEnd; i++ ) pDoc->ShowCol( static_cast(i), nTab, false ); else pDoc->ShowRows( nSubStart, nSubEnd, nTab, false ); } } pArray->SetVisibleBelow( nLevel, nEntry, true, true ); pDoc->SetDrawPageSize(nTab); pDoc->InvalidatePageBreaks(nTab); pDoc->UpdatePageBreaks( nTab ); if (bPaint) lcl_PaintWidthHeight( rDocShell, nTab, bColumns, nStart, nEnd ); rDocShell.SetDocumentModified(); lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); return true; //! immer ??? } bool ScOutlineDocFunc::HideOutline( SCTAB nTab, bool bColumns, sal_uInt16 nLevel, sal_uInt16 nEntry, bool bRecord, bool bPaint ) { ScDocument* pDoc = rDocShell.GetDocument(); if (bRecord && !pDoc->IsUndoEnabled()) bRecord = false; ScOutlineTable* pTable = pDoc->GetOutlineTable( nTab ); ScOutlineArray* pArray = bColumns ? pTable->GetColArray() : pTable->GetRowArray(); ScOutlineEntry* pEntry = pArray->GetEntry( nLevel, nEntry ); SCCOLROW nStart = pEntry->GetStart(); SCCOLROW nEnd = pEntry->GetEnd(); if ( bRecord ) { ScDocument* pUndoDoc = new ScDocument( SCDOCMODE_UNDO ); if (bColumns) { pUndoDoc->InitUndo( pDoc, nTab, nTab, true, false ); pDoc->CopyToDocument( static_cast(nStart), 0, nTab, static_cast(nEnd), MAXROW, nTab, IDF_NONE, false, pUndoDoc ); } else { pUndoDoc->InitUndo( pDoc, nTab, nTab, false, true ); pDoc->CopyToDocument( 0, nStart, nTab, MAXCOL, nEnd, nTab, IDF_NONE, false, pUndoDoc ); } rDocShell.GetUndoManager()->AddUndoAction( new ScUndoDoOutline( &rDocShell, nStart, nEnd, nTab, pUndoDoc, bColumns, nLevel, nEntry, false ) ); } pEntry->SetHidden(true); SCCOLROW i; if ( bColumns ) for ( i = nStart; i <= nEnd; i++ ) pDoc->ShowCol( static_cast(i), nTab, false ); else pDoc->ShowRows( nStart, nEnd, nTab, false ); pArray->SetVisibleBelow( nLevel, nEntry, false ); pDoc->SetDrawPageSize(nTab); pDoc->InvalidatePageBreaks(nTab); pDoc->UpdatePageBreaks( nTab ); if (bPaint) lcl_PaintWidthHeight( rDocShell, nTab, bColumns, nStart, nEnd ); rDocShell.SetDocumentModified(); lcl_InvalidateOutliner( rDocShell.GetViewBindings() ); return true; //! immer ??? } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */