From 0c3580828811496052f41b09ad68fcc00a525f6f Mon Sep 17 00:00:00 2001 From: Mike Kaganski Date: Sun, 3 Mar 2024 16:12:55 +0600 Subject: [PATCH] tdf#153706: do not add categories, when source data doesn't have them lcl_AllOperator is used in XChartDocument::attachData implementation. When a data without existing categories is passed there, like an XY scatter, lcl_AllOperator used to force creation of the categories in the target, by returning 'true' unconditionally from setsCategories. This meant, that a new sequence of numbers starting from 1 was used as X values, and the old X data was interpreted as an extra Y series. This changes lcl_AllOperator::setsCategories to try to check if its data actually contains categories. Thus, XChartDocument::attachData will use categories either when the chart already uses categories, and ChartDataWrapper::applyData detects that using a call to DataSourceHelper::detectRangeSegmentation; or when the new data has it; but not when neither had it. When it's not possible to detect if there were categories in the new data (e.g., with user data), old behavior is used, setting categories. It could be an alternative to detect the chart type using xOldDoc->getDiagram()->getDiagramType() == "com.sun.star.chart.XYDiagram" in XChartDocument::attachData; and then decide to force the creation or not. But it seems hackish, and not really universal: other chart types must be tested (bubble?), no idea how to handle hypothetical cases when applied data contains categories in case of XY chart, etc. Change-Id: I86b34f6799c30b103f7fc6b2faf6ec255a9d137b Reviewed-on: https://gerrit.libreoffice.org/c/core/+/164298 Tested-by: Jenkins Reviewed-by: Mike Kaganski --- .../data/ods/tdf153706_XY_scatter_chart.ods | Bin 0 -> 16152 bytes chart2/qa/extras/uichart.cxx | 54 ++++++++++++++++++ .../chartapiwrapper/ChartDataWrapper.cxx | 10 ++++ .../chartapiwrapper/ChartDataWrapper.hxx | 11 +++- 4 files changed, 74 insertions(+), 1 deletion(-) create mode 100644 chart2/qa/extras/data/ods/tdf153706_XY_scatter_chart.ods diff --git a/chart2/qa/extras/data/ods/tdf153706_XY_scatter_chart.ods b/chart2/qa/extras/data/ods/tdf153706_XY_scatter_chart.ods new file mode 100644 index 0000000000000000000000000000000000000000..2c6153ed6ab2e3552717199b320766d8b55a0f03 GIT binary patch literal 16152 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 ZanyzZ-mGjOWugqC3getDataProvider().queryThrow()); + + css::uno::Sequence> aData = xDataArray->getData(); + CPPUNIT_ASSERT_EQUAL(sal_Int32(3), aData.getLength()); + CPPUNIT_ASSERT_EQUAL(sal_Int32(2), aData[0].getLength()); + CPPUNIT_ASSERT_EQUAL(sal_Int32(2), aData[1].getLength()); + CPPUNIT_ASSERT_EQUAL(sal_Int32(2), aData[2].getLength()); + CPPUNIT_ASSERT_EQUAL(2.0, aData[0][0]); + CPPUNIT_ASSERT_EQUAL(3.0, aData[0][1]); + CPPUNIT_ASSERT_EQUAL(3.0, aData[1][0]); + CPPUNIT_ASSERT_EQUAL(2.0, aData[1][1]); + CPPUNIT_ASSERT_EQUAL(4.0, aData[2][0]); + CPPUNIT_ASSERT_EQUAL(1.0, aData[2][1]); + + // Without the fix, this would fail with + // - Expected: 1 + // - Actual : 2 + // i.e., the X values were treated as another Y series + CPPUNIT_ASSERT_EQUAL(sal_Int32(1), getNumberOfDataSeries(xChartDoc)); + + auto xSeries(getDataSeriesFromDoc(xChartDoc, 0).queryThrow()); + auto sequences = xSeries->getDataSequences(); + // Without the fix, this would fail with + // - Expected: 2 + // - Actual : 1 + CPPUNIT_ASSERT_EQUAL(sal_Int32(2), sequences.getLength()); + + auto propX(sequences[0]->getValues().queryThrow()); + // Without the fix, this would fail with + // - Expected: values-x + // - Actual : values-y + CPPUNIT_ASSERT_EQUAL(u"values-x"_ustr, propX->getPropertyValue("Role").get()); + + auto propY(sequences[1]->getValues().queryThrow()); + CPPUNIT_ASSERT_EQUAL(u"values-y"_ustr, propY->getPropertyValue("Role").get()); +} + CPPUNIT_PLUGIN_IMPLEMENT(); /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/chart2/source/controller/chartapiwrapper/ChartDataWrapper.cxx b/chart2/source/controller/chartapiwrapper/ChartDataWrapper.cxx index 84b98f0d8018..7988ef90df94 100644 --- a/chart2/source/controller/chartapiwrapper/ChartDataWrapper.cxx +++ b/chart2/source/controller/chartapiwrapper/ChartDataWrapper.cxx @@ -121,6 +121,11 @@ struct lcl_AllOperator : public lcl_Operator virtual bool setsCategories( bool /*bDataInColumns*/ ) override { + // Do not force creation of categories, when original has no categories + if (auto pDataWrapper = dynamic_cast(m_xDataToApply.get())) + if (auto xChartModel = pDataWrapper->getChartModel()) + if (auto xDiagram = xChartModel->getFirstChartDiagram()) + return xDiagram->getCategories().is(); return true; } @@ -698,6 +703,11 @@ css::uno::Sequence< OUString > SAL_CALL ChartDataWrapper::getSupportedServiceNam }; } +rtl::Reference ChartDataWrapper::getChartModel() const +{ + return m_spChart2ModelContact->getDocumentModel(); +} + } // namespace chart /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/chart2/source/controller/chartapiwrapper/ChartDataWrapper.hxx b/chart2/source/controller/chartapiwrapper/ChartDataWrapper.hxx index 3c6602d4e028..9a44e53b8b12 100644 --- a/chart2/source/controller/chartapiwrapper/ChartDataWrapper.hxx +++ b/chart2/source/controller/chartapiwrapper/ChartDataWrapper.hxx @@ -20,6 +20,8 @@ #include #include +#include + #include #include #include @@ -28,7 +30,11 @@ #include -namespace chart::wrapper +namespace chart +{ +class ChartModel; + +namespace wrapper { class Chart2ModelContact; @@ -53,6 +59,8 @@ public: virtual sal_Bool SAL_CALL supportsService( const OUString& ServiceName ) override; virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() override; + rtl::Reference getChartModel() const; + private: // ____ XDateCategories ____ virtual css::uno::Sequence< double > SAL_CALL getDateCategories() override; @@ -113,5 +121,6 @@ private: }; } // namespace chart::wrapper +} // namespace chart /* vim:set shiftwidth=4 softtabstop=4 expandtab: */