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
10*b3f79822SAndrew Rist *
11*b3f79822SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12*b3f79822SAndrew Rist *
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.
19*b3f79822SAndrew Rist *
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
ScEditableTester()36cdf0e10cSrcweir ScEditableTester::ScEditableTester() :
37cdf0e10cSrcweir bIsEditable( sal_True ),
38cdf0e10cSrcweir bOnlyMatrix( sal_True )
39cdf0e10cSrcweir {
40cdf0e10cSrcweir }
41cdf0e10cSrcweir
ScEditableTester(ScDocument * pDoc,SCTAB nTab,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow)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
ScEditableTester(ScDocument * pDoc,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScMarkData & rMark)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
ScEditableTester(ScDocument * pDoc,const ScRange & rRange)59cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScDocument* pDoc, const ScRange& rRange ) :
60cdf0e10cSrcweir bIsEditable( sal_True ),
61cdf0e10cSrcweir bOnlyMatrix( sal_True )
62cdf0e10cSrcweir {
63cdf0e10cSrcweir TestRange( pDoc, rRange );
64cdf0e10cSrcweir }
65cdf0e10cSrcweir
ScEditableTester(ScDocument * pDoc,const ScMarkData & rMark)66cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScDocument* pDoc, const ScMarkData& rMark ) :
67cdf0e10cSrcweir bIsEditable( sal_True ),
68cdf0e10cSrcweir bOnlyMatrix( sal_True )
69cdf0e10cSrcweir {
70cdf0e10cSrcweir TestSelection( pDoc, rMark );
71cdf0e10cSrcweir }
72cdf0e10cSrcweir
ScEditableTester(ScViewFunc * pView)73cdf0e10cSrcweir ScEditableTester::ScEditableTester( ScViewFunc* pView ) :
74cdf0e10cSrcweir bIsEditable( sal_True ),
75cdf0e10cSrcweir bOnlyMatrix( sal_True )
76cdf0e10cSrcweir {
77cdf0e10cSrcweir TestView( pView );
78cdf0e10cSrcweir }
79cdf0e10cSrcweir
80cdf0e10cSrcweir //------------------------------------------------------------------
81cdf0e10cSrcweir
TestBlock(ScDocument * pDoc,SCTAB nTab,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow)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
TestSelectedBlock(ScDocument * pDoc,SCCOL nStartCol,SCROW nStartRow,SCCOL nEndCol,SCROW nEndRow,const ScMarkData & rMark)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
TestRange(ScDocument * pDoc,const ScRange & rRange)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
TestSelection(ScDocument * pDoc,const ScMarkData & rMark)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
TestView(ScViewFunc * pView)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
GetMessageId() const149cdf0e10cSrcweir 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