1*b3f79822SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*b3f79822SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*b3f79822SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*b3f79822SAndrew Rist * distributed with this work for additional information 6*b3f79822SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*b3f79822SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*b3f79822SAndrew Rist * "License"); you may not use this file except in compliance 9*b3f79822SAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 11*b3f79822SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 13*b3f79822SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*b3f79822SAndrew Rist * software distributed under the License is distributed on an 15*b3f79822SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*b3f79822SAndrew Rist * KIND, either express or implied. See the License for the 17*b3f79822SAndrew Rist * specific language governing permissions and limitations 18*b3f79822SAndrew Rist * under the License. 19cdf0e10cSrcweir * 20*b3f79822SAndrew Rist *************************************************************/ 21*b3f79822SAndrew Rist 22*b3f79822SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 25cdf0e10cSrcweir #include "precompiled_sc.hxx" 26cdf0e10cSrcweir 27cdf0e10cSrcweir 28cdf0e10cSrcweir 29cdf0e10cSrcweir #include "editable.hxx" 30cdf0e10cSrcweir #include "document.hxx" 31cdf0e10cSrcweir #include "viewfunc.hxx" 32cdf0e10cSrcweir #include "globstr.hrc" 33cdf0e10cSrcweir 34cdf0e10cSrcweir //------------------------------------------------------------------ 35cdf0e10cSrcweir 36cdf0e10cSrcweir ScEditableTester::ScEditableTester() : 37cdf0e10cSrcweir bIsEditable( sal_True ), 38cdf0e10cSrcweir bOnlyMatrix( sal_True ) 39cdf0e10cSrcweir { 40cdf0e10cSrcweir } 41cdf0e10cSrcweir 42cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScDocument* pDoc, SCTAB nTab, 43cdf0e10cSrcweir SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow ) : 44cdf0e10cSrcweir bIsEditable( sal_True ), 45cdf0e10cSrcweir bOnlyMatrix( sal_True ) 46cdf0e10cSrcweir { 47cdf0e10cSrcweir TestBlock( pDoc, nTab, nStartCol, nStartRow, nEndCol, nEndRow ); 48cdf0e10cSrcweir } 49cdf0e10cSrcweir 50cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScDocument* pDoc, 51cdf0e10cSrcweir SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow, 52cdf0e10cSrcweir const ScMarkData& rMark ) : 53cdf0e10cSrcweir bIsEditable( sal_True ), 54cdf0e10cSrcweir bOnlyMatrix( sal_True ) 55cdf0e10cSrcweir { 56cdf0e10cSrcweir TestSelectedBlock( pDoc, nStartCol, nStartRow, nEndCol, nEndRow, rMark ); 57cdf0e10cSrcweir } 58cdf0e10cSrcweir 59cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScDocument* pDoc, const ScRange& rRange ) : 60cdf0e10cSrcweir bIsEditable( sal_True ), 61cdf0e10cSrcweir bOnlyMatrix( sal_True ) 62cdf0e10cSrcweir { 63cdf0e10cSrcweir TestRange( pDoc, rRange ); 64cdf0e10cSrcweir } 65cdf0e10cSrcweir 66cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScDocument* pDoc, const ScMarkData& rMark ) : 67cdf0e10cSrcweir bIsEditable( sal_True ), 68cdf0e10cSrcweir bOnlyMatrix( sal_True ) 69cdf0e10cSrcweir { 70cdf0e10cSrcweir TestSelection( pDoc, rMark ); 71cdf0e10cSrcweir } 72cdf0e10cSrcweir 73cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScViewFunc* pView ) : 74cdf0e10cSrcweir bIsEditable( sal_True ), 75cdf0e10cSrcweir bOnlyMatrix( sal_True ) 76cdf0e10cSrcweir { 77cdf0e10cSrcweir TestView( pView ); 78cdf0e10cSrcweir } 79cdf0e10cSrcweir 80cdf0e10cSrcweir //------------------------------------------------------------------ 81cdf0e10cSrcweir 82cdf0e10cSrcweir void ScEditableTester::TestBlock( ScDocument* pDoc, SCTAB nTab, 83cdf0e10cSrcweir SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow ) 84cdf0e10cSrcweir { 85cdf0e10cSrcweir if ( bIsEditable || bOnlyMatrix ) 86cdf0e10cSrcweir { 87cdf0e10cSrcweir sal_Bool bThisMatrix; 88cdf0e10cSrcweir if ( !pDoc->IsBlockEditable( nTab, nStartCol, nStartRow, nEndCol, nEndRow, &bThisMatrix ) ) 89cdf0e10cSrcweir { 90cdf0e10cSrcweir bIsEditable = sal_False; 91cdf0e10cSrcweir if ( !bThisMatrix ) 92cdf0e10cSrcweir bOnlyMatrix = sal_False; 93cdf0e10cSrcweir } 94cdf0e10cSrcweir } 95cdf0e10cSrcweir } 96cdf0e10cSrcweir 97cdf0e10cSrcweir void ScEditableTester::TestSelectedBlock( ScDocument* pDoc, 98cdf0e10cSrcweir SCCOL nStartCol, SCROW nStartRow, SCCOL nEndCol, SCROW nEndRow, 99cdf0e10cSrcweir const ScMarkData& rMark ) 100cdf0e10cSrcweir { 101cdf0e10cSrcweir SCTAB nTabCount = pDoc->GetTableCount(); 102cdf0e10cSrcweir for (SCTAB nTab=0; nTab<nTabCount; nTab++) 103cdf0e10cSrcweir if (rMark.GetTableSelect(nTab)) 104cdf0e10cSrcweir TestBlock( pDoc, nTab, nStartCol, nStartRow, nEndCol, nEndRow ); 105cdf0e10cSrcweir } 106cdf0e10cSrcweir 107cdf0e10cSrcweir void ScEditableTester::TestRange( ScDocument* pDoc, const ScRange& rRange ) 108cdf0e10cSrcweir { 109cdf0e10cSrcweir SCCOL nStartCol = rRange.aStart.Col(); 110cdf0e10cSrcweir SCROW nStartRow = rRange.aStart.Row(); 111cdf0e10cSrcweir SCTAB nStartTab = rRange.aStart.Tab(); 112cdf0e10cSrcweir SCCOL nEndCol = rRange.aEnd.Col(); 113cdf0e10cSrcweir SCROW nEndRow = rRange.aEnd.Row(); 114cdf0e10cSrcweir SCTAB nEndTab = rRange.aEnd.Tab(); 115cdf0e10cSrcweir for (SCTAB nTab=nStartTab; nTab<=nEndTab; nTab++) 116cdf0e10cSrcweir TestBlock( pDoc, nTab, nStartCol, nStartRow, nEndCol, nEndRow ); 117cdf0e10cSrcweir } 118cdf0e10cSrcweir 119cdf0e10cSrcweir void ScEditableTester::TestSelection( ScDocument* pDoc, const ScMarkData& rMark ) 120cdf0e10cSrcweir { 121cdf0e10cSrcweir if ( bIsEditable || bOnlyMatrix ) 122cdf0e10cSrcweir { 123cdf0e10cSrcweir sal_Bool bThisMatrix; 124cdf0e10cSrcweir if ( !pDoc->IsSelectionEditable( rMark, &bThisMatrix ) ) 125cdf0e10cSrcweir { 126cdf0e10cSrcweir bIsEditable = sal_False; 127cdf0e10cSrcweir if ( !bThisMatrix ) 128cdf0e10cSrcweir bOnlyMatrix = sal_False; 129cdf0e10cSrcweir } 130cdf0e10cSrcweir } 131cdf0e10cSrcweir } 132cdf0e10cSrcweir 133cdf0e10cSrcweir void ScEditableTester::TestView( ScViewFunc* pView ) 134cdf0e10cSrcweir { 135cdf0e10cSrcweir if ( bIsEditable || bOnlyMatrix ) 136cdf0e10cSrcweir { 137cdf0e10cSrcweir sal_Bool bThisMatrix; 138cdf0e10cSrcweir if ( !pView->SelectionEditable( &bThisMatrix ) ) 139cdf0e10cSrcweir { 140cdf0e10cSrcweir bIsEditable = sal_False; 141cdf0e10cSrcweir if ( !bThisMatrix ) 142cdf0e10cSrcweir bOnlyMatrix = sal_False; 143cdf0e10cSrcweir } 144cdf0e10cSrcweir } 145cdf0e10cSrcweir } 146cdf0e10cSrcweir 147cdf0e10cSrcweir //------------------------------------------------------------------ 148cdf0e10cSrcweir 149cdf0e10cSrcweir sal_uInt16 ScEditableTester::GetMessageId() const 150cdf0e10cSrcweir { 151cdf0e10cSrcweir if (bIsEditable) 152cdf0e10cSrcweir return 0; 153cdf0e10cSrcweir else if (bOnlyMatrix) 154cdf0e10cSrcweir return STR_MATRIXFRAGMENTERR; 155cdf0e10cSrcweir else 156cdf0e10cSrcweir return STR_PROTECTIONERR; 157cdf0e10cSrcweir } 158cdf0e10cSrcweir 159