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
*
2010-02-12 15:01:35 +01:00
* Copyright 2000 , 2010 Oracle and / or its affiliates .
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
* 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"
2010-01-13 17:06:34 +01:00
# include "ExplicitCategoriesProvider.hxx"
2007-05-22 17:59:49 +00:00
# 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
{
// 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 " ) ) ;
2010-01-13 17:06:34 +01:00
static const : : rtl : : OUString lcl_aCategoriesLevelRangeNamePrefix (
RTL_CONSTASCII_USTRINGPARAM ( " categoriesL " ) ) ; //L <-> level
static const : : rtl : : OUString lcl_aCategoriesPointRangeNamePrefix (
RTL_CONSTASCII_USTRINGPARAM ( " categoriesP " ) ) ; //P <-> point
2007-05-22 17:59:49 +00:00
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 " ) ) ;
typedef : : std : : multimap < OUString , uno : : WeakReference < chart2 : : data : : XDataSequence > >
lcl_tSequenceMap ;
2010-01-13 17:06:34 +01:00
struct lcl_setModified : public : : std : : unary_function < lcl_tSequenceMap , void >
2007-05-22 17:59:49 +00:00
{
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 ) ;
}
}
} ;
struct lcl_internalizeSeries : public : : std : : unary_function < Reference < chart2 : : XDataSeries > , void >
{
2009-12-21 10:27:32 +01:00
lcl_internalizeSeries ( InternalData & rInternalData ,
2010-01-13 17:06:34 +01:00
InternalDataProvider & rProvider ,
bool bConnectToModel , bool bDataInColumns ) :
2007-05-22 17:59:49 +00:00
m_rInternalData ( rInternalData ) ,
2010-01-13 17:06:34 +01:00
m_rProvider ( rProvider ) ,
m_bConnectToModel ( bConnectToModel ) ,
m_bDataInColumns ( bDataInColumns )
2007-05-22 17:59:49 +00:00
{ }
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 ) ;
2010-01-13 17:06:34 +01:00
if ( xSource . is ( ) & & xSink . is ( ) )
{
Sequence < Reference < chart2 : : data : : XLabeledDataSequence > > aOldSeriesData = xSource - > getDataSequences ( ) ;
Sequence < Reference < chart2 : : data : : XLabeledDataSequence > > aNewSeriesData ( aOldSeriesData . getLength ( ) ) ;
for ( sal_Int32 i = 0 ; i < aOldSeriesData . getLength ( ) ; + + i )
{
sal_Int32 nNewIndex ( m_bDataInColumns ? m_rInternalData . appendColumn ( ) : m_rInternalData . appendRow ( ) ) ;
OUString aIdentifier ( OUString : : valueOf ( nNewIndex ) ) ;
//@todo: deal also with genericXDataSequence
Reference < chart2 : : data : : XNumericalDataSequence > xValues ( aOldSeriesData [ i ] - > getValues ( ) , uno : : UNO_QUERY ) ;
Reference < chart2 : : data : : XTextualDataSequence > xLabel ( aOldSeriesData [ i ] - > getLabel ( ) , uno : : UNO_QUERY ) ;
Reference < chart2 : : data : : XDataSequence > xNewValues ;
if ( xValues . is ( ) )
{
: : std : : vector < double > aValues ( ContainerHelper : : SequenceToVector ( xValues - > getNumericalData ( ) ) ) ;
if ( m_bDataInColumns )
m_rInternalData . setColumnValues ( nNewIndex , aValues ) ;
else
m_rInternalData . setRowValues ( nNewIndex , aValues ) ;
if ( m_bConnectToModel )
{
xNewValues . set ( m_rProvider . createDataSequenceByRangeRepresentation ( aIdentifier ) ) ;
comphelper : : copyProperties (
Reference < beans : : XPropertySet > ( xValues , uno : : UNO_QUERY ) ,
Reference < beans : : XPropertySet > ( xNewValues , uno : : UNO_QUERY ) ) ;
}
}
if ( xLabel . is ( ) )
{
if ( m_bDataInColumns )
m_rInternalData . setComplexColumnLabel ( nNewIndex , ContainerHelper : : SequenceToVector ( xLabel - > getTextualData ( ) ) ) ;
else
m_rInternalData . setComplexRowLabel ( nNewIndex , ContainerHelper : : SequenceToVector ( xLabel - > getTextualData ( ) ) ) ;
if ( m_bConnectToModel )
{
Reference < chart2 : : data : : XDataSequence > xNewLabel (
m_rProvider . createDataSequenceByRangeRepresentation ( lcl_aLabelRangePrefix + aIdentifier ) ) ;
comphelper : : copyProperties (
Reference < beans : : XPropertySet > ( xLabel , uno : : UNO_QUERY ) ,
Reference < beans : : XPropertySet > ( xNewLabel , uno : : UNO_QUERY ) ) ;
aNewSeriesData [ i ] = Reference < chart2 : : data : : XLabeledDataSequence > (
new LabeledDataSequence ( xNewValues , xNewLabel ) ) ;
}
}
else
{
if ( m_bConnectToModel )
aNewSeriesData [ i ] = Reference < chart2 : : data : : XLabeledDataSequence > (
new LabeledDataSequence ( xNewValues ) ) ;
}
}
if ( m_bConnectToModel )
xSink - > setData ( aNewSeriesData ) ;
}
2007-05-22 17:59:49 +00:00
}
private :
2009-12-21 10:27:32 +01:00
InternalData & m_rInternalData ;
2007-05-22 17:59:49 +00:00
InternalDataProvider & m_rProvider ;
2010-01-13 17:06:34 +01:00
bool m_bConnectToModel ;
bool m_bDataInColumns ;
2007-05-22 17:59:49 +00:00
} ;
2010-01-13 17:06:34 +01:00
struct lcl_makeAnyFromLevelVector : public : : std : : unary_function < vector < OUString > , uno : : Any >
{
public :
2007-05-22 17:59:49 +00:00
2010-01-13 17:06:34 +01:00
explicit lcl_makeAnyFromLevelVector ( sal_Int32 nLevel ) : m_nLevel ( nLevel )
{ }
2007-05-22 17:59:49 +00:00
2010-01-13 17:06:34 +01:00
uno : : Any operator ( ) ( const vector < OUString > & rVector )
{
OUString aString ;
2010-01-29 17:23:04 +01:00
if ( m_nLevel < static_cast < sal_Int32 > ( rVector . size ( ) ) )
2010-01-13 17:06:34 +01:00
aString = rVector [ m_nLevel ] ;
return uno : : makeAny ( aString ) ;
}
private :
sal_Int32 m_nLevel ;
} ;
struct lcl_getStringFromLevelVector : public : : std : : unary_function < vector < OUString > , OUString >
{
public :
explicit lcl_getStringFromLevelVector ( sal_Int32 nLevel ) : m_nLevel ( nLevel )
{ }
OUString operator ( ) ( const vector < OUString > & rVector )
{
OUString aString ;
2010-01-29 17:23:04 +01:00
if ( m_nLevel < static_cast < sal_Int32 > ( rVector . size ( ) ) )
2010-01-13 17:06:34 +01:00
aString = rVector [ m_nLevel ] ;
return aString ;
}
private :
sal_Int32 m_nLevel ;
} ;
2007-05-22 17:59:49 +00:00
2010-01-13 17:06:34 +01:00
struct lcl_setStringAtLevel : public : : std : : binary_function < vector < OUString > , OUString , vector < OUString > >
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
public :
explicit lcl_setStringAtLevel ( sal_Int32 nLevel ) : m_nLevel ( nLevel )
{ }
vector < OUString > operator ( ) ( const vector < OUString > & rVector , const OUString & rNewText )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
vector < OUString > aRet ( rVector ) ;
2010-01-29 17:23:04 +01:00
if ( m_nLevel > = static_cast < sal_Int32 > ( aRet . size ( ) ) )
2010-01-13 17:06:34 +01:00
aRet . resize ( m_nLevel + 1 ) ;
aRet [ m_nLevel ] = rNewText ;
return aRet ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
private :
sal_Int32 m_nLevel ;
} ;
2010-01-28 10:52:28 +01:00
struct lcl_insertStringAtLevel : public : : std : : unary_function < vector < OUString > , void >
{
public :
explicit lcl_insertStringAtLevel ( sal_Int32 nLevel ) : m_nLevel ( nLevel )
{ }
void operator ( ) ( vector < OUString > & rVector )
{
2010-01-29 17:23:04 +01:00
if ( m_nLevel > static_cast < sal_Int32 > ( rVector . size ( ) ) )
2010-01-28 10:52:28 +01:00
rVector . resize ( m_nLevel ) ;
vector < OUString > : : iterator aIt ( rVector . begin ( ) ) ;
for ( sal_Int32 nN = 0 ; aIt < rVector . end ( ) ; aIt + + , nN + + )
{
if ( nN = = m_nLevel )
break ;
}
rVector . insert ( aIt , OUString ( ) ) ;
}
private :
sal_Int32 m_nLevel ;
} ;
struct lcl_removeStringAtLevel : public : : std : : unary_function < vector < OUString > , void >
{
public :
explicit lcl_removeStringAtLevel ( sal_Int32 nLevel ) : m_nLevel ( nLevel )
{ }
void operator ( ) ( vector < OUString > & rVector )
{
vector < OUString > : : iterator aIt ( rVector . begin ( ) ) ;
for ( sal_Int32 nN = 0 ; aIt < rVector . end ( ) ; aIt + + , nN + + )
{
if ( nN = = m_nLevel )
{
rVector . erase ( aIt ) ;
break ;
}
}
}
private :
sal_Int32 m_nLevel ;
} ;
2010-01-13 17:06:34 +01:00
vector < OUString > lcl_AnyToStringVector ( const Sequence < uno : : Any > & aAnySeq )
{
vector < OUString > aStringVec ;
transform ( aAnySeq . getConstArray ( ) , aAnySeq . getConstArray ( ) + aAnySeq . getLength ( ) ,
back_inserter ( aStringVec ) , CommonFunctors : : AnyToString ( ) ) ;
return aStringVec ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
Sequence < OUString > lcl_AnyToStringSequence ( const Sequence < uno : : Any > & aAnySeq )
{
Sequence < OUString > aResult ;
aResult . realloc ( aAnySeq . getLength ( ) ) ;
transform ( aAnySeq . getConstArray ( ) , aAnySeq . getConstArray ( ) + aAnySeq . getLength ( ) ,
aResult . getArray ( ) , CommonFunctors : : AnyToString ( ) ) ;
return aResult ;
}
} // anonymous namespace
// ================================================================================
InternalDataProvider : : InternalDataProvider ( const Reference < uno : : XComponentContext > & /*_xContext*/ )
: m_bDataInColumns ( true )
{ }
InternalDataProvider : : InternalDataProvider ( const Reference < chart2 : : XChartDocument > & xChartDoc , bool bConnectToModel )
: m_bDataInColumns ( true )
2007-05-22 17:59:49 +00:00
{
try
{
Reference < chart2 : : XDiagram > xDiagram ( ChartModelHelper : : findDiagram ( xChartDoc ) ) ;
if ( xDiagram . is ( ) )
{
2010-01-13 17:06:34 +01:00
Reference < frame : : XModel > xChartModel ( xChartDoc , uno : : UNO_QUERY ) ;
//data in columns?
{
: : rtl : : OUString aRangeString ;
bool bFirstCellAsLabel = true ;
bool bHasCategories = true ;
uno : : Sequence < sal_Int32 > aSequenceMapping ;
DataSourceHelper : : detectRangeSegmentation ( xChartModel , aRangeString , aSequenceMapping , m_bDataInColumns , bFirstCellAsLabel , bHasCategories ) ;
}
2007-05-22 17:59:49 +00:00
// categories
{
2010-01-13 17:06:34 +01:00
vector < vector < OUString > > aNewCategories ; //inner count is level
{
ExplicitCategoriesProvider aExplicitCategoriesProvider ( ChartModelHelper : : getFirstCoordinateSystem ( xChartModel ) , xChartModel ) ;
const Sequence < Reference < chart2 : : data : : XLabeledDataSequence > > & rSplitCategoriesList ( aExplicitCategoriesProvider . getSplitCategoriesList ( ) ) ;
sal_Int32 nLevelCount = rSplitCategoriesList . getLength ( ) ;
for ( sal_Int32 nL = 0 ; nL < nLevelCount ; nL + + )
{
Reference < chart2 : : data : : XLabeledDataSequence > xLDS ( rSplitCategoriesList [ nL ] ) ;
if ( ! xLDS . is ( ) )
continue ;
Reference < chart2 : : data : : XTextualDataSequence > xSeq ( xLDS - > getValues ( ) , uno : : UNO_QUERY ) ;
Sequence < OUString > aStringSeq ;
if ( xSeq . is ( ) )
aStringSeq = xSeq - > getTextualData ( ) ; // @todo: be able to deal with XDataSequence, too
sal_Int32 nLength = aStringSeq . getLength ( ) ;
2010-01-29 17:23:04 +01:00
if ( static_cast < sal_Int32 > ( aNewCategories . size ( ) ) < nLength )
2010-01-13 17:06:34 +01:00
aNewCategories . resize ( nLength ) ;
transform ( aNewCategories . begin ( ) , aNewCategories . end ( ) , aStringSeq . getConstArray ( ) ,
aNewCategories . begin ( ) , lcl_setStringAtLevel ( nL ) ) ;
}
if ( ! nLevelCount )
{
Sequence < OUString > aSimplecategories = aExplicitCategoriesProvider . getSimpleCategories ( ) ;
sal_Int32 nLength = aSimplecategories . getLength ( ) ;
aNewCategories . reserve ( nLength ) ;
for ( sal_Int32 nN = 0 ; nN < nLength ; nN + + )
{
vector < OUString > aStringVector ( 1 ) ;
aStringVector [ 0 ] = aSimplecategories [ nN ] ;
aNewCategories . push_back ( aStringVector ) ;
}
}
}
if ( m_bDataInColumns )
m_aInternalData . setComplexRowLabels ( aNewCategories ) ;
else
m_aInternalData . setComplexColumnLabels ( aNewCategories ) ;
if ( bConnectToModel )
DiagramHelper : : setCategoriesToDiagram ( new LabeledDataSequence (
createDataSequenceByRangeRepresentation ( lcl_aCategoriesRangeName ) ) , xDiagram ) ;
2007-05-22 17:59:49 +00:00
}
// data series
: : std : : vector < Reference < chart2 : : XDataSeries > > aSeriesVector ( ChartModelHelper : : getDataSeries ( xChartDoc ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aSeriesVector . begin ( ) , aSeriesVector . end ( ) , lcl_internalizeSeries ( m_aInternalData , * this , bConnectToModel , m_bDataInColumns ) ) ;
2007-05-22 17:59:49 +00:00
}
}
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 ) ,
2010-01-13 17:06:34 +01:00
m_aInternalData ( rOther . m_aInternalData ) ,
2007-05-22 17:59:49 +00:00
m_bDataInColumns ( rOther . m_bDataInColumns )
{ }
InternalDataProvider : : ~ InternalDataProvider ( )
{ }
2010-01-13 17:06:34 +01:00
void InternalDataProvider : : lcl_addDataSequenceToMap (
2007-05-22 17:59:49 +00:00
const OUString & rRangeRepresentation ,
const Reference < chart2 : : data : : XDataSequence > & xSequence )
{
m_aSequenceMap . insert (
tSequenceMap : : value_type (
rRangeRepresentation ,
uno : : WeakReference < chart2 : : data : : XDataSequence > ( xSequence ) ) ) ;
}
2010-01-13 17:06:34 +01:00
void InternalDataProvider : : lcl_deleteMapReferences ( const OUString & rRangeRepresentation )
2007-05-22 17:59:49 +00:00
{
// 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 ) ;
}
2010-01-13 17:06:34 +01:00
void InternalDataProvider : : lcl_adaptMapReferences (
2007-05-22 17:59:49 +00:00
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 ) ) ) ;
}
2010-01-13 17:06:34 +01:00
void InternalDataProvider : : lcl_increaseMapReferences (
2007-05-22 17:59:49 +00:00
sal_Int32 nBegin , sal_Int32 nEnd )
{
for ( sal_Int32 nIndex = nEnd - 1 ; nIndex > = nBegin ; - - nIndex )
{
2010-01-13 17:06:34 +01:00
lcl_adaptMapReferences ( OUString : : valueOf ( nIndex ) ,
2007-05-22 17:59:49 +00:00
OUString : : valueOf ( nIndex + 1 ) ) ;
2010-01-13 17:06:34 +01:00
lcl_adaptMapReferences ( lcl_aLabelRangePrefix + OUString : : valueOf ( nIndex ) ,
2007-05-22 17:59:49 +00:00
lcl_aLabelRangePrefix + OUString : : valueOf ( nIndex + 1 ) ) ;
}
}
2010-01-13 17:06:34 +01:00
void InternalDataProvider : : lcl_decreaseMapReferences (
2007-05-22 17:59:49 +00:00
sal_Int32 nBegin , sal_Int32 nEnd )
{
for ( sal_Int32 nIndex = nBegin ; nIndex < nEnd ; + + nIndex )
{
2010-01-13 17:06:34 +01:00
lcl_adaptMapReferences ( OUString : : valueOf ( nIndex ) ,
2007-05-22 17:59:49 +00:00
OUString : : valueOf ( nIndex - 1 ) ) ;
2010-01-13 17:06:34 +01:00
lcl_adaptMapReferences ( lcl_aLabelRangePrefix + OUString : : valueOf ( nIndex ) ,
2007-05-22 17:59:49 +00:00
lcl_aLabelRangePrefix + OUString : : valueOf ( nIndex - 1 ) ) ;
}
}
2010-01-13 17:06:34 +01:00
Reference < chart2 : : data : : XDataSequence > InternalDataProvider : : lcl_createDataSequenceAndAddToMap (
2007-05-22 17:59:49 +00:00
const OUString & rRangeRepresentation )
{
Reference < chart2 : : data : : XDataSequence > xSeq (
new UncachedDataSequence ( this , rRangeRepresentation ) ) ;
2010-01-13 17:06:34 +01:00
lcl_addDataSequenceToMap ( rRangeRepresentation , xSeq ) ;
2007-05-22 17:59:49 +00:00
return xSeq ;
}
2010-01-13 17:06:34 +01:00
Reference < chart2 : : data : : XDataSequence > InternalDataProvider : : lcl_createDataSequenceAndAddToMap (
2007-05-22 17:59:49 +00:00
const OUString & rRangeRepresentation ,
const OUString & rRole )
{
Reference < chart2 : : data : : XDataSequence > xSeq (
new UncachedDataSequence ( this , rRangeRepresentation , rRole ) ) ;
2010-01-13 17:06:34 +01:00
lcl_addDataSequenceToMap ( rRangeRepresentation , xSeq ) ;
2007-05-22 17:59:49 +00:00
return xSeq ;
}
void InternalDataProvider : : createDefaultData ( )
{
2010-01-13 17:06:34 +01:00
m_aInternalData . createDefaultData ( ) ;
2007-05-22 17:59:49 +00:00
}
// ____ 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 ;
}
2010-01-13 17:06:34 +01:00
namespace
{
sal_Int32 lcl_getInnerLevelCount ( const vector < vector < OUString > > & rLabels )
{
sal_Int32 nCount = 1 ; //minimum is 1!
vector < vector < OUString > > : : const_iterator aLevelIt ( rLabels . begin ( ) ) ;
vector < vector < OUString > > : : const_iterator aLevelEnd ( rLabels . end ( ) ) ;
for ( ; aLevelIt ! = aLevelEnd ; + + aLevelIt )
{
const vector < : : rtl : : OUString > & rCurrentLevelLabels = * aLevelIt ;
nCount = std : : max < sal_Int32 > ( rCurrentLevelLabels . size ( ) , nCount ) ;
}
return nCount ;
}
} //end anonymous namespace
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 ) ;
2010-01-13 17:06:34 +01:00
if ( aRangeRepresentation . equals ( lcl_aCategoriesRangeName ) )
{
//return split complex categories if we have any:
: : std : : vector < Reference < chart2 : : data : : XLabeledDataSequence > > aComplexCategories ;
vector < vector < OUString > > aCategories ( m_bDataInColumns ? m_aInternalData . getComplexRowLabels ( ) : m_aInternalData . getComplexColumnLabels ( ) ) ;
if ( bUseColumns = = m_bDataInColumns )
{
sal_Int32 nLevelCount = lcl_getInnerLevelCount ( aCategories ) ;
for ( sal_Int32 nL = 0 ; nL < nLevelCount ; nL + + )
aComplexCategories . push_back ( new LabeledDataSequence (
new UncachedDataSequence ( this
, lcl_aCategoriesLevelRangeNamePrefix + OUString : : valueOf ( nL )
, lcl_aCategoriesRoleName ) ) ) ;
}
else
{
sal_Int32 nPointCount = m_bDataInColumns ? m_aInternalData . getRowCount ( ) : m_aInternalData . getColumnCount ( ) ;
for ( sal_Int32 nP = 0 ; nP < nPointCount ; nP + + )
aComplexCategories . push_back ( new LabeledDataSequence (
new UncachedDataSequence ( this
, lcl_aCategoriesPointRangeNamePrefix + OUString : : valueOf ( nP )
, lcl_aCategoriesRoleName ) ) ) ;
}
//don't add the created sequences to the map as they are used temporarily only ...
return new DataSource ( ContainerHelper : : ContainerToSequence ( aComplexCategories ) ) ;
}
2007-05-22 17:59:49 +00:00
OSL_ASSERT ( aRangeRepresentation . equals ( lcl_aCompleteRange ) ) ;
: : std : : vector < Reference < chart2 : : data : : XLabeledDataSequence > > aResultLSeqVec ;
// categories
2010-01-13 17:06:34 +01:00
if ( bHasCategories )
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
aResultLSeqVec . push_back (
2010-01-13 17:06:34 +01:00
new LabeledDataSequence ( lcl_createDataSequenceAndAddToMap ( lcl_aCategoriesRangeName , lcl_aCategoriesRoleName ) ) ) ;
2007-05-22 17:59:49 +00:00
// data with labels
: : std : : vector < Reference < chart2 : : data : : XLabeledDataSequence > > aDataVec ;
2010-01-13 17:06:34 +01:00
const sal_Int32 nCount = ( bUseColumns ? m_aInternalData . getColumnCount ( ) : m_aInternalData . getRowCount ( ) ) ;
2009-12-21 10:27:32 +01:00
for ( sal_Int32 nIdx = 0 ; nIdx < nCount ; + + nIdx )
2007-05-22 17:59:49 +00:00
{
aDataVec . push_back (
new LabeledDataSequence (
2010-01-13 17:06:34 +01:00
lcl_createDataSequenceAndAddToMap ( OUString : : valueOf ( nIdx ) ) ,
lcl_createDataSequenceAndAddToMap ( lcl_aLabelRangePrefix + OUString : : valueOf ( nIdx ) ) ) ) ;
2007-05-22 17:59:49 +00:00
}
// 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 )
{
2010-01-13 17:06:34 +01:00
if ( aRangeRepresentation . match ( lcl_aCategoriesRangeName ) )
2007-07-25 07:57:46 +00:00
{
2010-01-13 17:06:34 +01:00
OSL_ASSERT ( aRangeRepresentation . equals ( lcl_aCategoriesRangeName ) ) ; //it is not expected nor implmented that only parts of the categories are really requested
2007-05-22 17:59:49 +00:00
// categories
2010-01-13 17:06:34 +01:00
return lcl_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 ( ) ;
2010-01-13 17:06:34 +01:00
return lcl_createDataSequenceAndAddToMap ( lcl_aLabelRangePrefix + OUString : : valueOf ( nIndex ) ) ;
2007-05-22 17:59:49 +00:00
}
2008-03-06 16:43:34 +00:00
else if ( aRangeRepresentation . equalsAsciiL ( RTL_CONSTASCII_STRINGPARAM ( " last " ) ) )
{
sal_Int32 nIndex = ( m_bDataInColumns
2010-01-13 17:06:34 +01:00
? m_aInternalData . getColumnCount ( )
: m_aInternalData . getRowCount ( ) ) - 1 ;
return lcl_createDataSequenceAndAddToMap ( OUString : : valueOf ( nIndex ) ) ;
2008-03-06 16:43:34 +00:00
}
else if ( aRangeRepresentation . getLength ( ) )
{
// data
sal_Int32 nIndex = aRangeRepresentation . toInt32 ( ) ;
2010-01-13 17:06:34 +01:00
return lcl_createDataSequenceAndAddToMap ( OUString : : valueOf ( nIndex ) ) ;
2008-03-06 16:43:34 +00:00
}
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 ;
2010-01-13 17:06:34 +01:00
if ( aRange . match ( lcl_aCategoriesRangeName ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
OSL_ASSERT ( aRange . equals ( lcl_aCategoriesRangeName ) ) ; //it is not expected nor implmented that only parts of the categories are really requested
2007-05-22 17:59:49 +00:00
bResult = true ;
}
else if ( aRange . match ( lcl_aLabelRangePrefix ) )
{
sal_Int32 nIndex = aRange . copy ( lcl_aLabelRangePrefix . getLength ( ) ) . toInt32 ( ) ;
2010-01-13 17:06:34 +01:00
bResult = ( nIndex < ( m_bDataInColumns ? m_aInternalData . getColumnCount ( ) : m_aInternalData . getRowCount ( ) ) ) ;
2007-05-22 17:59:49 +00:00
}
else
{
sal_Int32 nIndex = aRange . toInt32 ( ) ;
2010-01-13 17:06:34 +01:00
bResult = ( nIndex < ( m_bDataInColumns ? m_aInternalData . getColumnCount ( ) : m_aInternalData . getRowCount ( ) ) ) ;
2007-05-22 17:59:49 +00:00
}
return bResult ;
}
Sequence < uno : : Any > SAL_CALL InternalDataProvider : : getDataByRangeRepresentation ( const OUString & aRange )
throw ( uno : : RuntimeException )
{
Sequence < uno : : Any > aResult ;
2010-01-13 17:06:34 +01:00
if ( aRange . match ( lcl_aLabelRangePrefix ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
sal_Int32 nIndex = aRange . copy ( lcl_aLabelRangePrefix . getLength ( ) ) . toInt32 ( ) ;
vector < OUString > aComplexLabel = m_bDataInColumns
? m_aInternalData . getComplexColumnLabel ( nIndex )
: m_aInternalData . getComplexRowLabel ( nIndex ) ;
if ( ! aComplexLabel . empty ( ) )
{
aResult . realloc ( aComplexLabel . size ( ) ) ;
transform ( aComplexLabel . begin ( ) , aComplexLabel . end ( ) ,
aResult . getArray ( ) , CommonFunctors : : makeAny < OUString > ( ) ) ;
}
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
else if ( aRange . match ( lcl_aCategoriesPointRangeNamePrefix ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
sal_Int32 nPointIndex = aRange . copy ( lcl_aCategoriesPointRangeNamePrefix . getLength ( ) ) . toInt32 ( ) ;
vector < OUString > aComplexCategory = m_bDataInColumns
? m_aInternalData . getComplexRowLabel ( nPointIndex )
: m_aInternalData . getComplexColumnLabel ( nPointIndex ) ;
if ( ! aComplexCategory . empty ( ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
aResult . realloc ( aComplexCategory . size ( ) ) ;
transform ( aComplexCategory . begin ( ) , aComplexCategory . end ( ) ,
aResult . getArray ( ) , CommonFunctors : : makeAny < OUString > ( ) ) ;
2007-05-22 17:59:49 +00:00
}
}
2010-01-13 17:06:34 +01:00
else if ( aRange . match ( lcl_aCategoriesLevelRangeNamePrefix ) )
{
sal_Int32 nLevel = aRange . copy ( lcl_aCategoriesLevelRangeNamePrefix . getLength ( ) ) . toInt32 ( ) ;
vector < vector < OUString > > aCategories ( m_bDataInColumns ? m_aInternalData . getComplexRowLabels ( ) : m_aInternalData . getComplexColumnLabels ( ) ) ;
if ( nLevel < lcl_getInnerLevelCount ( aCategories ) )
{
aResult . realloc ( aCategories . size ( ) ) ;
transform ( aCategories . begin ( ) , aCategories . end ( ) ,
aResult . getArray ( ) , lcl_makeAnyFromLevelVector ( nLevel ) ) ;
}
}
else if ( aRange . equals ( lcl_aCategoriesRangeName ) )
{
Sequence < OUString > aLabels = m_bDataInColumns ? this - > getRowDescriptions ( ) : this - > getColumnDescriptions ( ) ;
aResult . realloc ( aLabels . getLength ( ) ) ;
transform ( aLabels . getConstArray ( ) , aLabels . getConstArray ( ) + aLabels . getLength ( ) ,
aResult . getArray ( ) , CommonFunctors : : makeAny < OUString > ( ) ) ;
}
2007-05-22 17:59:49 +00:00
else
{
sal_Int32 nIndex = aRange . toInt32 ( ) ;
2009-12-21 10:27:32 +01:00
if ( nIndex > = 0 )
2007-05-22 17:59:49 +00:00
{
2009-12-21 10:27:32 +01:00
Sequence < double > aData ;
if ( m_bDataInColumns )
2010-01-13 17:06:34 +01:00
aData = m_aInternalData . getColumnValues ( nIndex ) ;
2009-12-21 10:27:32 +01:00
else
2010-01-13 17:06:34 +01:00
aData = m_aInternalData . getRowValues ( nIndex ) ;
2009-12-21 10:27:32 +01:00
if ( aData . getLength ( ) )
{
aResult . realloc ( aData . getLength ( ) ) ;
transform ( aData . getConstArray ( ) , aData . getConstArray ( ) + aData . getLength ( ) ,
aResult . getArray ( ) , CommonFunctors : : makeAny < double > ( ) ) ;
}
2007-05-22 17:59:49 +00:00
}
}
return aResult ;
}
void SAL_CALL InternalDataProvider : : setDataByRangeRepresentation (
const OUString & aRange , const Sequence < uno : : Any > & aNewData )
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
if ( aRange . match ( lcl_aLabelRangePrefix ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
vector < OUString > aNewStrings ( lcl_AnyToStringVector ( aNewData ) ) ;
sal_uInt32 nIndex = aRange . copy ( lcl_aLabelRangePrefix . getLength ( ) ) . toInt32 ( ) ;
if ( m_bDataInColumns )
m_aInternalData . setComplexColumnLabel ( nIndex , aNewStrings ) ;
else
m_aInternalData . setComplexRowLabel ( nIndex , aNewStrings ) ;
}
else if ( aRange . match ( lcl_aCategoriesPointRangeNamePrefix ) )
{
vector < OUString > aNewStrings ( lcl_AnyToStringVector ( aNewData ) ) ;
sal_Int32 nPointIndex = aRange . copy ( lcl_aCategoriesLevelRangeNamePrefix . getLength ( ) ) . toInt32 ( ) ;
if ( m_bDataInColumns )
m_aInternalData . setComplexRowLabel ( nPointIndex , aNewStrings ) ;
else
m_aInternalData . setComplexColumnLabel ( nPointIndex , aNewStrings ) ;
}
else if ( aRange . match ( lcl_aCategoriesLevelRangeNamePrefix ) )
{
vector < OUString > aNewStrings ( lcl_AnyToStringVector ( aNewData ) ) ;
sal_Int32 nLevel = aRange . copy ( lcl_aCategoriesLevelRangeNamePrefix . getLength ( ) ) . toInt32 ( ) ;
vector < vector < OUString > > aComplexCategories = m_bDataInColumns ? m_aInternalData . getComplexRowLabels ( ) : m_aInternalData . getComplexColumnLabels ( ) ;
//ensure equal length
if ( aNewStrings . size ( ) > aComplexCategories . size ( ) )
aComplexCategories . resize ( aNewStrings . size ( ) ) ;
else if ( aNewStrings . size ( ) < aComplexCategories . size ( ) )
aNewStrings . resize ( aComplexCategories . size ( ) ) ;
transform ( aComplexCategories . begin ( ) , aComplexCategories . end ( ) , aNewStrings . begin ( ) ,
aComplexCategories . begin ( ) , lcl_setStringAtLevel ( nLevel ) ) ;
2007-05-22 17:59:49 +00:00
if ( m_bDataInColumns )
2010-01-13 17:06:34 +01:00
m_aInternalData . setComplexRowLabels ( aComplexCategories ) ;
2007-05-22 17:59:49 +00:00
else
2010-01-13 17:06:34 +01:00
m_aInternalData . setComplexColumnLabels ( aComplexCategories ) ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
else if ( aRange . equals ( lcl_aCategoriesRangeName ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
if ( m_bDataInColumns )
this - > setRowDescriptions ( lcl_AnyToStringSequence ( aNewData ) ) ;
else
this - > setColumnDescriptions ( lcl_AnyToStringSequence ( aNewData ) ) ;
2007-05-22 17:59:49 +00:00
}
else
{
sal_Int32 nIndex = aRange . toInt32 ( ) ;
2009-12-21 10:27:32 +01:00
if ( nIndex > = 0 )
2007-05-22 17:59:49 +00:00
{
vector < double > aNewDataVec ;
transform ( aNewData . getConstArray ( ) , aNewData . getConstArray ( ) + aNewData . getLength ( ) ,
back_inserter ( aNewDataVec ) , CommonFunctors : : AnyToDouble ( ) ) ;
2009-12-21 10:27:32 +01:00
if ( m_bDataInColumns )
2010-01-13 17:06:34 +01:00
m_aInternalData . setColumnValues ( nIndex , aNewDataVec ) ;
2009-12-21 10:27:32 +01:00
else
2010-01-13 17:06:34 +01:00
m_aInternalData . setRowValues ( nIndex , aNewDataVec ) ;
2007-05-22 17:59:49 +00:00
}
}
}
void SAL_CALL InternalDataProvider : : insertSequence ( : : sal_Int32 nAfterIndex )
throw ( uno : : RuntimeException )
{
if ( m_bDataInColumns )
{
2010-01-13 17:06:34 +01:00
lcl_increaseMapReferences ( nAfterIndex + 1 , m_aInternalData . getColumnCount ( ) ) ;
m_aInternalData . insertColumn ( nAfterIndex ) ;
2007-05-22 17:59:49 +00:00
}
else
{
2010-01-13 17:06:34 +01:00
lcl_increaseMapReferences ( nAfterIndex + 1 , m_aInternalData . getRowCount ( ) ) ;
m_aInternalData . insertRow ( nAfterIndex ) ;
2007-05-22 17:59:49 +00:00
}
}
void SAL_CALL InternalDataProvider : : deleteSequence ( : : sal_Int32 nAtIndex )
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
lcl_deleteMapReferences ( OUString : : valueOf ( nAtIndex ) ) ;
lcl_deleteMapReferences ( lcl_aLabelRangePrefix + OUString : : valueOf ( nAtIndex ) ) ;
2007-05-22 17:59:49 +00:00
if ( m_bDataInColumns )
{
2010-01-13 17:06:34 +01:00
lcl_decreaseMapReferences ( nAtIndex + 1 , m_aInternalData . getColumnCount ( ) ) ;
m_aInternalData . deleteColumn ( nAtIndex ) ;
2007-05-22 17:59:49 +00:00
}
else
{
2010-01-13 17:06:34 +01:00
lcl_decreaseMapReferences ( nAtIndex + 1 , m_aInternalData . getRowCount ( ) ) ;
m_aInternalData . deleteRow ( nAtIndex ) ;
2007-05-22 17:59:49 +00:00
}
}
2008-03-06 16:43:34 +00:00
void SAL_CALL InternalDataProvider : : appendSequence ( )
throw ( uno : : RuntimeException )
{
if ( m_bDataInColumns )
2010-01-13 17:06:34 +01:00
m_aInternalData . appendColumn ( ) ;
2008-03-06 16:43:34 +00:00
else
2010-01-13 17:06:34 +01:00
m_aInternalData . appendRow ( ) ;
2008-03-06 16:43:34 +00:00
}
2010-01-28 10:52:28 +01:00
void SAL_CALL InternalDataProvider : : insertComplexCategoryLevel ( sal_Int32 nLevel )
throw ( uno : : RuntimeException )
{
OSL_ENSURE ( nLevel > 0 , " you can only insert category levels > 0 " ) ; //the first categories level cannot be deleted, check the calling code for error
if ( nLevel > 0 )
{
vector < vector < OUString > > aComplexCategories = m_bDataInColumns ? m_aInternalData . getComplexRowLabels ( ) : m_aInternalData . getComplexColumnLabels ( ) ;
: : std : : for_each ( aComplexCategories . begin ( ) , aComplexCategories . end ( ) , lcl_insertStringAtLevel ( nLevel ) ) ;
if ( m_bDataInColumns )
m_aInternalData . setComplexRowLabels ( aComplexCategories ) ;
else
m_aInternalData . setComplexColumnLabels ( aComplexCategories ) ;
tSequenceMapRange aRange ( m_aSequenceMap . equal_range ( lcl_aCategoriesRangeName ) ) ;
: : std : : for_each ( aRange . first , aRange . second , lcl_setModified ( ) ) ;
}
}
void SAL_CALL InternalDataProvider : : deleteComplexCategoryLevel ( sal_Int32 nLevel )
throw ( uno : : RuntimeException )
{
OSL_ENSURE ( nLevel > 0 , " you can only delete category levels > 0 " ) ; //the first categories level cannot be deleted, check the calling code for error
if ( nLevel > 0 )
{
vector < vector < OUString > > aComplexCategories = m_bDataInColumns ? m_aInternalData . getComplexRowLabels ( ) : m_aInternalData . getComplexColumnLabels ( ) ;
: : std : : for_each ( aComplexCategories . begin ( ) , aComplexCategories . end ( ) , lcl_removeStringAtLevel ( nLevel ) ) ;
if ( m_bDataInColumns )
m_aInternalData . setComplexRowLabels ( aComplexCategories ) ;
else
m_aInternalData . setComplexColumnLabels ( aComplexCategories ) ;
tSequenceMapRange aRange ( m_aSequenceMap . equal_range ( lcl_aCategoriesRangeName ) ) ;
: : std : : for_each ( aRange . first , aRange . second , lcl_setModified ( ) ) ;
}
}
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 )
{
2010-01-13 17:06:34 +01:00
m_aInternalData . insertRow ( nAfterIndex ) ;
nMaxRep = m_aInternalData . getColumnCount ( ) ;
2007-05-22 17:59:49 +00:00
}
else
{
2010-01-13 17:06:34 +01:00
m_aInternalData . insertColumn ( nAfterIndex ) ;
nMaxRep = m_aInternalData . getRowCount ( ) ;
2007-05-22 17:59:49 +00:00
}
// 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 ) ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aBegin , aEnd , lcl_setModified ( ) ) ;
2007-05-22 17:59:49 +00:00
tSequenceMapRange aRange ( m_aSequenceMap . equal_range ( lcl_aCategoriesRangeName ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aRange . first , aRange . second , lcl_setModified ( ) ) ;
2007-05-22 17:59:49 +00:00
}
void SAL_CALL InternalDataProvider : : deleteDataPointForAllSequences ( : : sal_Int32 nAtIndex )
throw ( uno : : RuntimeException )
{
sal_Int32 nMaxRep = 0 ;
if ( m_bDataInColumns )
{
2010-01-13 17:06:34 +01:00
m_aInternalData . deleteRow ( nAtIndex ) ;
nMaxRep = m_aInternalData . getColumnCount ( ) ;
2007-05-22 17:59:49 +00:00
}
else
{
2010-01-13 17:06:34 +01:00
m_aInternalData . deleteColumn ( nAtIndex ) ;
nMaxRep = m_aInternalData . getRowCount ( ) ;
2007-05-22 17:59:49 +00:00
}
// 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 ) ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aBegin , aEnd , lcl_setModified ( ) ) ;
2007-05-22 17:59:49 +00:00
tSequenceMapRange aRange ( m_aSequenceMap . equal_range ( lcl_aCategoriesRangeName ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aRange . first , aRange . second , lcl_setModified ( ) ) ;
2007-05-22 17:59:49 +00:00
}
void SAL_CALL InternalDataProvider : : swapDataPointWithNextOneForAllSequences ( : : sal_Int32 nAtIndex )
throw ( uno : : RuntimeException )
{
2009-12-21 10:27:32 +01:00
if ( m_bDataInColumns )
2010-01-13 17:06:34 +01:00
m_aInternalData . swapRowWithNext ( nAtIndex ) ;
2009-12-21 10:27:32 +01:00
else
2010-01-13 17:06:34 +01:00
m_aInternalData . swapColumnWithNext ( nAtIndex ) ;
2007-05-22 17:59:49 +00:00
sal_Int32 nMaxRep = ( m_bDataInColumns
2010-01-13 17:06:34 +01:00
? m_aInternalData . getColumnCount ( )
: m_aInternalData . getRowCount ( ) ) ;
2007-05-22 17:59:49 +00:00
// 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 ) ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aBegin , aEnd , lcl_setModified ( ) ) ;
2007-05-22 17:59:49 +00:00
tSequenceMapRange aRange ( m_aSequenceMap . equal_range ( lcl_aCategoriesRangeName ) ) ;
2010-01-13 17:06:34 +01:00
: : std : : for_each ( aRange . first , aRange . second , lcl_setModified ( ) ) ;
2007-05-22 17:59:49 +00:00
}
void SAL_CALL InternalDataProvider : : registerDataSequenceForChanges ( const Reference < chart2 : : data : : XDataSequence > & xSeq )
throw ( uno : : RuntimeException )
{
if ( xSeq . is ( ) )
2010-01-13 17:06:34 +01:00
lcl_addDataSequenceToMap ( xSeq - > getSourceRangeRepresentation ( ) , xSeq ) ;
2007-05-22 17:59:49 +00:00
}
// ____ 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 " ) ) ;
// 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
2010-01-13 17:06:34 +01:00
if ( aRangeRepresentation . match ( lcl_aCategoriesRangeName ) )
2007-05-22 17:59:49 +00:00
{
2010-01-13 17:06:34 +01:00
OSL_ASSERT ( aRangeRepresentation . equals ( lcl_aCategoriesRangeName ) ) ; //it is not expected nor implmented that only parts of the categories are really requested
2007-05-22 17:59:49 +00:00
aRange . aUpperLeft . bIsEmpty = false ;
if ( m_bDataInColumns )
{
aRange . aUpperLeft . nColumn = 0 ;
aRange . aUpperLeft . nRow = 1 ;
aRange . aLowerRight = aRange . aUpperLeft ;
2010-01-13 17:06:34 +01:00
aRange . aLowerRight . nRow = m_aInternalData . getRowCount ( ) ;
2007-05-22 17:59:49 +00:00
}
else
{
aRange . aUpperLeft . nColumn = 1 ;
aRange . aUpperLeft . nRow = 0 ;
aRange . aLowerRight = aRange . aUpperLeft ;
2010-01-13 17:06:34 +01:00
aRange . aLowerRight . nColumn = m_aInternalData . getColumnCount ( ) ;
2007-05-22 17:59:49 +00:00
}
}
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 ;
2010-01-13 17:06:34 +01:00
aRange . aLowerRight . nColumn = m_aInternalData . getColumnCount ( ) ;
aRange . aLowerRight . nRow = m_aInternalData . getRowCount ( ) ;
2007-05-22 17:59:49 +00:00
}
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 ;
2010-01-13 17:06:34 +01:00
aRange . aLowerRight . nRow = m_aInternalData . getRowCount ( ) ;
2007-05-22 17:59:49 +00:00
}
else
{
aRange . aUpperLeft . nColumn = 1 ;
aRange . aUpperLeft . nRow = nIndex + 1 ;
aRange . aLowerRight = aRange . aUpperLeft ;
2010-01-13 17:06:34 +01:00
aRange . aLowerRight . nColumn = m_aInternalData . getColumnCount ( ) ;
2007-05-22 17:59:49 +00:00
}
}
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 ) ;
}
2010-01-13 17:06:34 +01:00
namespace
{
Sequence < Sequence < OUString > > lcl_convertComplexVectorToSequence ( const vector < vector < OUString > > & rIn )
{
Sequence < Sequence < OUString > > aRet ;
sal_Int32 nOuterCount = rIn . size ( ) ;
if ( nOuterCount )
{
aRet . realloc ( nOuterCount ) ;
for ( sal_Int32 nN = 0 ; nN < nOuterCount ; nN + + )
aRet [ nN ] = ContainerHelper : : ContainerToSequence ( rIn [ nN ] ) ;
}
return aRet ;
}
vector < vector < OUString > > lcl_convertComplexSequenceToVector ( const Sequence < Sequence < OUString > > & rIn )
{
vector < vector < OUString > > aRet ;
sal_Int32 nOuterCount = rIn . getLength ( ) ;
for ( sal_Int32 nN = 0 ; nN < nOuterCount ; nN + + )
aRet . push_back ( ContainerHelper : : SequenceToVector ( rIn [ nN ] ) ) ;
return aRet ;
}
class SplitCategoriesProvider_ForComplexDescriptions : public SplitCategoriesProvider
{
public :
explicit SplitCategoriesProvider_ForComplexDescriptions ( const : : std : : vector < : : std : : vector < : : rtl : : OUString > > & rComplexDescriptions )
: m_rComplexDescriptions ( rComplexDescriptions )
{ }
virtual ~ SplitCategoriesProvider_ForComplexDescriptions ( )
{ }
virtual sal_Int32 getLevelCount ( ) const ;
virtual uno : : Sequence < rtl : : OUString > getStringsForLevel ( sal_Int32 nIndex ) const ;
private :
const : : std : : vector < : : std : : vector < : : rtl : : OUString > > & m_rComplexDescriptions ;
} ;
sal_Int32 SplitCategoriesProvider_ForComplexDescriptions : : getLevelCount ( ) const
{
return lcl_getInnerLevelCount ( m_rComplexDescriptions ) ;
}
uno : : Sequence < rtl : : OUString > SplitCategoriesProvider_ForComplexDescriptions : : getStringsForLevel ( sal_Int32 nLevel ) const
{
uno : : Sequence < rtl : : OUString > aResult ;
if ( nLevel < lcl_getInnerLevelCount ( m_rComplexDescriptions ) )
{
aResult . realloc ( m_rComplexDescriptions . size ( ) ) ;
transform ( m_rComplexDescriptions . begin ( ) , m_rComplexDescriptions . end ( ) ,
aResult . getArray ( ) , lcl_getStringFromLevelVector ( nLevel ) ) ;
}
return aResult ;
}
} //anonymous namespace
// ____ XComplexDescriptionAccess ____
Sequence < Sequence < OUString > > SAL_CALL InternalDataProvider : : getComplexRowDescriptions ( ) throw ( uno : : RuntimeException )
{
return lcl_convertComplexVectorToSequence ( m_aInternalData . getComplexRowLabels ( ) ) ;
}
void SAL_CALL InternalDataProvider : : setComplexRowDescriptions ( const Sequence < Sequence < : : rtl : : OUString > > & aRowDescriptions ) throw ( uno : : RuntimeException )
{
m_aInternalData . setComplexRowLabels ( lcl_convertComplexSequenceToVector ( aRowDescriptions ) ) ;
}
Sequence < Sequence < : : rtl : : OUString > > SAL_CALL InternalDataProvider : : getComplexColumnDescriptions ( ) throw ( uno : : RuntimeException )
{
return lcl_convertComplexVectorToSequence ( m_aInternalData . getComplexColumnLabels ( ) ) ;
}
void SAL_CALL InternalDataProvider : : setComplexColumnDescriptions ( const Sequence < Sequence < : : rtl : : OUString > > & aColumnDescriptions ) throw ( uno : : RuntimeException )
{
m_aInternalData . setComplexColumnLabels ( lcl_convertComplexSequenceToVector ( aColumnDescriptions ) ) ;
}
2007-05-22 17:59:49 +00:00
// ____ XChartDataArray ____
Sequence < Sequence < double > > SAL_CALL InternalDataProvider : : getData ( )
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
return m_aInternalData . getData ( ) ;
2007-05-22 17:59:49 +00:00
}
2009-12-21 10:27:32 +01:00
void SAL_CALL InternalDataProvider : : setData ( const Sequence < Sequence < double > > & rDataInRows )
2007-05-22 17:59:49 +00:00
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
return m_aInternalData . setData ( rDataInRows ) ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
void SAL_CALL InternalDataProvider : : setRowDescriptions ( const Sequence < OUString > & aRowDescriptions )
2007-05-22 17:59:49 +00:00
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
vector < vector < OUString > > aComplexDescriptions ( aRowDescriptions . getLength ( ) ) ;
transform ( aComplexDescriptions . begin ( ) , aComplexDescriptions . end ( ) , aRowDescriptions . getConstArray ( ) ,
aComplexDescriptions . begin ( ) , lcl_setStringAtLevel ( 0 ) ) ;
m_aInternalData . setComplexRowLabels ( aComplexDescriptions ) ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
void SAL_CALL InternalDataProvider : : setColumnDescriptions ( const Sequence < OUString > & aColumnDescriptions )
2007-05-22 17:59:49 +00:00
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
vector < vector < OUString > > aComplexDescriptions ( aColumnDescriptions . getLength ( ) ) ;
transform ( aComplexDescriptions . begin ( ) , aComplexDescriptions . end ( ) , aColumnDescriptions . getConstArray ( ) ,
aComplexDescriptions . begin ( ) , lcl_setStringAtLevel ( 0 ) ) ;
m_aInternalData . setComplexColumnLabels ( aComplexDescriptions ) ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
Sequence < OUString > SAL_CALL InternalDataProvider : : getRowDescriptions ( )
2007-05-22 17:59:49 +00:00
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
vector < vector < OUString > > aComplexLabels ( m_aInternalData . getComplexRowLabels ( ) ) ;
SplitCategoriesProvider_ForComplexDescriptions aProvider ( aComplexLabels ) ;
return ExplicitCategoriesProvider : : getExplicitSimpleCategories ( aProvider ) ;
2007-05-22 17:59:49 +00:00
}
2010-01-13 17:06:34 +01:00
Sequence < OUString > SAL_CALL InternalDataProvider : : getColumnDescriptions ( )
2007-05-22 17:59:49 +00:00
throw ( uno : : RuntimeException )
{
2010-01-13 17:06:34 +01:00
vector < vector < OUString > > aComplexLabels ( m_aInternalData . getComplexColumnLabels ( ) ) ;
SplitCategoriesProvider_ForComplexDescriptions aProvider ( aComplexLabels ) ;
return ExplicitCategoriesProvider : : getExplicitSimpleCategories ( aProvider ) ;
2007-05-22 17:59:49 +00:00
}
// ____ 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