2007-05-22 17:59:49 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* $RCSfile: InternalDataProvider.cxx,v $
|
2008-06-16 11:56:50 +00:00
|
|
|
* $Revision: 1.7 $
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* 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.
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* 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).
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
2008-04-10 21:08:47 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2007-05-22 17:59:49 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
2008-03-18 14:58:12 +00:00
|
|
|
|
2007-05-22 17:59:49 +00:00
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_chart2.hxx"
|
|
|
|
#include <rtl/math.hxx>
|
|
|
|
|
|
|
|
#include <valarray>
|
|
|
|
|
|
|
|
#include "InternalDataProvider.hxx"
|
|
|
|
#include "LabeledDataSequence.hxx"
|
|
|
|
#include "DataSource.hxx"
|
|
|
|
#include "PropertyHelper.hxx"
|
|
|
|
#include "macros.hxx"
|
|
|
|
#include "XMLRangeHelper.hxx"
|
|
|
|
#include "ContainerHelper.hxx"
|
|
|
|
#include "CommonConverters.hxx"
|
|
|
|
#include "CommonFunctors.hxx"
|
|
|
|
#include "UncachedDataSequence.hxx"
|
|
|
|
#include "DataSourceHelper.hxx"
|
|
|
|
#include "ChartModelHelper.hxx"
|
|
|
|
#include "DiagramHelper.hxx"
|
|
|
|
#include "ResId.hxx"
|
|
|
|
#include "Strings.hrc"
|
|
|
|
#include <com/sun/star/chart2/XChartDocument.hpp>
|
|
|
|
#include <com/sun/star/chart2/data/XDataSequence.hpp>
|
|
|
|
#include <com/sun/star/chart/ChartDataRowSource.hpp>
|
|
|
|
#include <rtl/ustrbuf.hxx>
|
|
|
|
#include <unotools/charclass.hxx>
|
2008-06-16 11:56:50 +00:00
|
|
|
#include <comphelper/sequenceashashmap.hxx>
|
2007-05-22 17:59:49 +00:00
|
|
|
|
|
|
|
#include <vector>
|
2008-03-06 16:43:34 +00:00
|
|
|
#include <algorithm>
|
2007-05-22 17:59:49 +00:00
|
|
|
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
using namespace ::std;
|
|
|
|
|
|
|
|
using ::com::sun::star::uno::Reference;
|
|
|
|
using ::com::sun::star::uno::Sequence;
|
|
|
|
using ::rtl::OUString;
|
|
|
|
using ::rtl::OUStringBuffer;
|
|
|
|
|
|
|
|
namespace chart
|
|
|
|
{
|
|
|
|
namespace impl
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
struct OUStringBufferAppend : public unary_function< OUString, void >
|
|
|
|
{
|
|
|
|
OUStringBufferAppend( OUStringBuffer & rBuffer, const OUString & rSeparator ) :
|
|
|
|
m_rBuffer( rBuffer ),
|
|
|
|
m_aSep( rSeparator )
|
|
|
|
{}
|
|
|
|
void operator() ( const OUString & rStr )
|
|
|
|
{
|
|
|
|
m_rBuffer.append( m_aSep );
|
|
|
|
m_rBuffer.append( rStr );
|
|
|
|
}
|
|
|
|
private:
|
|
|
|
OUStringBuffer m_rBuffer;
|
|
|
|
OUString m_aSep;
|
|
|
|
};
|
|
|
|
|
|
|
|
OUString FlattenStringSequence( const Sequence< OUString > & aSeq )
|
|
|
|
{
|
|
|
|
if( aSeq.getLength() == 0 )
|
|
|
|
return OUString();
|
|
|
|
OUStringBuffer aBuf( aSeq[0] );
|
|
|
|
for_each( aSeq.getConstArray() + 1, aSeq.getConstArray() + aSeq.getLength(),
|
|
|
|
OUStringBufferAppend( aBuf, OUString(RTL_CONSTASCII_USTRINGPARAM(" "))));
|
|
|
|
return aBuf.makeStringAndClear();
|
|
|
|
}
|
|
|
|
|
|
|
|
class InternalData
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
InternalData();
|
|
|
|
|
|
|
|
void createDefaultData();
|
|
|
|
|
|
|
|
void setData( const Sequence< Sequence< double > > & rNewData, bool bDataInColumns );
|
|
|
|
Sequence< Sequence< double > > getData( bool bDataInColumns ) const;
|
|
|
|
Sequence< double > getDataAt( sal_Int32 nIndex, bool bDataInColumns ) const;
|
|
|
|
void setDataAt( sal_Int32 nIndex, bool bDataInColumns, const ::std::vector< double > & rNewData );
|
|
|
|
void swapAllDataAtIndexWithNext( sal_Int32 nAtIndex, bool bDataInColumns );
|
|
|
|
|
|
|
|
/** resizes the data if at least one of the given dimensions is larger than
|
|
|
|
before. The data is never becoming smaller only larger.
|
|
|
|
|
|
|
|
@return </TRUE>, if the data was enlarged
|
|
|
|
*/
|
|
|
|
bool enlargeData( sal_Int32 nColumnCount, sal_Int32 nRowCount );
|
|
|
|
|
|
|
|
void insertColumn( sal_Int32 nAfterIndex );
|
|
|
|
void insertRow( sal_Int32 nAfterIndex );
|
|
|
|
void deleteColumn( sal_Int32 nAtIndex );
|
|
|
|
void deleteRow( sal_Int32 nAtIndex );
|
|
|
|
|
|
|
|
/// @return the index of the newly appended column
|
|
|
|
sal_Int32 appendColumn();
|
2008-03-06 16:43:34 +00:00
|
|
|
/// @return the index of the newly appended row
|
|
|
|
sal_Int32 appendRow();
|
2007-05-22 17:59:49 +00:00
|
|
|
|
|
|
|
sal_Int32 getRowCount() const;
|
|
|
|
sal_Int32 getColumnCount() const;
|
|
|
|
|
|
|
|
void setRowLabels( const ::std::vector< OUString > & rNewRowLabels );
|
|
|
|
::std::vector< OUString > getRowLabels() const;
|
|
|
|
void setColumnLabels( const ::std::vector< OUString > & rNewColumnLabels );
|
|
|
|
::std::vector< OUString > getColumnLabels() const;
|
|
|
|
|
|
|
|
#if OSL_DEBUG_LEVEL > 2
|
|
|
|
void traceData() const;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
private:
|
|
|
|
sal_Int32 m_nColumnCount;
|
|
|
|
sal_Int32 m_nRowCount;
|
|
|
|
|
|
|
|
typedef ::std::valarray< double > tDataType;
|
|
|
|
typedef ::std::vector< OUString > tLabelType;
|
|
|
|
|
|
|
|
tDataType m_aData;
|
|
|
|
tLabelType m_aRowLabels;
|
|
|
|
tLabelType m_aColumnLabels;
|
|
|
|
};
|
|
|
|
|
|
|
|
// ----------------------------------------
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
struct lcl_NumberedStringGenerator
|
|
|
|
{
|
|
|
|
lcl_NumberedStringGenerator( const OUString & rStub, const OUString & rWildcard ) :
|
|
|
|
m_aStub( rStub ),
|
|
|
|
m_nCounter( 0 ),
|
|
|
|
m_nStubStartIndex( rStub.indexOf( rWildcard )),
|
|
|
|
m_nWildcardLength( rWildcard.getLength())
|
|
|
|
{
|
|
|
|
}
|
|
|
|
OUString operator()() {
|
|
|
|
return m_aStub.replaceAt( m_nStubStartIndex, m_nWildcardLength, OUString::valueOf( ++m_nCounter ));
|
|
|
|
}
|
|
|
|
private:
|
|
|
|
OUString m_aStub;
|
|
|
|
sal_Int32 m_nCounter;
|
|
|
|
const sal_Int32 m_nStubStartIndex;
|
|
|
|
const sal_Int32 m_nWildcardLength;
|
|
|
|
};
|
|
|
|
|
|
|
|
template< typename T >
|
|
|
|
Sequence< T > lcl_ValarrayToSequence( const ::std::valarray< T > & rValarray )
|
|
|
|
{
|
|
|
|
// is there a more elegant way of conversion?
|
|
|
|
Sequence< T > aResult( rValarray.size());
|
|
|
|
for( size_t i = 0; i < rValarray.size(); ++i )
|
|
|
|
aResult[i] = rValarray[i];
|
|
|
|
return aResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct lcl_ValuesOfLabeledSequence :
|
|
|
|
public unary_function< Reference< chart2::data::XLabeledDataSequence >, Sequence< double > >
|
|
|
|
{
|
|
|
|
Sequence< double > operator() ( const Reference< chart2::data::XLabeledDataSequence > & xLSeq )
|
|
|
|
{
|
|
|
|
if( ! xLSeq.is())
|
|
|
|
return Sequence< double >();
|
|
|
|
return DataSequenceToDoubleSequence( xLSeq->getValues());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct lcl_LabelsOfLabeledSequence :
|
|
|
|
public unary_function< Reference< chart2::data::XLabeledDataSequence >, Sequence< OUString > >
|
|
|
|
{
|
|
|
|
Sequence< OUString > operator() ( const Reference< chart2::data::XLabeledDataSequence > & xLSeq )
|
|
|
|
{
|
|
|
|
if( ! xLSeq.is())
|
|
|
|
return Sequence< OUString >();
|
|
|
|
return DataSequenceToStringSequence( xLSeq->getLabel());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct lcl_LabelOfLabeledSequence :
|
|
|
|
public unary_function< Reference< chart2::data::XLabeledDataSequence >, OUString >
|
|
|
|
{
|
|
|
|
OUString operator() ( const Reference< chart2::data::XLabeledDataSequence > & xLSeq )
|
|
|
|
{
|
|
|
|
if( ! xLSeq.is())
|
|
|
|
return OUString();
|
|
|
|
return FlattenStringSequence( DataSequenceToStringSequence( xLSeq->getLabel()));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // anonymous namespace
|
|
|
|
// ----------------------------------------
|
|
|
|
|
|
|
|
InternalData::InternalData() :
|
|
|
|
m_nColumnCount( 0 ),
|
|
|
|
m_nRowCount( 0 )
|
|
|
|
{}
|
|
|
|
|
|
|
|
void InternalData::createDefaultData()
|
|
|
|
{
|
|
|
|
const sal_Int32 nNumRows = 4;
|
|
|
|
const sal_Int32 nNumColumns = 3;
|
|
|
|
const sal_Int32 nSize = nNumColumns * nNumRows;
|
|
|
|
// @todo: localize this!
|
|
|
|
const OUString aRowName( ::chart::SchResId::getResString( STR_ROW_LABEL ));
|
|
|
|
const OUString aColName( ::chart::SchResId::getResString( STR_COLUMN_LABEL ));
|
|
|
|
|
|
|
|
const double fDefaultData[ nSize ] =
|
|
|
|
{ 9.10, 3.20, 4.54,
|
|
|
|
2.40, 8.80, 9.65,
|
|
|
|
3.10, 1.50, 3.70,
|
|
|
|
4.30, 9.02, 6.20 };
|
|
|
|
|
|
|
|
m_aData.resize( nSize );
|
|
|
|
for( sal_Int32 i=0; i<nSize; ++i )
|
|
|
|
m_aData[i] = fDefaultData[i];
|
|
|
|
m_nRowCount = nNumRows;
|
|
|
|
m_nColumnCount = nNumColumns;
|
|
|
|
|
|
|
|
vector< OUString > aRowLabels;
|
|
|
|
aRowLabels.reserve( nNumRows );
|
|
|
|
generate_n( back_inserter( aRowLabels ), nNumRows,
|
|
|
|
lcl_NumberedStringGenerator( aRowName, C2U("%ROWNUMBER") ));
|
|
|
|
setRowLabels( aRowLabels );
|
|
|
|
|
|
|
|
vector< OUString > aColumnLabels;
|
|
|
|
aColumnLabels.reserve( nNumColumns );
|
|
|
|
generate_n( back_inserter( aColumnLabels ), nNumColumns,
|
|
|
|
lcl_NumberedStringGenerator( aColName, C2U("%COLUMNNUMBER") ));
|
|
|
|
setColumnLabels( aColumnLabels );
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::setData( const Sequence< Sequence< double > > & rNewData, bool bDataInColumns )
|
|
|
|
{
|
|
|
|
sal_Int32 nOuterSize = rNewData.getLength();
|
|
|
|
sal_Int32 nInnerSize = (nOuterSize ? rNewData[0].getLength() : 0);
|
|
|
|
|
|
|
|
m_nRowCount = (bDataInColumns ? nInnerSize : nOuterSize);
|
|
|
|
m_nColumnCount = (bDataInColumns ? nOuterSize : nInnerSize);
|
|
|
|
|
|
|
|
if( m_aRowLabels.size() != static_cast< sal_uInt32 >( m_nRowCount ))
|
|
|
|
m_aRowLabels.resize( m_nRowCount );
|
|
|
|
if( m_aColumnLabels.size() != static_cast< sal_uInt32 >( m_nColumnCount ))
|
|
|
|
m_aColumnLabels.resize( m_nColumnCount );
|
|
|
|
|
|
|
|
m_aData.resize( m_nRowCount * m_nColumnCount );
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( & fNan );
|
|
|
|
// set all values to Nan
|
|
|
|
m_aData = fNan;
|
|
|
|
|
|
|
|
for( sal_Int32 nOuterIdx=0; nOuterIdx<nOuterSize; ++nOuterIdx )
|
|
|
|
{
|
|
|
|
int nDataIdx = (bDataInColumns ? nOuterIdx : nOuterIdx*nInnerSize);
|
|
|
|
const sal_Int32 nMax = ::std::min( rNewData[nOuterIdx].getLength(), nInnerSize );
|
|
|
|
sal_Int32 nInnerIdx=0;
|
|
|
|
for( ; nInnerIdx < nMax; ++nInnerIdx )
|
|
|
|
{
|
|
|
|
m_aData[nDataIdx] = rNewData[nOuterIdx][nInnerIdx];
|
|
|
|
nDataIdx += (bDataInColumns ? m_nColumnCount : 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< Sequence< double > > InternalData::getData( bool bDataInColumns ) const
|
|
|
|
{
|
|
|
|
Sequence< Sequence< double > > aResult( bDataInColumns ? m_nColumnCount : m_nRowCount );
|
|
|
|
|
|
|
|
if( bDataInColumns )
|
|
|
|
{
|
|
|
|
for( sal_Int32 i=0; i<m_nColumnCount; ++i )
|
2007-07-25 07:57:46 +00:00
|
|
|
aResult[i] = lcl_ValarrayToSequence< tDataType::value_type >(
|
|
|
|
m_aData[ ::std::slice( i, m_nRowCount, m_nColumnCount ) ] );
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
for( sal_Int32 i=0; i<m_nRowCount; ++i )
|
2007-07-25 07:57:46 +00:00
|
|
|
aResult[i] = lcl_ValarrayToSequence< tDataType::value_type >(
|
|
|
|
m_aData[ ::std::slice( i*m_nColumnCount, m_nColumnCount, 1 ) ] );
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return aResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< double > InternalData::getDataAt( sal_Int32 nIndex, bool bDataInColumns ) const
|
|
|
|
{
|
|
|
|
Sequence< double > aResult( bDataInColumns ? m_nRowCount : m_nColumnCount );
|
|
|
|
|
|
|
|
if( bDataInColumns )
|
|
|
|
{
|
|
|
|
if( nIndex < m_nColumnCount )
|
2007-07-25 07:57:46 +00:00
|
|
|
return lcl_ValarrayToSequence< tDataType::value_type >(
|
|
|
|
m_aData[ ::std::slice( nIndex, m_nRowCount, m_nColumnCount ) ] );
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if( nIndex < m_nRowCount )
|
2007-07-25 07:57:46 +00:00
|
|
|
return lcl_ValarrayToSequence< tDataType::value_type >(
|
|
|
|
m_aData[ ::std::slice( nIndex*m_nColumnCount, m_nColumnCount, 1 ) ] );
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return Sequence< double >();
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::setDataAt( sal_Int32 nIndex, bool bDataInColumns, const ::std::vector< double > & rNewData )
|
|
|
|
{
|
|
|
|
if( bDataInColumns )
|
|
|
|
{
|
|
|
|
if( nIndex < m_nColumnCount )
|
|
|
|
{
|
|
|
|
tDataType aSlice = m_aData[ ::std::slice( nIndex, m_nRowCount, m_nColumnCount ) ];
|
|
|
|
for( ::std::vector< double >::size_type i = 0; i < rNewData.size(); ++i )
|
|
|
|
aSlice[i] = rNewData[i];
|
|
|
|
m_aData[ ::std::slice( nIndex, m_nRowCount, m_nColumnCount ) ] = aSlice;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if( nIndex < m_nRowCount )
|
|
|
|
{
|
|
|
|
tDataType aSlice = m_aData[ ::std::slice( nIndex*m_nColumnCount, m_nColumnCount, 1 ) ];
|
|
|
|
for( ::std::vector< double >::size_type i = 0; i < rNewData.size(); ++i )
|
|
|
|
aSlice[i] = rNewData[i];
|
|
|
|
m_aData[ ::std::slice( nIndex*m_nColumnCount, m_nColumnCount, 1 ) ]= aSlice;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::swapAllDataAtIndexWithNext( sal_Int32 nAtIndex, bool bDataInColumns )
|
|
|
|
{
|
|
|
|
if( bDataInColumns && nAtIndex < m_nRowCount - 1 )
|
|
|
|
{
|
|
|
|
const sal_Int32 nMax = m_nColumnCount;
|
|
|
|
for( sal_Int32 nColIdx=0; nColIdx<nMax; ++nColIdx )
|
|
|
|
{
|
|
|
|
size_t nIndex1 = nColIdx + nAtIndex*m_nColumnCount;
|
|
|
|
size_t nIndex2 = nIndex1 + m_nColumnCount;
|
|
|
|
double fTemp = m_aData[nIndex1];
|
|
|
|
m_aData[nIndex1] = m_aData[nIndex2];
|
|
|
|
m_aData[nIndex2] = fTemp;
|
|
|
|
}
|
|
|
|
OUString sTemp( m_aRowLabels[nAtIndex] );
|
|
|
|
m_aRowLabels[nAtIndex] = m_aRowLabels[nAtIndex + 1];
|
|
|
|
m_aRowLabels[nAtIndex + 1] = sTemp;
|
|
|
|
}
|
|
|
|
else if( nAtIndex < m_nColumnCount - 1 )
|
|
|
|
{
|
|
|
|
const sal_Int32 nMax = m_nRowCount;
|
|
|
|
for( sal_Int32 nRowIdx=0; nRowIdx<nMax; ++nRowIdx )
|
|
|
|
{
|
|
|
|
size_t nIndex1 = nAtIndex + nRowIdx*m_nColumnCount;
|
|
|
|
size_t nIndex2 = nIndex1 + 1;
|
|
|
|
double fTemp = m_aData[nIndex1];
|
|
|
|
m_aData[nIndex1] = m_aData[nIndex2];
|
|
|
|
m_aData[nIndex2] = fTemp;
|
|
|
|
}
|
|
|
|
OUString sTemp( m_aColumnLabels[nAtIndex] );
|
|
|
|
m_aColumnLabels[nAtIndex] = m_aColumnLabels[nAtIndex + 1];
|
|
|
|
m_aColumnLabels[nAtIndex + 1] = sTemp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool InternalData::enlargeData( sal_Int32 nColumnCount, sal_Int32 nRowCount )
|
|
|
|
{
|
2009-09-14 10:57:16 +00:00
|
|
|
sal_Int32 nNewColumnCount( ::std::max<sal_Int32>( m_nColumnCount, nColumnCount ) );
|
|
|
|
sal_Int32 nNewRowCount( ::std::max<sal_Int32>( m_nRowCount, nRowCount ) );
|
2007-05-22 17:59:49 +00:00
|
|
|
sal_Int32 nNewSize( nNewColumnCount*nNewRowCount );
|
|
|
|
|
|
|
|
bool bGrow = (nNewSize > m_nColumnCount*m_nRowCount);
|
|
|
|
|
|
|
|
if( bGrow )
|
|
|
|
{
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( &fNan );
|
|
|
|
tDataType aNewData( fNan, nNewSize );
|
|
|
|
// copy old data
|
|
|
|
for( int nCol=0; nCol<m_nColumnCount; ++nCol )
|
|
|
|
static_cast< tDataType >(
|
|
|
|
aNewData[ ::std::slice( nCol, m_nRowCount, nNewColumnCount ) ] ) =
|
|
|
|
m_aData[ ::std::slice( nCol, m_nRowCount, m_nColumnCount ) ];
|
|
|
|
|
|
|
|
m_aData.resize( nNewSize );
|
|
|
|
m_aData = aNewData;
|
|
|
|
}
|
2009-09-14 10:57:16 +00:00
|
|
|
m_nColumnCount = nNewColumnCount;
|
|
|
|
m_nRowCount = nNewRowCount;
|
2007-05-22 17:59:49 +00:00
|
|
|
return bGrow;
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::insertColumn( sal_Int32 nAfterIndex )
|
|
|
|
{
|
|
|
|
// note: -1 is allowed, as we insert after the given index
|
|
|
|
OSL_ASSERT( nAfterIndex < m_nColumnCount && nAfterIndex >= -1 );
|
|
|
|
if( nAfterIndex >= m_nColumnCount || nAfterIndex < -1 )
|
|
|
|
return;
|
|
|
|
sal_Int32 nNewColumnCount = m_nColumnCount + 1;
|
|
|
|
sal_Int32 nNewSize( nNewColumnCount * m_nRowCount );
|
|
|
|
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( &fNan );
|
|
|
|
tDataType aNewData( fNan, nNewSize );
|
|
|
|
|
|
|
|
// copy old data
|
|
|
|
int nCol=0;
|
|
|
|
for( ; nCol<=nAfterIndex; ++nCol )
|
|
|
|
aNewData[ ::std::slice( nCol, m_nRowCount, nNewColumnCount ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( nCol, m_nRowCount, m_nColumnCount ) ] );
|
|
|
|
for( ++nCol; nCol<nNewColumnCount; ++nCol )
|
|
|
|
aNewData[ ::std::slice( nCol, m_nRowCount, nNewColumnCount ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( nCol - 1, m_nRowCount, m_nColumnCount ) ] );
|
|
|
|
|
|
|
|
m_nColumnCount = nNewColumnCount;
|
|
|
|
m_aData.resize( nNewSize );
|
|
|
|
m_aData = aNewData;
|
|
|
|
|
|
|
|
// labels
|
|
|
|
if( nAfterIndex < static_cast< sal_Int32 >( m_aColumnLabels.size()))
|
|
|
|
m_aColumnLabels.insert( m_aColumnLabels.begin() + (nAfterIndex + 1), OUString());
|
|
|
|
|
|
|
|
#if OSL_DEBUG_LEVEL > 2
|
|
|
|
traceData();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Int32 InternalData::appendColumn()
|
|
|
|
{
|
|
|
|
insertColumn( getColumnCount() - 1 );
|
|
|
|
return getColumnCount() - 1;
|
|
|
|
}
|
|
|
|
|
2008-03-06 16:43:34 +00:00
|
|
|
sal_Int32 InternalData::appendRow()
|
|
|
|
{
|
|
|
|
insertRow( getRowCount() - 1 );
|
|
|
|
return getRowCount() - 1;
|
|
|
|
}
|
|
|
|
|
2007-05-22 17:59:49 +00:00
|
|
|
void InternalData::insertRow( sal_Int32 nAfterIndex )
|
|
|
|
{
|
|
|
|
// note: -1 is allowed, as we insert after the given index
|
|
|
|
OSL_ASSERT( nAfterIndex < m_nRowCount && nAfterIndex >= -1 );
|
|
|
|
if( nAfterIndex >= m_nRowCount || nAfterIndex < -1 )
|
|
|
|
return;
|
|
|
|
sal_Int32 nNewRowCount = m_nRowCount + 1;
|
|
|
|
sal_Int32 nNewSize( m_nColumnCount * nNewRowCount );
|
|
|
|
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( &fNan );
|
|
|
|
tDataType aNewData( fNan, nNewSize );
|
|
|
|
|
|
|
|
// copy old data
|
|
|
|
sal_Int32 nIndex = nAfterIndex + 1;
|
|
|
|
aNewData[ ::std::slice( 0, nIndex * m_nColumnCount, 1 ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( 0, nIndex * m_nColumnCount, 1 ) ] );
|
|
|
|
|
|
|
|
if( nIndex < m_nRowCount )
|
|
|
|
{
|
|
|
|
sal_Int32 nRemainingCount = m_nColumnCount * (m_nRowCount - nIndex);
|
|
|
|
aNewData[ ::std::slice( (nIndex + 1) * m_nColumnCount, nRemainingCount, 1 ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( nIndex * m_nColumnCount, nRemainingCount, 1 ) ] );
|
|
|
|
}
|
|
|
|
|
|
|
|
m_nRowCount = nNewRowCount;
|
|
|
|
m_aData.resize( nNewSize );
|
|
|
|
m_aData = aNewData;
|
|
|
|
|
|
|
|
// labels
|
|
|
|
if( nAfterIndex < static_cast< sal_Int32 >( m_aRowLabels.size()))
|
|
|
|
m_aRowLabels.insert( m_aRowLabels.begin() + nIndex, OUString());
|
|
|
|
|
|
|
|
#if OSL_DEBUG_LEVEL > 2
|
|
|
|
traceData();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::deleteColumn( sal_Int32 nAtIndex )
|
|
|
|
{
|
|
|
|
OSL_ASSERT( nAtIndex < m_nColumnCount && nAtIndex >= 0 );
|
|
|
|
if( nAtIndex >= m_nColumnCount || m_nColumnCount < 1 || nAtIndex < 0 )
|
|
|
|
return;
|
|
|
|
sal_Int32 nNewColumnCount = m_nColumnCount - 1;
|
|
|
|
sal_Int32 nNewSize( nNewColumnCount * m_nRowCount );
|
|
|
|
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( &fNan );
|
|
|
|
tDataType aNewData( fNan, nNewSize );
|
|
|
|
|
|
|
|
// copy old data
|
|
|
|
int nCol=0;
|
|
|
|
for( ; nCol<nAtIndex; ++nCol )
|
|
|
|
aNewData[ ::std::slice( nCol, m_nRowCount, nNewColumnCount ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( nCol, m_nRowCount, m_nColumnCount ) ] );
|
|
|
|
for( ; nCol<nNewColumnCount; ++nCol )
|
|
|
|
aNewData[ ::std::slice( nCol, m_nRowCount, nNewColumnCount ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( nCol + 1, m_nRowCount, m_nColumnCount ) ] );
|
|
|
|
|
|
|
|
m_nColumnCount = nNewColumnCount;
|
|
|
|
m_aData.resize( nNewSize );
|
|
|
|
m_aData = aNewData;
|
|
|
|
|
|
|
|
// labels
|
|
|
|
if( nAtIndex < static_cast< sal_Int32 >( m_aColumnLabels.size()))
|
|
|
|
m_aColumnLabels.erase( m_aColumnLabels.begin() + nAtIndex );
|
|
|
|
|
|
|
|
#if OSL_DEBUG_LEVEL > 2
|
|
|
|
traceData();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::deleteRow( sal_Int32 nAtIndex )
|
|
|
|
{
|
|
|
|
OSL_ASSERT( nAtIndex < m_nRowCount && nAtIndex >= 0 );
|
|
|
|
if( nAtIndex >= m_nRowCount || m_nRowCount < 1 || nAtIndex < 0 )
|
|
|
|
return;
|
|
|
|
sal_Int32 nNewRowCount = m_nRowCount - 1;
|
|
|
|
sal_Int32 nNewSize( m_nColumnCount * nNewRowCount );
|
|
|
|
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( &fNan );
|
|
|
|
tDataType aNewData( fNan, nNewSize );
|
|
|
|
|
|
|
|
// copy old data
|
|
|
|
sal_Int32 nIndex = nAtIndex;
|
|
|
|
if( nIndex )
|
|
|
|
aNewData[ ::std::slice( 0, nIndex * m_nColumnCount, 1 ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( 0, nIndex * m_nColumnCount, 1 ) ] );
|
|
|
|
|
|
|
|
if( nIndex < nNewRowCount )
|
|
|
|
{
|
|
|
|
sal_Int32 nRemainingCount = m_nColumnCount * (nNewRowCount - nIndex);
|
|
|
|
aNewData[ ::std::slice( nIndex * m_nColumnCount, nRemainingCount, 1 ) ] =
|
|
|
|
static_cast< tDataType >(
|
|
|
|
m_aData[ ::std::slice( (nIndex + 1) * m_nColumnCount, nRemainingCount, 1 ) ] );
|
|
|
|
}
|
|
|
|
|
|
|
|
m_nRowCount = nNewRowCount;
|
|
|
|
m_aData.resize( nNewSize );
|
|
|
|
m_aData = aNewData;
|
|
|
|
|
|
|
|
// labels
|
|
|
|
if( nAtIndex < static_cast< sal_Int32 >( m_aRowLabels.size()))
|
|
|
|
m_aRowLabels.erase( m_aRowLabels.begin() + nAtIndex );
|
|
|
|
|
|
|
|
#if OSL_DEBUG_LEVEL > 2
|
|
|
|
traceData();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Int32 InternalData::getRowCount() const
|
|
|
|
{
|
|
|
|
return m_nRowCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
sal_Int32 InternalData::getColumnCount() const
|
|
|
|
{
|
|
|
|
return m_nColumnCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::setRowLabels( const ::std::vector< OUString > & rNewRowLabels )
|
|
|
|
{
|
|
|
|
m_aRowLabels = rNewRowLabels;
|
|
|
|
if( m_aRowLabels.size() < static_cast< ::std::vector< OUString >::size_type >( m_nRowCount ))
|
|
|
|
m_aRowLabels.resize( m_nRowCount );
|
|
|
|
else
|
|
|
|
enlargeData( 0, static_cast< sal_Int32 >( m_aRowLabels.size() ));
|
|
|
|
}
|
|
|
|
|
|
|
|
::std::vector< OUString > InternalData::getRowLabels() const
|
|
|
|
{
|
|
|
|
return m_aRowLabels;
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalData::setColumnLabels( const ::std::vector< OUString > & rNewColumnLabels )
|
|
|
|
{
|
|
|
|
m_aColumnLabels = rNewColumnLabels;
|
|
|
|
if( m_aColumnLabels.size() < static_cast< ::std::vector< OUString >::size_type >( m_nColumnCount ))
|
|
|
|
m_aColumnLabels.resize( m_nColumnCount );
|
|
|
|
else
|
|
|
|
enlargeData( static_cast< sal_Int32 >( m_aColumnLabels.size()), 0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
::std::vector< OUString > InternalData::getColumnLabels() const
|
|
|
|
{
|
|
|
|
return m_aColumnLabels;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if OSL_DEBUG_LEVEL > 2
|
|
|
|
void InternalData::traceData() const
|
|
|
|
{
|
|
|
|
OSL_TRACE( "InternalData: Data in rows\n" );
|
|
|
|
|
|
|
|
for( sal_Int32 i=0; i<m_nRowCount; ++i )
|
|
|
|
{
|
|
|
|
tDataType aSlice( m_aData[ ::std::slice( i*m_nColumnCount, m_nColumnCount, 1 ) ] );
|
|
|
|
for( sal_Int32 j=0; j<m_nColumnCount; ++j )
|
|
|
|
OSL_TRACE( "%lf ", aSlice[j] );
|
|
|
|
OSL_TRACE( "\n" );
|
|
|
|
}
|
|
|
|
OSL_TRACE( "\n" );
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
} // namespace impl
|
|
|
|
|
|
|
|
// ================================================================================
|
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
|
|
|
|
// note: in xmloff this name is used to indicate usage of own data
|
|
|
|
static const ::rtl::OUString lcl_aServiceName(
|
|
|
|
RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.comp.chart.InternalDataProvider" ));
|
|
|
|
|
|
|
|
static const ::rtl::OUString lcl_aCategoriesRangeName(
|
|
|
|
RTL_CONSTASCII_USTRINGPARAM( "categories" ));
|
|
|
|
static const ::rtl::OUString lcl_aCategoriesRoleName(
|
|
|
|
RTL_CONSTASCII_USTRINGPARAM( "categories" ));
|
|
|
|
static const ::rtl::OUString lcl_aLabelRangePrefix(
|
|
|
|
RTL_CONSTASCII_USTRINGPARAM( "label " ));
|
|
|
|
static const ::rtl::OUString lcl_aCompleteRange(
|
|
|
|
RTL_CONSTASCII_USTRINGPARAM( "all" ));
|
|
|
|
|
|
|
|
|
|
|
|
struct lcl_DataProviderRangeCreator : public unary_function< OUString, Reference< chart2::data::XLabeledDataSequence > >
|
|
|
|
{
|
|
|
|
lcl_DataProviderRangeCreator( const Reference< chart2::data::XDataProvider > & xDataProvider ) :
|
|
|
|
m_xDataProvider( xDataProvider )
|
|
|
|
{}
|
|
|
|
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > operator() ( const OUString & rRange )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > xResult;
|
|
|
|
if( m_xDataProvider.is())
|
|
|
|
try
|
|
|
|
{
|
|
|
|
xResult.set( new ::chart::LabeledDataSequence(
|
|
|
|
m_xDataProvider->createDataSequenceByRangeRepresentation( rRange )));
|
|
|
|
}
|
|
|
|
catch( const lang::IllegalArgumentException & ex )
|
|
|
|
{
|
|
|
|
// data provider cannot create single data sequences, but then
|
|
|
|
// detectArguments should work also with an empty data source
|
2007-07-25 07:57:46 +00:00
|
|
|
(void)(ex);
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
catch( const uno::Exception & ex )
|
|
|
|
{
|
|
|
|
ASSERT_EXCEPTION( ex );
|
|
|
|
}
|
|
|
|
return xResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Reference< chart2::data::XDataProvider > m_xDataProvider;
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef ::std::multimap< OUString, uno::WeakReference< chart2::data::XDataSequence > >
|
|
|
|
lcl_tSequenceMap;
|
|
|
|
|
|
|
|
struct lcl_modifySeqMapValue : public ::std::unary_function< lcl_tSequenceMap, void >
|
|
|
|
{
|
|
|
|
void operator() ( const lcl_tSequenceMap::value_type & rMapEntry )
|
|
|
|
{
|
|
|
|
// convert weak reference to reference
|
|
|
|
Reference< chart2::data::XDataSequence > xSeq( rMapEntry.second );
|
|
|
|
if( xSeq.is())
|
|
|
|
{
|
|
|
|
Reference< util::XModifiable > xMod( xSeq, uno::UNO_QUERY );
|
|
|
|
if( xMod.is())
|
|
|
|
xMod->setModified( sal_True );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Sequence< Reference< chart2::data::XLabeledDataSequence > >
|
|
|
|
lcl_internalizeData(
|
|
|
|
const Sequence< Reference< chart2::data::XLabeledDataSequence > > & rDataSeq,
|
|
|
|
impl::InternalData & rInternalData,
|
|
|
|
InternalDataProvider & rProvider )
|
|
|
|
{
|
|
|
|
Sequence< Reference< chart2::data::XLabeledDataSequence > > aResult( rDataSeq.getLength());
|
|
|
|
for( sal_Int32 i=0; i<rDataSeq.getLength(); ++i )
|
|
|
|
{
|
|
|
|
sal_Int32 nNewIndex( rInternalData.appendColumn());
|
|
|
|
OUString aIdentifier( OUString::valueOf( nNewIndex ));
|
|
|
|
//@todo: deal also with genericXDataSequence
|
|
|
|
Reference< chart2::data::XNumericalDataSequence > xValues( rDataSeq[i]->getValues(), uno::UNO_QUERY );
|
|
|
|
Reference< chart2::data::XTextualDataSequence > xLabel( rDataSeq[i]->getLabel(), uno::UNO_QUERY );
|
|
|
|
Reference< chart2::data::XDataSequence > xNewValues;
|
|
|
|
|
|
|
|
if( xValues.is())
|
|
|
|
{
|
|
|
|
::std::vector< double > aValues( ContainerHelper::SequenceToVector( xValues->getNumericalData()));
|
|
|
|
rInternalData.enlargeData( nNewIndex + 1, aValues.size());
|
|
|
|
rInternalData.setDataAt( nNewIndex, true, aValues );
|
|
|
|
xNewValues.set( rProvider.createDataSequenceByRangeRepresentation( aIdentifier ));
|
2008-06-16 11:56:50 +00:00
|
|
|
comphelper::copyProperties(
|
2007-05-22 17:59:49 +00:00
|
|
|
Reference< beans::XPropertySet >( xValues, uno::UNO_QUERY ),
|
|
|
|
Reference< beans::XPropertySet >( xNewValues, uno::UNO_QUERY ));
|
|
|
|
}
|
|
|
|
|
|
|
|
if( xLabel.is())
|
|
|
|
{
|
|
|
|
::std::vector< OUString > aLabels( rInternalData.getColumnLabels());
|
|
|
|
OSL_ASSERT( static_cast< size_t >( nNewIndex ) < aLabels.size());
|
2009-09-14 10:57:16 +00:00
|
|
|
if( aLabels.size() <= static_cast< size_t >( nNewIndex ) )
|
|
|
|
aLabels.resize( nNewIndex+1 );
|
2007-05-22 17:59:49 +00:00
|
|
|
aLabels[nNewIndex] = impl::FlattenStringSequence( xLabel->getTextualData());
|
|
|
|
rInternalData.setColumnLabels( aLabels );
|
|
|
|
Reference< chart2::data::XDataSequence > xNewLabel(
|
|
|
|
rProvider.createDataSequenceByRangeRepresentation( lcl_aLabelRangePrefix + aIdentifier ));
|
2008-06-16 11:56:50 +00:00
|
|
|
comphelper::copyProperties(
|
2007-05-22 17:59:49 +00:00
|
|
|
Reference< beans::XPropertySet >( xLabel, uno::UNO_QUERY ),
|
|
|
|
Reference< beans::XPropertySet >( xNewLabel, uno::UNO_QUERY ));
|
|
|
|
aResult[i] =
|
|
|
|
Reference< chart2::data::XLabeledDataSequence >(
|
|
|
|
new LabeledDataSequence( xNewValues, xNewLabel ));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
aResult[i] =
|
|
|
|
Reference< chart2::data::XLabeledDataSequence >(
|
|
|
|
new LabeledDataSequence( xNewValues ));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return aResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct lcl_internalizeSeries : public ::std::unary_function< Reference< chart2::XDataSeries >, void >
|
|
|
|
{
|
|
|
|
lcl_internalizeSeries( impl::InternalData & rInternalData,
|
|
|
|
InternalDataProvider & rProvider ) :
|
|
|
|
m_rInternalData( rInternalData ),
|
|
|
|
m_rProvider( rProvider )
|
|
|
|
{}
|
|
|
|
void operator() ( const Reference< chart2::XDataSeries > & xSeries )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XDataSource > xSource( xSeries, uno::UNO_QUERY );
|
|
|
|
Reference< chart2::data::XDataSink > xSink( xSeries, uno::UNO_QUERY );
|
|
|
|
if( xSource.is() && xSink.is())
|
|
|
|
xSink->setData( lcl_internalizeData( xSource->getDataSequences(), m_rInternalData, m_rProvider ));
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
impl::InternalData & m_rInternalData;
|
|
|
|
InternalDataProvider & m_rProvider;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // anonymous namespace
|
2008-06-16 11:56:50 +00:00
|
|
|
InternalDataProvider::InternalDataProvider(const Reference< uno::XComponentContext > & /*_xContext*/) :
|
|
|
|
m_bDataInColumns( true )
|
|
|
|
{}
|
2007-05-22 17:59:49 +00:00
|
|
|
|
|
|
|
// ================================================================================
|
|
|
|
|
|
|
|
InternalDataProvider::InternalDataProvider() :
|
|
|
|
m_bDataInColumns( true )
|
|
|
|
{}
|
|
|
|
|
|
|
|
InternalDataProvider::InternalDataProvider(
|
|
|
|
const Reference< ::com::sun::star::chart::XChartDataArray > & xDataToCopy ) :
|
|
|
|
m_bDataInColumns( true )
|
|
|
|
{
|
|
|
|
if( xDataToCopy.is())
|
|
|
|
{
|
|
|
|
setData( xDataToCopy->getData() );
|
|
|
|
setColumnDescriptions( xDataToCopy->getColumnDescriptions() );
|
|
|
|
setRowDescriptions( xDataToCopy->getRowDescriptions() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
InternalDataProvider::InternalDataProvider(
|
|
|
|
const Reference< chart2::XChartDocument > & xChartDoc ) :
|
|
|
|
m_bDataInColumns( true )
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
Reference< chart2::XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartDoc ) );
|
|
|
|
if( xDiagram.is())
|
|
|
|
{
|
|
|
|
impl::InternalData & rData( getInternalData());
|
|
|
|
// categories
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ));
|
|
|
|
if( xCategories.is())
|
|
|
|
{
|
|
|
|
// @todo: be able to deal with XDataSequence, too
|
|
|
|
Reference< chart2::data::XTextualDataSequence > xSeq( xCategories->getValues(), uno::UNO_QUERY );
|
|
|
|
if( xSeq.is())
|
|
|
|
rData.setRowLabels( ContainerHelper::SequenceToVector( xSeq->getTextualData()));
|
|
|
|
DiagramHelper::setCategoriesToDiagram(
|
|
|
|
new LabeledDataSequence(
|
|
|
|
createDataSequenceByRangeRepresentation( lcl_aCategoriesRangeName )),
|
|
|
|
xDiagram );
|
|
|
|
}
|
|
|
|
|
|
|
|
// data series
|
|
|
|
::std::vector< Reference< chart2::XDataSeries > > aSeriesVector( ChartModelHelper::getDataSeries( xChartDoc ));
|
|
|
|
::std::for_each( aSeriesVector.begin(), aSeriesVector.end(),
|
|
|
|
lcl_internalizeSeries( rData, *this ));
|
|
|
|
|
|
|
|
// unused data
|
|
|
|
Sequence< Reference< chart2::data::XLabeledDataSequence > > aUnusedData( xDiagram->getUnusedData());
|
|
|
|
aUnusedData = lcl_internalizeData( aUnusedData, rData, *this );
|
|
|
|
xDiagram->setUnusedData( aUnusedData );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch( const uno::Exception & ex )
|
|
|
|
{
|
|
|
|
ASSERT_EXCEPTION( ex );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// copy-CTOR
|
|
|
|
InternalDataProvider::InternalDataProvider( const InternalDataProvider & rOther ) :
|
2007-07-25 07:57:46 +00:00
|
|
|
impl::InternalDataProvider_Base(),
|
2007-05-22 17:59:49 +00:00
|
|
|
m_aSequenceMap( rOther.m_aSequenceMap ),
|
|
|
|
m_apData( new impl::InternalData( rOther.getInternalData())),
|
|
|
|
m_bDataInColumns( rOther.m_bDataInColumns )
|
|
|
|
{}
|
|
|
|
|
|
|
|
InternalDataProvider::~InternalDataProvider()
|
|
|
|
{}
|
|
|
|
|
|
|
|
void InternalDataProvider::addDataSequenceToMap(
|
|
|
|
const OUString & rRangeRepresentation,
|
|
|
|
const Reference< chart2::data::XDataSequence > & xSequence )
|
|
|
|
{
|
|
|
|
m_aSequenceMap.insert(
|
|
|
|
tSequenceMap::value_type(
|
|
|
|
rRangeRepresentation,
|
|
|
|
uno::WeakReference< chart2::data::XDataSequence >( xSequence )));
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalDataProvider::deleteMapReferences( const OUString & rRangeRepresentation )
|
|
|
|
{
|
|
|
|
// set sequence to deleted by setting its range to an empty string
|
|
|
|
tSequenceMapRange aRange( m_aSequenceMap.equal_range( rRangeRepresentation ));
|
|
|
|
for( tSequenceMap::iterator aIt( aRange.first ); aIt != aRange.second; ++aIt )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XDataSequence > xSeq( aIt->second );
|
|
|
|
if( xSeq.is())
|
|
|
|
{
|
|
|
|
Reference< container::XNamed > xNamed( xSeq, uno::UNO_QUERY );
|
|
|
|
if( xNamed.is())
|
|
|
|
xNamed->setName( OUString());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// remove from map
|
|
|
|
m_aSequenceMap.erase( aRange.first, aRange.second );
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalDataProvider::adaptMapReferences(
|
|
|
|
const OUString & rOldRangeRepresentation,
|
|
|
|
const OUString & rNewRangeRepresentation )
|
|
|
|
{
|
|
|
|
tSequenceMapRange aRange( m_aSequenceMap.equal_range( rOldRangeRepresentation ));
|
2007-07-25 07:57:46 +00:00
|
|
|
tSequenceMap aNewElements;
|
2007-05-22 17:59:49 +00:00
|
|
|
for( tSequenceMap::iterator aIt( aRange.first ); aIt != aRange.second; ++aIt )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XDataSequence > xSeq( aIt->second );
|
|
|
|
if( xSeq.is())
|
|
|
|
{
|
|
|
|
Reference< container::XNamed > xNamed( xSeq, uno::UNO_QUERY );
|
|
|
|
if( xNamed.is())
|
|
|
|
xNamed->setName( rNewRangeRepresentation );
|
|
|
|
}
|
2007-07-25 07:57:46 +00:00
|
|
|
aNewElements.insert( tSequenceMap::value_type( rNewRangeRepresentation, aIt->second ));
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
// erase map values for old index
|
|
|
|
m_aSequenceMap.erase( aRange.first, aRange.second );
|
|
|
|
// add new entries for values with new index
|
|
|
|
::std::copy( aNewElements.begin(), aNewElements.end(),
|
|
|
|
::std::inserter( m_aSequenceMap,
|
|
|
|
m_aSequenceMap.upper_bound( rNewRangeRepresentation )));
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalDataProvider::increaseMapReferences(
|
|
|
|
sal_Int32 nBegin, sal_Int32 nEnd )
|
|
|
|
{
|
|
|
|
for( sal_Int32 nIndex = nEnd - 1; nIndex >= nBegin; --nIndex )
|
|
|
|
{
|
|
|
|
adaptMapReferences( OUString::valueOf( nIndex ),
|
|
|
|
OUString::valueOf( nIndex + 1 ));
|
|
|
|
adaptMapReferences( lcl_aLabelRangePrefix + OUString::valueOf( nIndex ),
|
|
|
|
lcl_aLabelRangePrefix + OUString::valueOf( nIndex + 1 ));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalDataProvider::decreaseMapReferences(
|
|
|
|
sal_Int32 nBegin, sal_Int32 nEnd )
|
|
|
|
{
|
|
|
|
for( sal_Int32 nIndex = nBegin; nIndex < nEnd; ++nIndex )
|
|
|
|
{
|
|
|
|
adaptMapReferences( OUString::valueOf( nIndex ),
|
|
|
|
OUString::valueOf( nIndex - 1 ));
|
|
|
|
adaptMapReferences( lcl_aLabelRangePrefix + OUString::valueOf( nIndex ),
|
|
|
|
lcl_aLabelRangePrefix + OUString::valueOf( nIndex - 1 ));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XDataSequence > InternalDataProvider::createDataSequenceAndAddToMap(
|
|
|
|
const OUString & rRangeRepresentation )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XDataSequence > xSeq(
|
|
|
|
new UncachedDataSequence( this, rRangeRepresentation ));
|
|
|
|
addDataSequenceToMap( rRangeRepresentation, xSeq );
|
|
|
|
return xSeq;
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XDataSequence > InternalDataProvider::createDataSequenceAndAddToMap(
|
|
|
|
const OUString & rRangeRepresentation,
|
|
|
|
const OUString & rRole )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XDataSequence > xSeq(
|
|
|
|
new UncachedDataSequence( this, rRangeRepresentation, rRole ));
|
|
|
|
addDataSequenceToMap( rRangeRepresentation, xSeq );
|
|
|
|
return xSeq;
|
|
|
|
}
|
|
|
|
|
|
|
|
const impl::InternalData & InternalDataProvider::getInternalData() const
|
|
|
|
{
|
|
|
|
if( m_apData.get())
|
|
|
|
return *(m_apData.get());
|
|
|
|
|
|
|
|
m_apData.reset( new impl::InternalData());
|
|
|
|
return *(m_apData.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
impl::InternalData & InternalDataProvider::getInternalData()
|
|
|
|
{
|
|
|
|
if( m_apData.get())
|
|
|
|
return *(m_apData.get());
|
|
|
|
|
|
|
|
m_apData.reset( new impl::InternalData());
|
|
|
|
return *(m_apData.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
void InternalDataProvider::createDefaultData()
|
|
|
|
{
|
|
|
|
getInternalData().createDefaultData();
|
|
|
|
}
|
|
|
|
|
|
|
|
// ____ XDataProvider ____
|
2007-07-25 07:57:46 +00:00
|
|
|
::sal_Bool SAL_CALL InternalDataProvider::createDataSourcePossible( const Sequence< beans::PropertyValue >& /* aArguments */ )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-05-22 17:59:49 +00:00
|
|
|
Reference< chart2::data::XDataSource > SAL_CALL InternalDataProvider::createDataSource(
|
|
|
|
const Sequence< beans::PropertyValue >& aArguments )
|
|
|
|
throw (lang::IllegalArgumentException,
|
|
|
|
uno::RuntimeException)
|
|
|
|
{
|
|
|
|
OUString aRangeRepresentation;
|
|
|
|
bool bUseColumns = true;
|
|
|
|
bool bFirstCellAsLabel = true;
|
|
|
|
bool bHasCategories = true;
|
|
|
|
uno::Sequence< sal_Int32 > aSequenceMapping;
|
|
|
|
DataSourceHelper::readArguments( aArguments, aRangeRepresentation, aSequenceMapping, bUseColumns, bFirstCellAsLabel, bHasCategories );
|
|
|
|
|
|
|
|
OSL_ASSERT( aRangeRepresentation.equals( lcl_aCompleteRange ));
|
|
|
|
|
|
|
|
::std::vector< Reference< chart2::data::XLabeledDataSequence > > aResultLSeqVec;
|
|
|
|
impl::InternalData & rData( getInternalData());
|
|
|
|
|
|
|
|
// categories
|
CWS-TOOLING: integrate CWS dba32b
2009-06-03 14:58:08 +0200 fs r272581 : #i102439#
2009-05-29 13:56:18 +0200 fs r272456 : remove the sub form when the 'add subform' setting changes from <true/> to <false/>, not only its controls
2009-05-29 13:19:27 +0200 fs r272454 : display '(Default)' instead of an empty string when a control has the default font
2009-05-28 20:49:18 +0200 fs r272428 : #i98162# getFirstSelectedValue: do not return reference to a temporary
2009-05-27 15:30:22 +0200 msc r272353 : #102303#
2009-05-26 13:03:06 +0200 fs r272295 : spelling
2009-05-26 12:59:54 +0200 fs r272294 : merge m48 version to get latest cygwin related fixes
2009-05-25 14:02:06 +0200 fs r272239 : remove references to local files, needed for debugging sessions only
2009-05-25 14:01:16 +0200 fs r272238 : #i102021# ensure members such as bNumberFormat are initialized before actually returning them
2009-05-25 13:10:20 +0200 fs r272236 : #i10000# reset ENABLE_EVOAB2
2009-05-22 06:44:45 +0200 oj r272167 : #i99104# add import handler for calc-sett
2009-05-22 06:42:27 +0200 oj r272166 : #i99104# impl NullDate as member
2009-05-22 06:36:22 +0200 oj r272165 : #i99104# handle nulldate from parent model
2009-05-22 06:33:13 +0200 oj r272164 : #i99104# export and import calculation-settings and nulldate
2009-05-22 06:27:50 +0200 oj r272163 : #i99104# export and import calculation-settings and nulldate
2009-05-20 13:29:58 +0200 oj r272118 : #i99911# handle invalid name
2009-05-20 13:28:49 +0200 oj r272117 : #i101261# handle different rowsets
2009-05-20 11:29:55 +0200 msc r272111 : #i100000#
2009-05-20 11:28:27 +0200 msc r272110 : merge in change from dba32a
2009-05-20 11:27:38 +0200 msc r272109 : #102082# CTRL + C does not work
2009-05-20 09:43:36 +0200 oj r272106 : clean up includes
2009-05-20 09:32:15 +0200 oj r272105 : #i99060# merge error resovled now VERTICAL_ALIGN is in both stmt
2009-05-20 08:37:21 +0200 msc r272104 : add workaround for issue #102010#
2009-05-20 08:10:12 +0200 oj r272103 : #i99104# use numberformatkey
2009-05-20 08:07:02 +0200 oj r272102 : #i99104# use column info from rowset
2009-05-20 08:04:43 +0200 oj r272101 : #i102032# use a special column type where prec and scale are the values currently set at the column
2009-05-20 08:03:04 +0200 oj r272100 : #i102032# correct type info, we have to use SQL defined type names
2009-05-19 10:27:02 +0200 oj r272061 : #i99104# export null-date
2009-05-19 08:26:53 +0200 oj r272056 : #i99104# export null-date
2009-05-18 13:15:10 +0200 msc r272014 : add issue #102019#
2009-05-18 11:33:07 +0200 msc r272005 : add issue #102019#
2009-05-18 08:59:45 +0200 msc r271996 : add workaroud for issue #102010#
2009-05-15 10:21:24 +0200 msc r271929 : #101944#
2009-05-11 21:18:30 +0200 fs r271792 : #i99914#
2009-05-08 13:52:06 +0200 oj r271715 : #i96423# remember column span
2009-05-08 11:26:19 +0200 oj r271708 : #i98605# impl new scale mode
2009-05-08 10:33:35 +0200 fs r271706 : SendUserCall: only call into the shape notification routine for UserCall types where this is necessary (performance issue)
2009-05-07 20:52:44 +0200 fs r271698 : outsource ShapeProperty from shapepropertynotifier.hxx
2009-05-07 20:43:33 +0200 fs r271697 : #i99056# use notifyShapePropertyChange, instead of getShapePropertyChangeNotifier - the latter throws if no shape exists, yet
2009-05-07 20:33:58 +0200 fs r271696 : #i99056# +notifyShapePropertyChange: allow notifying chages without checking whether there actually already exists an SvxShape
2009-05-07 16:22:15 +0200 fs r271679 : #i10000# cygwin needs quotes around the classpath
2009-05-07 16:21:37 +0200 fs r271678 : #i10000# cygwin needs quotes around the classpath
2009-05-07 16:01:11 +0200 oj r271677 : #i99914# notify parent handler
2009-05-07 15:54:54 +0200 fs r271676 : #i10000# cygwin needs some quoting
2009-05-07 14:49:48 +0200 oj r271672 : #i99277# quote alias name
2009-05-07 14:48:12 +0200 oj r271671 : #i92538# add ~ in front of type
2009-05-07 14:37:13 +0200 oj r271667 : #i99118# change type from char to varchar
2009-05-07 14:36:23 +0200 oj r271666 : #i99118# clear dest columns when changing to create new table
2009-05-07 13:35:32 +0200 oj r271657 : #i94467# handle type 0 as double as well
2009-05-07 13:20:49 +0200 oj r271655 : i99743# setNull when varchar is no text
2009-05-07 12:58:06 +0200 fs r271651 : initialize the SdrObject's property change notifier after the ctor, if necessary
2009-05-07 11:47:18 +0200 fs r271647 : #i10000#
2009-05-07 10:57:16 +0200 fs r271639 : OPropertyBrowserController::propertyChange: care for the current property state, too, and properly forward it to the UI
2009-05-07 10:18:14 +0200 fs r271636 : onNewComponent: do not ask the map for grid columns, it will throw
2009-05-07 10:09:55 +0200 fs r271634 : #i101623#
2009-05-07 09:53:44 +0200 fs r271631 : #i101622#
2009-05-06 21:55:53 +0200 fs r271615 : #i10000#
2009-05-06 21:10:42 +0200 fs r271611 : #i10000#
2009-05-06 13:11:48 +0200 fs r271583 : #i10000#
2009-05-05 22:29:31 +0200 fs r271559 : proper assertion message
2009-05-05 22:29:03 +0200 fs r271558 : diagnostics
2009-05-05 22:16:16 +0200 fs r271557 : #i10000#
2009-05-05 13:50:32 +0200 fs r271513 : #i10000#
2009-05-05 10:21:50 +0200 fs r271503 : #i10000#
2009-05-05 09:30:26 +0200 fs r271501 : why did those survive the rebase -C step?
2009-05-05 09:18:12 +0200 fs r271500 : #i10000#
2009-05-04 17:08:17 +0200 fs r271475 : CWS-TOOLING: rebase CWS dba32b to trunk@271427 (milestone: DEV300:m47)
2009-05-04 14:51:26 +0200 fs r271456 : line ends
2009-04-30 15:55:27 +0200 fs r271418 : NewURL -> PublicConnectionURL
2009-04-22 21:18:34 +0200 fs r271141 : #i100944#
2009-04-22 09:12:26 +0200 oj r271071 : #i101261# little code change
2009-04-22 09:11:43 +0200 oj r271070 : #i101261# only ask for parameters which aren't set before
2009-04-22 09:11:25 +0200 oj r271069 : #i101261# new grabage container for nodes
2009-04-22 09:11:02 +0200 oj r271068 : #i101261# new grabage container for nodes
2009-04-22 09:10:44 +0200 oj r271067 : #i101261# new grabage container for nodes
2009-04-22 09:10:21 +0200 oj r271066 : #i101261# only ask for parameters which aren't set before
2009-04-22 09:08:24 +0200 oj r271065 : #i101261# only ask for parameters which aren't set before
2009-04-22 09:07:25 +0200 oj r271064 : #i101261# only ask for parameters which aren't set before
2009-04-22 08:49:07 +0200 oj r271062 : #i77501# preview only when needed
2009-04-22 08:45:44 +0200 oj r271061 : #i101261# new prop max rows
2009-04-22 08:44:18 +0200 oj r271060 : #i101261# create dataprovider earlier to avoid the wrong legend in chart
2009-04-22 08:42:48 +0200 oj r271059 : #i101261# handle parameter
2009-04-17 21:00:23 +0200 fs r270954 : #i98350#
2009-04-17 13:54:19 +0200 fs r270942 : #i99565#
2009-04-17 13:51:34 +0200 fs r270940 : #i101153# only localize the (potentially) localizable properties when there really is support at the control model
2009-04-17 11:43:14 +0200 fs r270932 : removed superfluous include
2009-04-17 10:10:15 +0200 fs r270926 : #i10000#
2009-04-17 10:02:36 +0200 fs r270925 : #i10000#
2009-04-17 09:15:13 +0200 fs r270918 : #i99056# some more refactoring of the recently introduced property change notification mechanism for UNO shapes
2009-04-17 09:14:56 +0200 fs r270917 : #i99056# some more refactoring of the recently introduced property change notification mechanism for UNO shapes
2009-04-17 09:13:25 +0200 fs r270915 : #i99056# some more refactoring of the recently introduced property change notification mechanism for UNO shapes
2009-04-17 08:30:34 +0200 fs r270914 : removed unotools/servicehelper.hxx in favour of the (duplicated) comphelper/servicehelper.hxx
2009-04-16 21:05:25 +0200 fs r270903 : #i10000#
2009-04-16 20:43:43 +0200 fs r270902 : #i99056# shape notification outsourced to the SdrObject, this is what all other shape implementations (which only aggregate an SvxShape) have access to, too
2009-04-16 15:57:36 +0200 fs r270891 : #i99056# make SetUnoControlModel virtual
2009-04-16 15:44:02 +0200 fs r270890 : #i99056# let the ScShapeObj notify changes in its Anchor property
2009-04-16 15:36:47 +0200 fs r270889 : #i99056# enable the sheet anchor type property, too
2009-04-16 15:33:45 +0200 fs r270887 : #i99056# shape notification outsourced to the SdrObject, this is what all other shape implementations (which only aggregate an SvxShape) have access to, too
2009-04-15 14:53:13 +0200 fs r270844 : #i10000#
2009-04-15 13:08:29 +0200 fs r270836 : #i10000#
2009-04-15 12:28:14 +0200 fs r270832 : #i10000#
2009-04-15 10:59:14 +0200 fs r270827 : #i10000#
2009-04-15 09:41:08 +0200 oj r270823 : fix issues found with findbugs and pmd
2009-04-14 21:08:04 +0200 fs r270808 : #i99056# implement SheetAnchorType - now the only thing missing to enable it is the proper notification when it is modified
2009-04-14 17:09:00 +0200 fs r270799 : #i99056# implement XServiceInfo for the ScShapeObj
2009-04-14 17:07:55 +0200 fs r270798 : #i99056# implement TextAnchorType, partially implement SheetAnchorType
2009-04-14 15:54:05 +0200 fs r270786 : #i99056# SwXShape: notify changes of the AnchorType property
2009-04-14 15:47:32 +0200 fs r270785 : #i99056# deliver shapepropertynotifier.hxx
2009-04-14 15:46:54 +0200 fs r270784 : diagnostics
2009-04-14 15:08:28 +0200 fs r270781 : #i99056# outsourced the SvxShape's property change notification code into a dedicated class
2009-04-14 14:41:09 +0200 fs r270773 : #i99056# outsourced the SvxShape's property change notification code into a dedicated class
2009-04-14 14:37:23 +0200 fs r270772 : in dtor, remove the properties from the temporary component context
2009-04-14 14:36:34 +0200 fs r270771 : getWeakUnoShape made const
2009-04-14 12:23:08 +0200 oj r270757 : #i101064# add missing braces
2009-04-14 12:21:25 +0200 oj r270756 : #i101065# add braces for gcc 4.3.2
2009-04-14 12:17:45 +0200 oj r270755 : #i101059# add dep for manifest
2009-04-09 12:06:58 +0200 oj r270686 : #i93100# use OptimalSize from control to get height
2009-04-08 09:56:55 +0200 oj r270619 : #i92537# handle calculations in the select columns as well
2009-04-08 09:30:39 +0200 oj r270615 : #i96657# throw error message when the key doesn't have any columns
2009-04-07 12:08:26 +0200 oj r270592 : #i77501# impl preview of the executed report
2009-04-07 12:01:56 +0200 oj r270591 : #i77501# impl preview of the executed report
2009-04-07 11:41:03 +0200 oj r270590 : #i77501# impl preview of the executed report
2009-04-07 11:39:32 +0200 oj r270589 : #i77501# impl preview of the executed report
2009-04-07 11:29:25 +0200 oj r270588 : #i77501# convert dos to unix lineends
2009-04-07 11:28:23 +0200 oj r270587 : #i77501# impl preview of the executed report
2009-04-07 11:16:50 +0200 oj r270586 : #i77501# impl preview of the executed report
2009-04-07 11:16:00 +0200 oj r270585 : #i77501# impl preview of the executed report
2009-04-07 11:15:44 +0200 oj r270584 : #i77501# impl preview of the executed report
2009-04-07 11:15:28 +0200 oj r270583 : #i77501# impl preview of the executed report
2009-04-07 11:15:04 +0200 oj r270582 : #i77501# impl preview of the executed report
2009-04-06 15:38:54 +0200 fs r270559 : merge changes from CWS dba32a herein
2009-04-03 15:56:16 +0200 fs r270494 : ImpSvMEdit::Resize: do multiple iterations, if necessary
2009-04-03 14:35:49 +0200 fs r270487 : #i10000#
2009-04-03 13:17:16 +0200 fs r270476 : #i99056# display geometry information for controls, too
2009-04-03 13:16:37 +0200 fs r270475 : #i99056# better ordering of the geometry properties
2009-04-03 13:16:07 +0200 fs r270473 : #i99056# now that SvxShape supports property change listeners, forward add/remove requests to it
2009-04-03 13:13:18 +0200 fs r270472 : #i99056# at SvxShape, allow for PropertyChangeListeners for Size/Position
2009-04-03 09:29:27 +0200 oj r270456 : #i94571# use correct prop name
2009-04-03 09:14:54 +0200 fs r270451 : merge changes from CWS dba32a herein
2009-04-02 17:00:51 +0200 fs r270424 : better diagnostics
2009-04-02 16:35:19 +0200 fs r270421 : diagnostics
2009-04-02 16:34:50 +0200 fs r270420 : #i99056# mxUnoShape not accessible anymore, use impl_setUnoShape instead
2009-04-02 16:32:48 +0200 fs r270419 : #i99056# make getUnoShape cheaper: keep the pointer to the SvxShape all the time, so there's no need to ask for it in getUnoShape. As a consequence, we will later be able to use the pointer in scenarious where performance (potentially) matters
2009-04-02 16:31:13 +0200 fs r270417 : merge changes from CWS dba32a herein
2009-04-02 16:23:16 +0200 fs r270414 : merge changes from CWS dba32a herein
2009-04-02 14:10:35 +0200 fs r270405 : #i10000#
2009-04-02 14:06:26 +0200 fs r270404 : merge changes from CWS dba32a herein
2009-04-02 14:03:03 +0200 fs r270401 : #i10000#
2009-04-02 13:58:13 +0200 fs r270400 : #i10000#
2009-04-02 12:59:44 +0200 fs r270397 : merge changes from CWS dba32a herein
2009-04-02 12:46:30 +0200 fs r270396 : #i99056# let the form page maintain a mapping between control models and control shapes
2009-04-02 12:44:07 +0200 fs r270395 : merge changes from CWS dba32a herein
2009-04-02 12:42:06 +0200 fs r270394 : merge changes from CWS dba32a herein
2009-04-02 12:35:20 +0200 fs r270393 : #i10000# precompiled header
2009-04-02 12:05:31 +0200 fs r270392 : merge changes from CWS dba32a herein
2009-04-02 12:00:42 +0200 fs r270391 : merge changes from CWS dba32a herein
2009-04-02 11:47:26 +0200 fs r270390 : merge changes from CWS dba32a herein
2009-04-02 11:39:15 +0200 oj r270389 : #i94467# foxpro impl several new types
2009-04-02 11:35:58 +0200 fs r270387 : merge changes from CWS dba32a herein
2009-04-01 14:10:51 +0200 fs r270329 : merge changes from CWS dba32a herein
2009-03-31 17:29:50 +0200 fs r270290 : merge changes from CWS dba32a herein
2009-03-30 14:53:56 +0200 fs r270233 : #i100417# don't set grid column widths to 0, but to <void/>
2009-03-30 12:31:03 +0200 oj r270213 : #i100552# wrong orb used
2009-03-30 12:19:20 +0200 oj r270212 : #i98303# convertlike corrected to sal_Unicode
2009-03-30 11:58:25 +0200 fs r270210 : merge changes from CWS dba32a herein
2009-03-30 11:38:16 +0200 oj r270205 : remove duplicate code from merge
2009-03-30 11:02:27 +0200 fs r270202 : merge changes from CWS dba32a herein
2009-03-30 11:02:19 +0200 fs r270201 : merge changes from CWS dba32a herein
2009-03-30 10:31:26 +0200 oj r270200 : #i100665# only throw exception and do not drop table
2009-03-30 09:36:24 +0200 fs r270195 : assertion text
2009-03-28 20:21:58 +0100 fs r270187 : #ii10000#
2009-03-28 20:19:54 +0100 fs r270186 : removed unused help ids
2009-03-28 20:19:40 +0100 fs r270185 : removed unused help ids
2009-03-28 20:19:10 +0100 fs r270184 : #i100237# +DefaultState/XReset
2009-03-28 00:29:29 +0100 fs r270177 : CWS-TOOLING: rebase CWS dba32b to trunk@270033 (milestone: DEV300:m45)
2009-03-27 22:56:46 +0100 fs r270173 : #i100237# DEFAULT_CHECKED -> DEFAULT_STATE
2009-03-27 22:55:52 +0100 fs r270172 : #i100237# DefaultState property for buttons, enabled only when Toggle=Yes
2009-03-27 22:54:15 +0100 fs r270171 : #i100237# DEFAULT_CHECKED -> DEFAULT_STATE
2009-03-27 22:53:54 +0100 fs r270170 : #i100237# introduce a DefaultState property for buttons, which implies buttongs supporting XReset, which needed some refactoring
2009-03-27 13:31:41 +0100 fs r270152 : ignore output paths
2009-03-27 11:23:44 +0100 fs r270139 : tuned behavior with respect to invalid keys/values
2009-03-27 09:57:14 +0100 fs r270136 : don't allow Double.NaN
2009-03-27 09:56:16 +0100 fs r270135 : talk about Double.NaN
2009-03-26 12:14:30 +0100 fs r270067 : removed unused parameter
2009-03-26 12:14:02 +0100 fs r270066 : removed widening conversion when checking keys
2009-03-26 09:17:34 +0100 fs r270053 : separated the enumerator functionality into a dedicated interface, this way not burdening XMap with it
2009-03-26 09:17:11 +0100 fs r270052 : separated the enumerator functionality into a dedicated interface, this way not burdening XMap with it
2009-03-26 09:16:49 +0100 fs r270051 : separated the enumerator functionality into a dedicated interface, this way not burdening XMap with it
2009-03-25 21:55:20 +0100 fs r270044 : #i100541# properly calculat bNeedScrollBox
2009-03-25 12:56:17 +0100 fs r270019 : renamed the previously introduced error condition
2009-03-25 12:11:48 +0100 fs r270015 : #i100095# when the error messages contain non-trivial details (SQLState/ErrorCode), then always display the 'Details' button
2009-03-25 12:10:05 +0100 fs r270012 : renamed the previously introduced error condition
2009-03-25 12:01:04 +0100 fs r270011 : #i100095# when no address book (or respective profile) can be found, then use a dedicated ErrorCondition
2009-03-25 10:29:07 +0100 fs r270003 : add missing localization
2009-03-25 10:23:12 +0100 fs r270001 : in preparation of #i1000095#:
rework the error handling, allow using css.sdb.ErrorCondition values, plus
allow propagating the nsresult
2009-03-25 10:21:55 +0100 fs r270000 : in preparation of #i1000095#:
rework the error handling, allow using css.sdb.ErrorCondition values, plus
allow propagating the nsresult
2009-03-20 23:05:38 +0100 fs r269829 : XMap::getSize removed
2009-03-20 23:05:19 +0100 fs r269828 : changes as suggested by sb
2009-03-20 23:04:56 +0100 fs r269827 : enhanced documentation
2009-03-20 15:31:40 +0100 fs r269815 : changes as suggested by sb
2009-03-20 13:23:52 +0100 oj r269804 : #i92538# correct the zorder that fixedtext is infront of control
2009-03-20 12:59:38 +0100 oj r269801 : #i94571# paraadjust now supports BLOCK
2009-03-20 12:58:11 +0100 oj r269800 : #i94571# export style with data style
2009-03-20 12:57:05 +0100 oj r269799 : #i94571# text align is now paraadjust
2009-03-20 12:37:02 +0100 fs r269797 : enum keys only accepted if they have the exact type, not if they have *any* enum type
2009-03-20 12:28:31 +0100 fs r269794 : some changes requested by sb
2009-03-20 08:52:47 +0100 fs r269780 : doc
2009-03-20 07:37:31 +0100 oj r269779 : #i99913# only notifiy when values are different
2009-03-20 07:36:58 +0100 oj r269778 : #i99913# add undoenv as listener at the dataprovider
2009-03-19 22:52:52 +0100 fs r269771 : added comment
2009-03-19 22:40:06 +0100 fs r269770 : +testEnumeration
2009-03-19 22:39:41 +0100 fs r269769 : implemented enumeration, getKeySet, and getValues. Should be finished now.
2009-03-19 14:01:01 +0100 oj r269743 : #i99913# reset the modified state when selecting an object
2009-03-19 12:19:54 +0100 lla r269739 : #i72390# cleanups
2009-03-19 09:25:27 +0100 fs r269727 : #i10000#
2009-03-18 23:37:02 +0100 fs r269708 : extended checks for value type acceptance
2009-03-18 23:36:41 +0100 fs r269707 : fixed value type checks
2009-03-18 14:59:56 +0100 fs r269678 : initial complex test case for the new css.container.Map implementation
2009-03-18 14:59:24 +0100 fs r269677 : verifyExpectedException moved to base class (in complexlib), and renamed to assureException for consistency
2009-03-18 14:58:35 +0100 fs r269676 : removed unused imports
2009-03-18 14:58:03 +0100 fs r269675 : first implementation of the new css.container.Map service (not completed, yet)
2009-03-18 14:57:17 +0100 fs r269674 : base class for UNO components, freeing you from some repeating work
2009-03-18 14:55:53 +0100 fs r269672 : +assureException: call a given method with given parameters on a given object, ensure that a given exception is thrown by the method implementation
2009-03-18 14:54:58 +0100 fs r269671 : +getComponentContext
2009-03-18 14:54:00 +0100 fs r269670 : isEmpty returns a boolean, not a long
2009-03-18 14:14:43 +0100 oj r269663 : #i99743# now text also supports null
2009-03-18 13:54:14 +0100 oj r269660 : #i99223# remove check for 2 params
2009-03-18 13:33:35 +0100 oj r269659 : #i99060# replace text::ParagraphVertAlign with style::VerticalAlignment
2009-03-18 13:32:18 +0100 oj r269658 : #i99060# don't set void property when void isn't allowed
2009-03-18 13:31:11 +0100 oj r269657 : #i99060# handle vertical alignment
2009-03-18 13:28:28 +0100 oj r269656 : #i99060# remove unused elements from sytle
2009-03-18 09:35:42 +0100 lla r269639 : #i72390# cleanups
2009-03-18 09:31:20 +0100 lla r269638 : #i72390# add ButtonList
2009-03-18 09:30:46 +0100 lla r269637 : #i72390# renamed interface
2009-03-18 09:30:15 +0100 lla r269636 : #i72390# use ButtonList instead of ImageList
2009-03-18 09:29:05 +0100 lla r269635 : #i72390# new ButtonList, cleanups
2009-03-18 09:26:34 +0100 lla r269634 : #i72390# cleanups
2009-03-17 12:21:20 +0100 oj r269590 : #i99222# remove assertion
2009-03-17 12:17:22 +0100 oj r269589 : #i98605# impl scale mode
2009-03-17 12:10:42 +0100 oj r269588 : #i98605# impl scale mode
2009-03-17 11:40:15 +0100 oj r269584 : #i96944# doesn't create equation for shapes
2009-03-17 11:33:16 +0100 oj r269583 : #i96423# switch calc from float to long
2009-03-16 15:19:18 +0100 fs r269550 : #i41930# enable zoom for embedded/outplace documents
2009-03-16 14:25:54 +0100 oj r269542 : #i93734# remove ContextSensitive
2009-03-16 14:21:58 +0100 oj r269541 : #i99274# page header before group header
2009-03-16 14:18:23 +0100 oj r269539 : #i99110# fix value type
2009-03-16 14:14:16 +0100 fs r269537 : line ends
2009-03-16 14:11:06 +0100 fs r269535 : line ends
2009-03-16 14:08:34 +0100 fs r269534 : #i100087# (provided my np): allow for polymorphic types with more than one parameter
2009-03-16 12:30:31 +0100 oj r269521 : compile error
2009-03-16 12:19:12 +0100 oj r269519 : compile error
2009-03-16 10:39:28 +0100 oj r269511 : compile error under linux with swap
2009-03-13 10:33:04 +0100 oj r269462 : CWS-TOOLING: rebase CWS dba32b to trunk@269297 (milestone: DEV300:m43)
2009-03-12 14:37:25 +0100 fs r269416 : interface SequenceOutputStreamTest is unneeded, and pollutes the namespace here :)
2009-03-12 14:35:07 +0100 fs r269414 : not needed
2009-03-12 14:34:15 +0100 fs r269413 : preparation for multiple tests in this module
2009-03-12 14:33:02 +0100 fs r269412 : ShowTargets was moved from module integration.forms to module complexlib
2009-03-12 14:32:48 +0100 fs r269411 : helper class for projects containing multiple complex test cases (and following a certain structure)
2009-03-12 14:00:14 +0100 fs r269407 : proper module after the move
2009-03-12 13:59:10 +0100 fs r269406 : superseded by ../makefile.mk
2009-03-12 13:47:38 +0100 fs r269403 : not needed anymore
2009-03-12 13:45:46 +0100 fs r269402 : moved, in preparation of adding more test cases here, with a common infrastructure
2009-03-12 13:45:07 +0100 fs r269401 : moved from ../
2009-03-12 13:43:59 +0100 fs r269400 : moved to ./comphelper, in preparation of adding more test cases here, with a common infrastructure
2009-03-12 13:29:47 +0100 oj r269396 : #i99914# set parent on dataprovider
2009-03-12 13:10:35 +0100 oj r269393 : #i99832# check thrown exception and show error
2009-03-12 13:08:10 +0100 fs r269392 : reorganizing tests
2009-03-12 12:52:55 +0100 oj r269390 : #i99118# convert formatkey in numberformat
2009-03-12 12:34:53 +0100 fs r269388 : new API tests
2009-03-12 12:29:05 +0100 fs r269386 : Map not yet committed
2009-03-12 12:28:36 +0100 fs r269385 : oops, forgot the SequenceInputStream during the previous refactoring
2009-03-12 12:12:39 +0100 oj r269384 : #i99104# set HasCategories prop
2009-03-12 12:12:08 +0100 oj r269383 : #i99104# check HasCategories even for internal dataprovider
2009-03-12 12:10:40 +0100 oj r269382 : #i99104# set HasCategories prop
2009-03-12 10:51:49 +0100 fs r269373 : #i10000# exception specifications
2009-03-12 10:49:18 +0100 fs r269372 : #i10000# exception specifications
2009-03-12 10:44:02 +0100 fs r269371 : #i10000# exception specifications
2009-03-12 10:30:55 +0100 fs r269368 : refactored the UNO service registration in this module, using the helper classes provided by comphelper itself, so you have less effort when extending the list of to-be-registered components
2009-03-12 10:30:37 +0100 fs r269367 : module-local includes
2009-03-12 07:05:54 +0100 oj r269357 : #i99104# database dataprovider doesn't need dataranges and diagramdata
2009-03-11 10:58:28 +0100 oj r269306 : #i99911# check if name of the report is a valid file name
2009-03-11 10:03:23 +0100 oj r269299 : #i99666# the report is new when the HierarchicalDocumentName is empty
2009-03-10 11:32:45 +0100 oj r269258 : #i99221# use fallback for language
2009-03-10 10:48:40 +0100 oj r269255 : #i99433# now use OStringBuffer
2009-03-10 10:36:21 +0100 fs r269252 : initial version of (X)Map
2009-03-10 09:52:23 +0100 oj r269246 : #i99433# now use OStringBuffer
2009-03-10 08:56:13 +0100 oj r269240 : #i99655# patch applied
2009-03-09 07:35:33 +0100 lla r269058 : #i10000# wrong variable assignment fixed
2009-03-06 17:20:40 +0100 fs r269030 : some explicit defaults
2009-03-06 17:20:30 +0100 fs r269029 : #i98600#
2009-03-06 14:40:34 +0100 fs r269009 : #i87692# during reload, prevent the document being modified just because of some control content changes ...
2009-03-06 12:52:20 +0100 lla r268997 : #i10000# ambigous problem with FontWeight fixed
2009-03-06 11:39:32 +0100 fs r268989 : #i10000# (approved by pl): use --without-t1-library configure option
2009-03-06 10:55:43 +0100 fs r268986 : #i99953# depends on xmlscript module now
2009-03-06 10:54:04 +0100 fs r268985 : #i99953# also adjust the event names found in dialogs embedded in the forms
2009-03-06 09:53:41 +0100 fs r268977 : #i10000#
2009-03-06 09:30:41 +0100 lla r268973 : #i10000# merge problems
2009-03-05 17:52:34 +0100 fs r268932 : #i98593# for sub components which are actually controlled by a DocumentDefinition (aka XComponentSupplier aka XCommandProcessor), close them by executing the 'close' command, not by suspending/closing the controller (which cannot be intercepted)
2009-03-05 11:41:56 +0100 fs r268889 : default the drop down line count for list/combo boxes to 20
2009-03-05 11:39:10 +0100 fs r268887 : do not display empty error messages
2009-03-02 10:13:57 +0100 lla r268639 : #i91541# CWS rebase m41 to m42
2009-03-02 09:06:27 +0100 lla r268635 : #i10000# add ';' to strings
2009-02-26 11:18:00 +0100 fs r268492 : reportdesign depends on REPORTBUILDER, not REPORTDESIGN
2009-02-26 10:11:38 +0100 lla r268489 : CWS-TOOLING: rebase CWS dba32b to trunk@268395 (milestone: DEV300:m42)
2009-02-26 09:04:11 +0100 lla r268488 : CWS-TOOLING: rebase CWS dba32b to trunk@268395 (milestone: DEV300:m42)
2009-02-24 12:09:13 +0100 lla r268392 : #i91541# #i91542# cleanups
2009-02-24 08:08:06 +0100 lla r268382 : merge all dba32a changes into dba32b
2009-02-24 07:14:55 +0100 lla r268381 : merge all dba32a changes into dba32b
2009-02-23 21:44:28 +0100 fs r268377 : oops ... don't tamper with m_aListSourceValues at the end of loadData
2009-02-23 20:57:05 +0100 fs r268376 : #i98162# don't hold the values as strings, but as ORowSetValue, this way preserving their type, and being agnostic to different result/rowset implementations doing different to-string-conversations
2009-02-23 20:55:44 +0100 fs r268375 : getObject: throwFunctionNotSupportedException, instead of silently returning NULL
2009-02-23 20:55:20 +0100 fs r268374 : #i98162# some more supported types
2009-02-23 20:54:43 +0100 fs r268373 : #i98162# +operator !=
2009-02-20 09:35:39 +0100 fs r268306 : #i99422# for a font, display the font name, the style, and the size
2009-02-20 09:33:45 +0100 fs r268305 : #i99422# in the property browser, FONT supersedes CHARFONTNAME: the aggregated FormComponentHandler displays them more nicely now
2009-02-19 16:12:06 +0100 fs r268293 : #i99372# recognize DataType::FLOAT as numeric
2009-02-19 15:43:12 +0100 fs r268291 : #i99415#
2009-02-19 15:40:15 +0100 fs r268290 : #i99242# lcl_firstFocussableControl: take disabled controls into account
2009-02-19 15:34:36 +0100 fs r268289 : #i99396# properly decode the base name of the URL when using it as title
2009-02-19 15:19:05 +0100 fs r268287 : #i98247#
2009-06-05 09:47:55 +00:00
|
|
|
if ( bHasCategories )
|
|
|
|
aResultLSeqVec.push_back(
|
|
|
|
new LabeledDataSequence( createDataSequenceAndAddToMap( lcl_aCategoriesRangeName, lcl_aCategoriesRoleName )));
|
2007-05-22 17:59:49 +00:00
|
|
|
|
|
|
|
// data with labels
|
|
|
|
::std::vector< Reference< chart2::data::XLabeledDataSequence > > aDataVec;
|
|
|
|
const sal_Int32 nCount = (bUseColumns ? rData.getColumnCount() : rData.getRowCount());
|
|
|
|
for( sal_Int32 nIdx=0; nIdx<nCount; ++nIdx )
|
|
|
|
{
|
|
|
|
aDataVec.push_back(
|
|
|
|
new LabeledDataSequence(
|
|
|
|
createDataSequenceAndAddToMap( OUString::valueOf( nIdx )),
|
|
|
|
createDataSequenceAndAddToMap( lcl_aLabelRangePrefix + OUString::valueOf( nIdx ))));
|
|
|
|
}
|
|
|
|
|
|
|
|
// attention: this data provider has the limitation that it stores
|
|
|
|
// internally if data comes from columns or rows. It is intended for
|
|
|
|
// creating only one used data source.
|
|
|
|
// @todo: add this information in the range representation strings
|
|
|
|
m_bDataInColumns = bUseColumns;
|
|
|
|
|
|
|
|
//reorder labeled sequences according to aSequenceMapping; ignore categories
|
|
|
|
for( sal_Int32 nNewIndex = 0; nNewIndex < aSequenceMapping.getLength(); nNewIndex++ )
|
|
|
|
{
|
|
|
|
std::vector< LabeledDataSequence* >::size_type nOldIndex = aSequenceMapping[nNewIndex];
|
|
|
|
if( nOldIndex < aDataVec.size() )
|
|
|
|
{
|
|
|
|
if( aDataVec[nOldIndex].is() )
|
|
|
|
{
|
|
|
|
aResultLSeqVec.push_back( aDataVec[nOldIndex] );
|
|
|
|
aDataVec[nOldIndex] = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//add left over data sequences to result
|
|
|
|
::std::vector< Reference< chart2::data::XLabeledDataSequence > >::iterator aIt(aDataVec.begin());
|
|
|
|
const ::std::vector< Reference< chart2::data::XLabeledDataSequence > >::const_iterator aEndIt(aDataVec.end());
|
|
|
|
for( ;aIt!=aEndIt; ++aIt)
|
|
|
|
{
|
|
|
|
if( aIt->is() )
|
|
|
|
aResultLSeqVec.push_back( *aIt );
|
|
|
|
}
|
|
|
|
|
|
|
|
return new DataSource( ContainerHelper::ContainerToSequence(aResultLSeqVec) );
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< beans::PropertyValue > SAL_CALL InternalDataProvider::detectArguments(
|
2008-03-18 14:58:12 +00:00
|
|
|
const Reference< chart2::data::XDataSource >& /* xDataSource */ )
|
2007-05-22 17:59:49 +00:00
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
Sequence< beans::PropertyValue > aArguments( 4 );
|
|
|
|
aArguments[0] = beans::PropertyValue(
|
|
|
|
C2U("CellRangeRepresentation"), -1, uno::makeAny( lcl_aCompleteRange ),
|
|
|
|
beans::PropertyState_DIRECT_VALUE );
|
|
|
|
aArguments[1] = beans::PropertyValue(
|
|
|
|
C2U("DataRowSource"), -1, uno::makeAny(
|
|
|
|
m_bDataInColumns
|
|
|
|
? ::com::sun::star::chart::ChartDataRowSource_COLUMNS
|
|
|
|
: ::com::sun::star::chart::ChartDataRowSource_ROWS ),
|
|
|
|
beans::PropertyState_DIRECT_VALUE );
|
|
|
|
// internal data always contains labels and categories
|
|
|
|
aArguments[2] = beans::PropertyValue(
|
|
|
|
C2U("FirstCellAsLabel"), -1, uno::makeAny( true ), beans::PropertyState_DIRECT_VALUE );
|
|
|
|
aArguments[3] = beans::PropertyValue(
|
|
|
|
C2U("HasCategories"), -1, uno::makeAny( true ), beans::PropertyState_DIRECT_VALUE );
|
|
|
|
|
2008-03-18 14:58:12 +00:00
|
|
|
// #i85913# Sequence Mapping is not needed for internal data, as it is
|
|
|
|
// applied to the data when the data source is created.
|
2007-05-22 17:59:49 +00:00
|
|
|
|
|
|
|
return aArguments;
|
|
|
|
}
|
|
|
|
|
2007-07-25 07:57:46 +00:00
|
|
|
::sal_Bool SAL_CALL InternalDataProvider::createDataSequenceByRangeRepresentationPossible( const OUString& /* aRangeRepresentation */ )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2007-05-22 17:59:49 +00:00
|
|
|
Reference< chart2::data::XDataSequence > SAL_CALL InternalDataProvider::createDataSequenceByRangeRepresentation(
|
|
|
|
const OUString& aRangeRepresentation )
|
|
|
|
throw (lang::IllegalArgumentException,
|
|
|
|
uno::RuntimeException)
|
|
|
|
{
|
|
|
|
if( aRangeRepresentation.equals( lcl_aCategoriesRangeName ))
|
2007-07-25 07:57:46 +00:00
|
|
|
{
|
2007-05-22 17:59:49 +00:00
|
|
|
// categories
|
|
|
|
return createDataSequenceAndAddToMap( lcl_aCategoriesRangeName, lcl_aCategoriesRoleName );
|
2007-07-25 07:57:46 +00:00
|
|
|
}
|
2007-05-22 17:59:49 +00:00
|
|
|
else if( aRangeRepresentation.match( lcl_aLabelRangePrefix ))
|
|
|
|
{
|
|
|
|
// label
|
|
|
|
sal_Int32 nIndex = aRangeRepresentation.copy( lcl_aLabelRangePrefix.getLength()).toInt32();
|
|
|
|
return createDataSequenceAndAddToMap( lcl_aLabelRangePrefix + OUString::valueOf( nIndex ));
|
|
|
|
}
|
2008-03-06 16:43:34 +00:00
|
|
|
else if( aRangeRepresentation.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "last" )))
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = (m_bDataInColumns
|
|
|
|
? getInternalData().getColumnCount()
|
|
|
|
: getInternalData().getRowCount()) - 1;
|
|
|
|
return createDataSequenceAndAddToMap( OUString::valueOf( nIndex ));
|
|
|
|
}
|
|
|
|
else if( aRangeRepresentation.getLength())
|
|
|
|
{
|
|
|
|
// data
|
|
|
|
sal_Int32 nIndex = aRangeRepresentation.toInt32();
|
|
|
|
return createDataSequenceAndAddToMap( OUString::valueOf( nIndex ));
|
|
|
|
}
|
2007-05-22 17:59:49 +00:00
|
|
|
|
2008-03-06 16:43:34 +00:00
|
|
|
return Reference< chart2::data::XDataSequence >();
|
2007-05-22 17:59:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Reference< sheet::XRangeSelection > SAL_CALL InternalDataProvider::getRangeSelection()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
// there is no range selection component
|
|
|
|
return Reference< sheet::XRangeSelection >();
|
|
|
|
}
|
|
|
|
|
|
|
|
// ____ XInternalDataProvider ____
|
|
|
|
::sal_Bool SAL_CALL InternalDataProvider::hasDataByRangeRepresentation( const OUString& aRange )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
sal_Bool bResult = false;
|
|
|
|
const impl::InternalData & rData( getInternalData());
|
|
|
|
|
|
|
|
if( aRange.equals( lcl_aCategoriesRangeName ))
|
|
|
|
{
|
|
|
|
bResult = true;
|
|
|
|
}
|
|
|
|
else if( aRange.match( lcl_aLabelRangePrefix ))
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRange.copy( lcl_aLabelRangePrefix.getLength()).toInt32();
|
|
|
|
bResult = (nIndex < (m_bDataInColumns ? rData.getColumnCount(): rData.getRowCount()));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRange.toInt32();
|
|
|
|
bResult = (nIndex < (m_bDataInColumns ? rData.getColumnCount(): rData.getRowCount()));
|
|
|
|
}
|
|
|
|
|
|
|
|
return bResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< uno::Any > SAL_CALL InternalDataProvider::getDataByRangeRepresentation( const OUString& aRange )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
Sequence< uno::Any > aResult;
|
|
|
|
const impl::InternalData & rData( getInternalData());
|
|
|
|
|
|
|
|
if( aRange.equals( lcl_aCategoriesRangeName ))
|
|
|
|
{
|
|
|
|
vector< OUString > aCategories( m_bDataInColumns ? rData.getRowLabels() : rData.getColumnLabels());
|
|
|
|
aResult.realloc( aCategories.size());
|
|
|
|
transform( aCategories.begin(), aCategories.end(),
|
|
|
|
aResult.getArray(), CommonFunctors::makeAny< OUString >());
|
|
|
|
}
|
|
|
|
else if( aRange.match( lcl_aLabelRangePrefix ))
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRange.copy( lcl_aLabelRangePrefix.getLength()).toInt32();
|
|
|
|
vector< OUString > aLabels( m_bDataInColumns ? rData.getColumnLabels() : rData.getRowLabels());
|
|
|
|
if( nIndex < static_cast< sal_Int32 >( aLabels.size()))
|
|
|
|
{
|
|
|
|
aResult.realloc( 1 );
|
|
|
|
aResult[0] = uno::makeAny( aLabels[ nIndex ] );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRange.toInt32();
|
|
|
|
if( nIndex < (m_bDataInColumns ? rData.getColumnCount() : rData.getRowCount()))
|
|
|
|
{
|
|
|
|
Sequence< double > aData( rData.getDataAt( nIndex, m_bDataInColumns ));
|
|
|
|
aResult.realloc( aData.getLength());
|
|
|
|
transform( aData.getConstArray(), aData.getConstArray() + aData.getLength(),
|
|
|
|
aResult.getArray(), CommonFunctors::makeAny< double >());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return aResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::setDataByRangeRepresentation(
|
|
|
|
const OUString& aRange, const Sequence< uno::Any >& aNewData )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
impl::InternalData & rData( getInternalData());
|
|
|
|
|
|
|
|
if( aRange.equals( lcl_aCategoriesRangeName ))
|
|
|
|
{
|
|
|
|
vector< OUString > aCategories;
|
|
|
|
transform( aNewData.getConstArray(), aNewData.getConstArray() + aNewData.getLength(),
|
|
|
|
back_inserter( aCategories ), CommonFunctors::AnyToString());
|
|
|
|
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
rData.setRowLabels( aCategories );
|
|
|
|
else
|
|
|
|
rData.setColumnLabels( aCategories );
|
|
|
|
}
|
|
|
|
else if( aRange.match( lcl_aLabelRangePrefix ))
|
|
|
|
{
|
2008-06-16 11:56:50 +00:00
|
|
|
sal_uInt32 nIndex = aRange.copy( lcl_aLabelRangePrefix.getLength()).toInt32();
|
2007-05-22 17:59:49 +00:00
|
|
|
OUString aNewLabel;
|
|
|
|
if( aNewData.getLength() &&
|
|
|
|
(aNewData[0] >>= aNewLabel))
|
|
|
|
{
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
vector< OUString > aLabels( rData.getColumnLabels());
|
2008-06-16 11:56:50 +00:00
|
|
|
if ( aLabels.size() <= nIndex )
|
|
|
|
aLabels.push_back(aNewLabel);
|
|
|
|
else
|
|
|
|
aLabels[ nIndex ] = aNewLabel;
|
2007-05-22 17:59:49 +00:00
|
|
|
rData.setColumnLabels( aLabels );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
vector< OUString > aLabels( rData.getRowLabels());
|
2008-06-16 11:56:50 +00:00
|
|
|
if ( aLabels.size() <= nIndex )
|
|
|
|
aLabels.push_back(aNewLabel);
|
|
|
|
else
|
|
|
|
aLabels[ nIndex ] = aNewLabel;
|
2007-05-22 17:59:49 +00:00
|
|
|
rData.setRowLabels( aLabels );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRange.toInt32();
|
|
|
|
// ensure that the data is large enough
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
rData.enlargeData( nIndex, 0 );
|
|
|
|
else
|
|
|
|
rData.enlargeData( 0, nIndex );
|
|
|
|
|
|
|
|
if( nIndex < (m_bDataInColumns ? rData.getColumnCount() : rData.getRowCount()))
|
|
|
|
{
|
|
|
|
vector< double > aNewDataVec;
|
|
|
|
transform( aNewData.getConstArray(), aNewData.getConstArray() + aNewData.getLength(),
|
|
|
|
back_inserter( aNewDataVec ), CommonFunctors::AnyToDouble());
|
|
|
|
rData.setDataAt( nIndex, m_bDataInColumns, aNewDataVec );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::insertSequence( ::sal_Int32 nAfterIndex )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
increaseMapReferences( nAfterIndex + 1, getInternalData().getColumnCount());
|
|
|
|
getInternalData().insertColumn( nAfterIndex );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
increaseMapReferences( nAfterIndex + 1, getInternalData().getRowCount());
|
|
|
|
getInternalData().insertRow( nAfterIndex );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::deleteSequence( ::sal_Int32 nAtIndex )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
deleteMapReferences( OUString::valueOf( nAtIndex ));
|
|
|
|
deleteMapReferences( lcl_aLabelRangePrefix + OUString::valueOf( nAtIndex ));
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
decreaseMapReferences( nAtIndex + 1, getInternalData().getColumnCount());
|
|
|
|
getInternalData().deleteColumn( nAtIndex );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
decreaseMapReferences( nAtIndex + 1, getInternalData().getRowCount());
|
|
|
|
getInternalData().deleteRow( nAtIndex );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-03-06 16:43:34 +00:00
|
|
|
void SAL_CALL InternalDataProvider::appendSequence()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
getInternalData().appendColumn();
|
|
|
|
else
|
|
|
|
getInternalData().appendRow();
|
|
|
|
}
|
|
|
|
|
2007-05-22 17:59:49 +00:00
|
|
|
void SAL_CALL InternalDataProvider::insertDataPointForAllSequences( ::sal_Int32 nAfterIndex )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
sal_Int32 nMaxRep = 0;
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
getInternalData().insertRow( nAfterIndex );
|
|
|
|
nMaxRep = getInternalData().getColumnCount();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
getInternalData().insertColumn( nAfterIndex );
|
|
|
|
nMaxRep = getInternalData().getRowCount();
|
|
|
|
}
|
|
|
|
|
|
|
|
// notify change to all affected ranges
|
|
|
|
tSequenceMap::const_iterator aBegin( m_aSequenceMap.lower_bound( C2U("0")));
|
|
|
|
tSequenceMap::const_iterator aEnd( m_aSequenceMap.upper_bound( OUString::valueOf( nMaxRep )));
|
|
|
|
::std::for_each( aBegin, aEnd, lcl_modifySeqMapValue());
|
|
|
|
|
|
|
|
tSequenceMapRange aRange( m_aSequenceMap.equal_range( lcl_aCategoriesRangeName ));
|
|
|
|
::std::for_each( aRange.first, aRange.second, lcl_modifySeqMapValue());
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::deleteDataPointForAllSequences( ::sal_Int32 nAtIndex )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
sal_Int32 nMaxRep = 0;
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
getInternalData().deleteRow( nAtIndex );
|
|
|
|
nMaxRep = getInternalData().getColumnCount();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
getInternalData().deleteColumn( nAtIndex );
|
|
|
|
nMaxRep = getInternalData().getRowCount();
|
|
|
|
}
|
|
|
|
|
|
|
|
// notify change to all affected ranges
|
|
|
|
tSequenceMap::const_iterator aBegin( m_aSequenceMap.lower_bound( C2U("0")));
|
|
|
|
tSequenceMap::const_iterator aEnd( m_aSequenceMap.upper_bound( OUString::valueOf( nMaxRep )));
|
|
|
|
::std::for_each( aBegin, aEnd, lcl_modifySeqMapValue());
|
|
|
|
|
|
|
|
tSequenceMapRange aRange( m_aSequenceMap.equal_range( lcl_aCategoriesRangeName ));
|
|
|
|
::std::for_each( aRange.first, aRange.second, lcl_modifySeqMapValue());
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::swapDataPointWithNextOneForAllSequences( ::sal_Int32 nAtIndex )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
getInternalData().swapAllDataAtIndexWithNext( nAtIndex, m_bDataInColumns );
|
|
|
|
sal_Int32 nMaxRep = (m_bDataInColumns
|
|
|
|
? getInternalData().getColumnCount()
|
|
|
|
: getInternalData().getRowCount());
|
|
|
|
|
|
|
|
// notify change to all affected ranges
|
|
|
|
tSequenceMap::const_iterator aBegin( m_aSequenceMap.lower_bound( C2U("0")));
|
|
|
|
tSequenceMap::const_iterator aEnd( m_aSequenceMap.upper_bound( OUString::valueOf( nMaxRep )));
|
|
|
|
::std::for_each( aBegin, aEnd, lcl_modifySeqMapValue());
|
|
|
|
|
|
|
|
tSequenceMapRange aRange( m_aSequenceMap.equal_range( lcl_aCategoriesRangeName ));
|
|
|
|
::std::for_each( aRange.first, aRange.second, lcl_modifySeqMapValue());
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::registerDataSequenceForChanges( const Reference< chart2::data::XDataSequence >& xSeq )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
if( xSeq.is())
|
|
|
|
addDataSequenceToMap( xSeq->getSourceRangeRepresentation(), xSeq );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ____ XRangeXMLConversion ____
|
|
|
|
OUString SAL_CALL InternalDataProvider::convertRangeToXML( const OUString& aRangeRepresentation )
|
|
|
|
throw (lang::IllegalArgumentException,
|
|
|
|
uno::RuntimeException)
|
|
|
|
{
|
|
|
|
XMLRangeHelper::CellRange aRange;
|
|
|
|
aRange.aTableName = OUString(RTL_CONSTASCII_USTRINGPARAM("local-table"));
|
|
|
|
impl::InternalData & rData( getInternalData());
|
|
|
|
|
|
|
|
// attention: this data provider has the limitation that it stores
|
|
|
|
// internally if data comes from columns or rows. It is intended for
|
|
|
|
// creating only one used data source.
|
|
|
|
// @todo: add this information in the range representation strings
|
|
|
|
if( aRangeRepresentation.equals( lcl_aCategoriesRangeName ))
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.bIsEmpty = false;
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.nColumn = 0;
|
|
|
|
aRange.aUpperLeft.nRow = 1;
|
|
|
|
aRange.aLowerRight = aRange.aUpperLeft;
|
|
|
|
aRange.aLowerRight.nRow = rData.getRowCount();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.nColumn = 1;
|
|
|
|
aRange.aUpperLeft.nRow = 0;
|
|
|
|
aRange.aLowerRight = aRange.aUpperLeft;
|
|
|
|
aRange.aLowerRight.nColumn = rData.getColumnCount();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if( aRangeRepresentation.match( lcl_aLabelRangePrefix ))
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRangeRepresentation.copy( lcl_aLabelRangePrefix.getLength()).toInt32();
|
|
|
|
aRange.aUpperLeft.bIsEmpty = false;
|
|
|
|
aRange.aLowerRight.bIsEmpty = true;
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.nColumn = nIndex + 1;
|
|
|
|
aRange.aUpperLeft.nRow = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.nColumn = 0;
|
|
|
|
aRange.aUpperLeft.nRow = nIndex + 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if( aRangeRepresentation.equals( lcl_aCompleteRange ))
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.bIsEmpty = false;
|
|
|
|
aRange.aLowerRight.bIsEmpty = false;
|
|
|
|
aRange.aUpperLeft.nColumn = 0;
|
|
|
|
aRange.aUpperLeft.nRow = 0;
|
|
|
|
aRange.aLowerRight.nColumn = rData.getColumnCount();
|
|
|
|
aRange.aLowerRight.nRow = rData.getRowCount();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
sal_Int32 nIndex = aRangeRepresentation.toInt32();
|
|
|
|
aRange.aUpperLeft.bIsEmpty = false;
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.nColumn = nIndex + 1;
|
|
|
|
aRange.aUpperLeft.nRow = 1;
|
|
|
|
aRange.aLowerRight = aRange.aUpperLeft;
|
|
|
|
aRange.aLowerRight.nRow = rData.getRowCount();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
aRange.aUpperLeft.nColumn = 1;
|
|
|
|
aRange.aUpperLeft.nRow = nIndex + 1;
|
|
|
|
aRange.aLowerRight = aRange.aUpperLeft;
|
|
|
|
aRange.aLowerRight.nColumn = rData.getColumnCount();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return XMLRangeHelper::getXMLStringFromCellRange( aRange );
|
|
|
|
}
|
|
|
|
|
|
|
|
OUString SAL_CALL InternalDataProvider::convertRangeFromXML( const OUString& aXMLRange )
|
|
|
|
throw (lang::IllegalArgumentException,
|
|
|
|
uno::RuntimeException)
|
|
|
|
{
|
|
|
|
XMLRangeHelper::CellRange aRange( XMLRangeHelper::getCellRangeFromXMLString( aXMLRange ));
|
|
|
|
if( aRange.aUpperLeft.bIsEmpty )
|
|
|
|
{
|
|
|
|
OSL_ENSURE( aRange.aLowerRight.bIsEmpty, "Weird Range" );
|
|
|
|
return OUString();
|
|
|
|
}
|
|
|
|
|
|
|
|
// "all"
|
|
|
|
if( !aRange.aLowerRight.bIsEmpty &&
|
|
|
|
( aRange.aUpperLeft.nColumn != aRange.aLowerRight.nColumn ) &&
|
|
|
|
( aRange.aUpperLeft.nRow != aRange.aLowerRight.nRow ) )
|
|
|
|
return lcl_aCompleteRange;
|
|
|
|
|
|
|
|
// attention: this data provider has the limitation that it stores
|
|
|
|
// internally if data comes from columns or rows. It is intended for
|
|
|
|
// creating only one used data source.
|
|
|
|
// @todo: add this information in the range representation strings
|
|
|
|
|
|
|
|
// data in columns
|
|
|
|
if( m_bDataInColumns )
|
|
|
|
{
|
|
|
|
if( aRange.aUpperLeft.nColumn == 0 )
|
|
|
|
return lcl_aCategoriesRangeName;
|
|
|
|
if( aRange.aUpperLeft.nRow == 0 )
|
|
|
|
return lcl_aLabelRangePrefix + OUString::valueOf( aRange.aUpperLeft.nColumn - 1 );
|
|
|
|
|
|
|
|
return OUString::valueOf( aRange.aUpperLeft.nColumn - 1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
// data in rows
|
|
|
|
if( aRange.aUpperLeft.nRow == 0 )
|
|
|
|
return lcl_aCategoriesRangeName;
|
|
|
|
if( aRange.aUpperLeft.nColumn == 0 )
|
|
|
|
return lcl_aLabelRangePrefix + OUString::valueOf( aRange.aUpperLeft.nRow - 1 );
|
|
|
|
|
|
|
|
return OUString::valueOf( aRange.aUpperLeft.nRow - 1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
// ____ XChartDataArray ____
|
|
|
|
// note: do not use m_bDataInColumns for all XChartDataArray-specific code
|
|
|
|
// the chart-API assumes data is always in rows
|
|
|
|
Sequence< Sequence< double > > SAL_CALL InternalDataProvider::getData()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getInternalData().getData( false );
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::setData( const Sequence< Sequence< double > >& aData )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return getInternalData().setData( aData, false );
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< OUString > SAL_CALL InternalDataProvider::getRowDescriptions()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return ContainerHelper::ContainerToSequence( getInternalData().getRowLabels());
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::setRowDescriptions( const Sequence< OUString >& aRowDescriptions )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
getInternalData().setRowLabels( ContainerHelper::SequenceToVector( aRowDescriptions ));
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< OUString > SAL_CALL InternalDataProvider::getColumnDescriptions()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return ContainerHelper::ContainerToSequence( getInternalData().getColumnLabels());
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::setColumnDescriptions( const Sequence< OUString >& aColumnDescriptions )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
getInternalData().setColumnLabels( ContainerHelper::SequenceToVector( aColumnDescriptions ));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ____ XChartData (base of XChartDataArray) ____
|
|
|
|
void SAL_CALL InternalDataProvider::addChartDataChangeEventListener(
|
|
|
|
const Reference< ::com::sun::star::chart::XChartDataChangeEventListener >& )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void SAL_CALL InternalDataProvider::removeChartDataChangeEventListener(
|
|
|
|
const Reference< ::com::sun::star::chart::XChartDataChangeEventListener >& )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
double SAL_CALL InternalDataProvider::getNotANumber()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
double fNan;
|
|
|
|
::rtl::math::setNan( & fNan );
|
|
|
|
return fNan;
|
|
|
|
}
|
|
|
|
|
|
|
|
::sal_Bool SAL_CALL InternalDataProvider::isNotANumber( double nNumber )
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return ::rtl::math::isNan( nNumber )
|
|
|
|
|| ::rtl::math::isInf( nNumber );
|
|
|
|
}
|
2008-06-16 11:56:50 +00:00
|
|
|
// lang::XInitialization:
|
|
|
|
void SAL_CALL InternalDataProvider::initialize(const uno::Sequence< uno::Any > & _aArguments) throw (uno::RuntimeException, uno::Exception)
|
|
|
|
{
|
|
|
|
comphelper::SequenceAsHashMap aArgs(_aArguments);
|
|
|
|
if ( aArgs.getUnpackedValueOrDefault(::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("CreateDefaultData")),sal_False) )
|
|
|
|
createDefaultData();
|
|
|
|
}
|
2007-05-22 17:59:49 +00:00
|
|
|
// ____ XCloneable ____
|
|
|
|
Reference< util::XCloneable > SAL_CALL InternalDataProvider::createClone()
|
|
|
|
throw (uno::RuntimeException)
|
|
|
|
{
|
|
|
|
return Reference< util::XCloneable >( new InternalDataProvider( *this ));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ================================================================================
|
|
|
|
|
|
|
|
Sequence< OUString > InternalDataProvider::getSupportedServiceNames_Static()
|
|
|
|
{
|
|
|
|
Sequence< OUString > aServices( 1 );
|
|
|
|
aServices[ 0 ] = OUString( RTL_CONSTASCII_USTRINGPARAM( "com.sun.star.chart2.data.DataProvider" ));
|
|
|
|
return aServices;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ================================================================================
|
|
|
|
|
|
|
|
APPHELPER_XSERVICEINFO_IMPL( InternalDataProvider, lcl_aServiceName );
|
|
|
|
|
|
|
|
} // namespace chart
|