1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
21 #include <com/sun/star/lang/DisposedException.hpp>
24 #include "tablerow.hxx"
25 #include "tableundo.hxx"
26 #include "svx/svdmodel.hxx"
27 #include "svx/svdotable.hxx"
31 using namespace ::com::sun::star::uno
;
32 using namespace ::com::sun::star::lang
;
33 using namespace ::com::sun::star::container
;
34 using namespace ::com::sun::star::table
;
35 using namespace ::com::sun::star::beans
;
39 namespace sdr
{ namespace table
{
41 const sal_Int32 Property_Height
= 0;
42 const sal_Int32 Property_OptimalHeight
= 1;
43 const sal_Int32 Property_IsVisible
= 2;
44 const sal_Int32 Property_IsStartOfNewPage
= 3;
46 TableRow::TableRow( const TableModelRef
& xTableModel
, sal_Int32 nRow
, sal_Int32 nColumns
)
47 : TableRowBase( getStaticPropertySetInfo() )
48 , mxTableModel( xTableModel
)
51 , mbOptimalHeight( true )
53 , mbIsStartOfNewPage( false )
56 maCells
.reserve( 20 );
60 maCells
.resize( nColumns
);
62 maCells
[ nColumns
] = mxTableModel
->createCell();
74 void TableRow::dispose()
77 if( !maCells
.empty() )
79 CellVector::iterator
aIter( maCells
.begin() );
80 while( aIter
!= maCells
.end() )
81 (*aIter
++)->dispose();
82 CellVector().swap(maCells
);
88 void TableRow::throwIfDisposed() const throw (::com::sun::star::uno::RuntimeException
)
90 if( !mxTableModel
.is() )
91 throw DisposedException();
96 TableRow
& TableRow::operator=( const TableRow
& r
)
98 mnHeight
= r
.mnHeight
;
99 mbOptimalHeight
= r
.mbOptimalHeight
;
100 mbIsVisible
= r
.mbIsVisible
;
101 mbIsStartOfNewPage
= r
.mbIsStartOfNewPage
;
110 void TableRow::insertColumns( sal_Int32 nIndex
, sal_Int32 nCount
, CellVector::iterator
* pIter
/* = 0 */ )
115 if( nIndex
>= static_cast< sal_Int32
>( maCells
.size() ) )
116 nIndex
= static_cast< sal_Int32
>( maCells
.size() );
118 maCells
.insert( maCells
.begin() + nIndex
, *pIter
, (*pIter
) + nCount
);
121 maCells
.reserve( maCells
.size() + nCount
);
122 for ( sal_Int32 i
= 0; i
< nCount
; i
++ )
123 maCells
.insert( maCells
.begin() + nIndex
+ i
, mxTableModel
->createCell() );
130 void TableRow::removeColumns( sal_Int32 nIndex
, sal_Int32 nCount
)
133 if( (nCount
>= 0) && ( nIndex
>= 0) )
135 if( (nIndex
+ nCount
) < static_cast< sal_Int32
>( maCells
.size() ) )
137 CellVector::iterator
aBegin( maCells
.begin() );
138 while( nIndex
-- && (aBegin
!= maCells
.end()) )
143 CellVector::iterator
aEnd( aBegin
);
144 while( nCount
-- && (aEnd
!= maCells
.end()) )
146 maCells
.erase( aBegin
, aEnd
);
150 maCells
.erase( aBegin
);
155 maCells
.resize( nIndex
);
164 Reference
< XCell
> SAL_CALL
TableRow::getCellByPosition( sal_Int32 nColumn
, sal_Int32 nRow
) throw (IndexOutOfBoundsException
, RuntimeException
, std::exception
)
168 throw IndexOutOfBoundsException();
170 return mxTableModel
->getCellByPosition( nColumn
, mnRow
);
175 Reference
< XCellRange
> SAL_CALL
TableRow::getCellRangeByPosition( sal_Int32 nLeft
, sal_Int32 nTop
, sal_Int32 nRight
, sal_Int32 nBottom
) throw (IndexOutOfBoundsException
, RuntimeException
, std::exception
)
178 if( (nLeft
>= 0 ) && (nTop
== 0) && (nRight
>= nLeft
) && (nBottom
== 0) )
180 return mxTableModel
->getCellRangeByPosition( nLeft
, mnRow
, nRight
, mnRow
);
182 throw IndexOutOfBoundsException();
187 Reference
< XCellRange
> SAL_CALL
TableRow::getCellRangeByName( const OUString
& /*aRange*/ ) throw (RuntimeException
, std::exception
)
190 return Reference
< XCellRange
>();
197 OUString SAL_CALL
TableRow::getName() throw (RuntimeException
, std::exception
)
204 void SAL_CALL
TableRow::setName( const OUString
& aName
) throw (RuntimeException
, std::exception
)
213 void SAL_CALL
TableRow::setFastPropertyValue( sal_Int32 nHandle
, const Any
& aValue
) throw (UnknownPropertyException
, PropertyVetoException
, IllegalArgumentException
, ::com::sun::star::lang::WrappedTargetException
, RuntimeException
, std::exception
)
216 bool bChange
= false;
218 TableRowUndo
* pUndo
= 0;
220 SdrModel
* pModel
= mxTableModel
->getSdrTableObj()->GetModel();
222 const bool bUndo
= mxTableModel
.is() && mxTableModel
->getSdrTableObj() && mxTableModel
->getSdrTableObj()->IsInserted() && pModel
&& pModel
->IsUndoEnabled();
226 TableRowRef
xThis( this );
227 pUndo
= new TableRowUndo( xThis
);
232 case Property_Height
:
234 sal_Int32 nHeight
= mnHeight
;
235 bOk
= aValue
>>= nHeight
;
236 if( bOk
&& (mnHeight
!= nHeight
) )
239 mbOptimalHeight
= mnHeight
== 0;
245 case Property_OptimalHeight
:
247 bool bOptimalHeight
= mbOptimalHeight
;
248 bOk
= aValue
>>= bOptimalHeight
;
249 if( bOk
&& (mbOptimalHeight
!= bOptimalHeight
) )
251 mbOptimalHeight
= bOptimalHeight
;
258 case Property_IsVisible
:
260 bool bIsVisible
= mbIsVisible
;
261 bOk
= aValue
>>= bIsVisible
;
262 if( bOk
&& (mbIsVisible
!= bIsVisible
) )
264 mbIsVisible
= bIsVisible
;
270 case Property_IsStartOfNewPage
:
272 bool bIsStartOfNewPage
= mbIsStartOfNewPage
;
273 bOk
= aValue
>>= bIsStartOfNewPage
;
274 if( bOk
&& (mbIsStartOfNewPage
!= bIsStartOfNewPage
) )
276 mbIsStartOfNewPage
= bIsStartOfNewPage
;
283 throw UnknownPropertyException();
288 throw IllegalArgumentException();
295 pModel
->AddUndo( pUndo
);
298 mxTableModel
->setModified(sal_True
);
306 Any SAL_CALL
TableRow::getFastPropertyValue( sal_Int32 nHandle
) throw (UnknownPropertyException
, WrappedTargetException
, RuntimeException
, std::exception
)
310 case Property_Height
: return Any( mnHeight
);
311 case Property_OptimalHeight
: return Any( mbOptimalHeight
);
312 case Property_IsVisible
: return Any( mbIsVisible
);
313 case Property_IsStartOfNewPage
: return Any( mbIsStartOfNewPage
);
314 default: throw UnknownPropertyException();
320 rtl::Reference
< FastPropertySetInfo
> TableRow::getStaticPropertySetInfo()
322 static rtl::Reference
< FastPropertySetInfo
> xInfo
;
325 ::osl::MutexGuard
aGuard( ::osl::Mutex::getGlobalMutex() );
328 PropertyVector
aProperties(6);
330 aProperties
[0].Name
= "Height";
331 aProperties
[0].Handle
= Property_Height
;
332 aProperties
[0].Type
= ::cppu::UnoType
<sal_Int32
>::get();
333 aProperties
[0].Attributes
= 0;
335 aProperties
[1].Name
= "OptimalHeight";
336 aProperties
[1].Handle
= Property_OptimalHeight
;
337 aProperties
[1].Type
= cppu::UnoType
<bool>::get();
338 aProperties
[1].Attributes
= 0;
340 aProperties
[2].Name
= "IsVisible";
341 aProperties
[2].Handle
= Property_IsVisible
;
342 aProperties
[2].Type
= cppu::UnoType
<bool>::get();
343 aProperties
[2].Attributes
= 0;
345 aProperties
[3].Name
= "IsStartOfNewPage";
346 aProperties
[3].Handle
= Property_IsStartOfNewPage
;
347 aProperties
[3].Type
= cppu::UnoType
<bool>::get();
348 aProperties
[3].Attributes
= 0;
350 aProperties
[4].Name
= "Size";
351 aProperties
[4].Handle
= Property_Height
;
352 aProperties
[4].Type
= ::cppu::UnoType
<sal_Int32
>::get();
353 aProperties
[4].Attributes
= 0;
355 aProperties
[5].Name
= "OptimalSize";
356 aProperties
[5].Handle
= Property_OptimalHeight
;
357 aProperties
[5].Type
= cppu::UnoType
<bool>::get();
358 aProperties
[5].Attributes
= 0;
360 xInfo
.set( new FastPropertySetInfo(aProperties
) );
372 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */