[Libreoffice-commits] core.git: sc/qa sc/source

Juergen Funk juergen.funk_ml at cib.de
Thu Mar 31 12:54:16 UTC 2016


 sc/qa/unit/data/README.cellborders          |   93 ++++++++++++++++++++++++
 sc/qa/unit/data/ods/test_borders_export.ods |binary
 sc/qa/unit/subsequent_export-test.cxx       |   90 +++++++++++++++++++++++
 sc/source/filter/excel/xestyle.cxx          |  107 ++++++++++++++++------------
 sc/source/filter/oox/stylesbuffer.cxx       |    6 +
 5 files changed, 250 insertions(+), 46 deletions(-)

New commits:
commit 51737960911d41593ffd9792a6a85aeaa86824fd
Author: Juergen Funk <juergen.funk_ml at cib.de>
Date:   Wed Feb 24 13:13:23 2016 +0100

    tdf#79787 Normal cell borders are showing dashed/dotted reopen in MSO
    
    New Mapping from LO to MS, decription in
      sc/qa/unit/data/README.cellborders
    
    Add a Unit-Test for testing the mapping
    
    Change-Id: I5324bf85b6299dbc63ce3c8ef479f19b0b1b3f1f
    Reviewed-on: https://gerrit.libreoffice.org/22665
    Reviewed-by: Katarina Behrens <Katarina.Behrens at cib.de>
    Tested-by: Katarina Behrens <Katarina.Behrens at cib.de>

diff --git a/sc/qa/unit/data/README.cellborders b/sc/qa/unit/data/README.cellborders
new file mode 100644
index 0000000..00db85a
--- /dev/null
+++ b/sc/qa/unit/data/README.cellborders
@@ -0,0 +1,93 @@
+
+Differences in borders between Excel and LibreOffice Calc.
+
+The sources for this Document is:
+ - sc/qa/unit/data/ods/test_borders_export.ods  (new Test-Document)
+ - sc/qa/unit/subsequent_export-test.cxx        (ScExportTest::testBordersExchangeXLSX)
+
+ - sc/source/filter/excel/xestyle.cxx           (void lclGetBorderLine)
+ - sc/source/filter/oox/stylesbuffer.cxx        (Border::convertBorderLine)
+
+ Bug-Ticket: tdf#79787
+
+
+In LibreOffice the lines are defined by two information: the style and the width of the line. There are seven different line styles available. And the following line width can be selected: 0.05 pt, 0.25 pt, 0.50 pt, 0.75 pt, 1.0 pt, 1.25 pt, 1.50 pt, … until 9pt.
+In Excel you can only define the style of the line. There are 13 different styles available. The width cannot be entered explicitly, instead you have different styles for a solid line with different width (s. Screenshots below).
+The question is now: how to map the borderlines of LibreOffice to Excel and vice versa.
+In the overview below you can see the mapping as it is and some suggestions how to improve it. As the borders are defined different, it will not be possible to define a 1:1 mapping."
+
+The current mapping is mainly defined of the width, but i think better is the line-style, i think user see that first
+
+Base for the evaluation is LibreOffice master (commit  [bbfeab3b13b48c99cfa2f94c8c34bc3efef7faa9] ) and Excel 2013
+
+                           EXCEL                                      ||                         LIBREOFFICE
+Excel-Line Name                                      Value            ||        LO-Line  Name                                      Value
+  Keine    EXC_LINE_NONE                               0              ||          none   table::BorderLineStyle::NONE              32767 (-1)
+    1      EXC_LINE_HAIR                               7              ||           1     table::BorderLineStyle::SOLID                 0
+    2      EXC_LINE_DOTTED                             4              ||           2     table::BorderLineStyle::DOTTED                1
+    3      EXC_LINE_THIN_DASHDOTDOT                    11             ||           3     table::BorderLineStyle::DASHED                2
+    4      EXC_LINE_THIN_DASHDOT                       9              ||           4     table::BorderLineStyle::FINE_DASHED           14
+    5      EXC_LINE_DASHED                             3              ||           5     table::BorderLineStyle::DASH_DOT              16
+    6      EXC_LINE_THIN                               1              ||           6     table::BorderLineStyle::DASH_DOT_DOT          17
+    7      EXC_LINE_MEDIUM_DASHDOTDOT                  12             ||           7     table::BorderLineStyle::DOUBLE_THIN           15
+    8      EXC_LINE_MEDIUM_SLANT_DASHDOT               13             ||
+    9      EXC_LINE_MEDIUM_DASHDOT                     10             ||
+    10     EXC_LINE_MEDIUM_DASHED                      8              ||
+    11     EXC_LINE_MEDIUM                             2              ||
+    12     EXC_LINE_THICK                              5              ||
+    13     EXC_LINE_DOUBLE                             6              ||
+
+In the following cases a 1:1 mapping is not possible.
+
+    Excel -> LibreOffice: Create in Excel and open it in LibreOffice. ||    LibreOffice -> Excel: Create Sheet in LibreOffice and save as XLSX.
+Create in|      In Excel save as XLSX,         | In Excel save as ODS,||  Created in     |        Load saved xlsx-file         | Load saved xlsx-file
+Excel2013|       Load in LibreOffice           |  Load in LibreOffice ||LibreOffice with |          in LibreOffice             |      in Excel
+_______________________________________________________________________________________________________________________________________________________
+   Line  |current transformation|new suggestion|current transformation||Line      Width  |current transformation|new suggestion|current|new suggestion
+         |   Line      Width    | Line   Width |   Line      Width    ||                 |   Line      Width    | Line   Width |  Line |    Line
+    13   |    7         2,50    |  7      1,75 |    1         0,05    || 2     0,05 - 0,5|    1         0,05    |  2      0,75 |   6   |     2
+                                                                      || 2     1,75 - 2,2|    1         1,75    |  4      1,75 |   6   |     8
+                                                                      || 2     2,50 - 9,0|    1         2,50    |  4      1,75 |   6   |     8
+                                                                      || 3     0,05 - 0,5|    1         0,05    |  2      0,75 |   6   |     2
+                                                                      || 3     0,75 - 1,5|    4         0,75    |  4      0,75 |   5   |     5
+                                                                      || 3     2,50 - 9,0|    1         2,50    |  3      1,75 |   6   |     10
+                                                                      || 4     0,05 - 0,5|    1         0,05    |  4      0,75 |   6   |     5
+                                                                      || 4     2,50 - 9,0|    1         2,50    |  4      1,75 |   6   |     8
+                                                                      || 5     0,05 - 0,5|    1         0,05    |  4      0,75 |   6   |     5
+                                                                      || 5     2,50 - 9,0|    1         2,50    |  5      1,75 |   6   |     9
+                                                                      || 6     0,05 - 0,5|    1         0,05    |  4      0,75 |   6   |     5
+                                                                      || 6     2,50 - 9,0|    1         2,50    |  6      1,75 |   6   |     7
+                                                                      || 7     0,05 - 9,0|    7         2,50    |  7      1,75 |   13  |     13
+
+
+No similar border available => choose one that is not used similar one and make the roundtrip via xlsx-file possible (create in LO, save as xlsx, open in LO and
+border is not changed)
+
+    Excel -> LibreOffice: Create in Excel and open it in LibreOffice. ||    LibreOffice -> Excel: Create Sheet in LibreOffice and save as XLSX.
+Create in|      In Excel save as XLSX,         | In Excel save as ODS,||  Created in     |        Load saved xlsx-file         | Load saved xlsx-file
+Excel2013|       Load in LibreOffice           |  Load in LibreOffice ||LibreOffice with |          in LibreOffice             |      in Excel
+_______________________________________________________________________________________________________________________________________________________
+   Line  |current transformation|new suggestion|current transformation||Line      Width  |current transformation|new suggestion|current|new suggestion
+         |   Line      Width    | Line   Width |   Line      Width    ||                 |   Line      Width    | Line   Width |  Line |    Line
+    8    |    5        1,75     |  4      1,75 |    1         0,05    || 4     1,75 - 2,2|    1         1,75    |  4      1,75 |   6   |     8
+
+
+In the following cases the mapping is o.k. and should not be changed.
+
+    Excel -> LibreOffice: Create in Excel and open it in LibreOffice. ||    LibreOffice -> Excel: Create Sheet in LibreOffice and save as XLSX.
+Create in|      In Excel save as XLSX,         | In Excel save as ODS,||  Created in     |        Load saved xlsx-file         | Load saved xlsx-file
+Excel2013|       Load in LibreOffice           |  Load in LibreOffice ||LibreOffice with |          in LibreOffice             |      in Excel
+_______________________________________________________________________________________________________________________________________________________
+   Line  |current transformation|new suggestion|current transformation||Line      Width  |current transformation               |current
+         |   Line      Width    | Line   Width |   Line      Width    ||                 |   Line      Width                   |  Line
+    1    |    1        0,05     |  1      0,05 |    1         0,05    || 1     0,05 - 0,5|    1        0,05                    |   1
+    2    |    2        0,75     |  2      0,75 |    1         0,05    || 1     0,75 - 1,5|    1        0,75                    |   6
+    3    |    6        0,75     |  6      0,75 |    1         0,05    || 1     1,75 - 2,2|    1        1,75                    |   11
+    4    |    5        0,75     |  5      0,75 |    1         0,05    || 1     2,50 - 9,0|    1        2,50                    |   12
+    5    |    4        0,75     |  4      0,75 |    1         0,05    || 2     0,75 - 1,5|    2        0,75                    |   2
+    6    |    1        0,75     |  1      0,75 |    1         0,05    || 3     1,75 - 2,2|    3        1,75                    |   10
+    7    |    6        1,75     |  6      1,75 |    1         0,05    || 4     0,75 - 1,5|    4        0,75                    |   5
+    9    |    5        1,75     |  5      1,75 |    1         0,05    || 5     0,75 - 1,5|    5        0,75                    |   4
+    10   |    3        1,75     |  3      1,75 |    3         2,00    || 5     1,75 - 2,2|    5        1,75                    |   9
+    11   |    1        1,75     |  1      1,75 |    1         2,00    || 6     0,75 - 1,5|    6        0,75                    |   3
+    12   |    1        2,50     |  1      2,50 |    1         2,50    || 6     1,75 - 2,2|    6        1,75                    |   7
diff --git a/sc/qa/unit/data/ods/test_borders_export.ods b/sc/qa/unit/data/ods/test_borders_export.ods
new file mode 100644
index 0000000..394ec4e
Binary files /dev/null and b/sc/qa/unit/data/ods/test_borders_export.ods differ
diff --git a/sc/qa/unit/subsequent_export-test.cxx b/sc/qa/unit/subsequent_export-test.cxx
index caeb15d..cf75d87 100644
--- a/sc/qa/unit/subsequent_export-test.cxx
+++ b/sc/qa/unit/subsequent_export-test.cxx
@@ -116,6 +116,7 @@ public:
 
     void testCellBordersXLS();
     void testCellBordersXLSX();
+    void testBordersExchangeXLSX();
     void testTrackChangesSimpleXLSX();
     void testSheetTabColorsXLSX();
 
@@ -190,6 +191,7 @@ public:
     CPPUNIT_TEST(testSheetProtectionXLSX);
     CPPUNIT_TEST(testCellBordersXLS);
     CPPUNIT_TEST(testCellBordersXLSX);
+    CPPUNIT_TEST(testBordersExchangeXLSX);
     CPPUNIT_TEST(testTrackChangesSimpleXLSX);
     CPPUNIT_TEST(testSheetTabColorsXLSX);
     CPPUNIT_TEST(testSharedFormulaExportXLS);
@@ -1529,6 +1531,94 @@ void ScExportTest::testCellBordersXLSX()
     testExcelCellBorders(FORMAT_XLSX);
 }
 
+void ScExportTest::testBordersExchangeXLSX()
+{
+    // Document: sc/qa/unit/data/README.cellborders
+
+    // short name for the table
+    const ::editeng::SvxBorderStyle None     = table::BorderLineStyle::NONE;
+    const ::editeng::SvxBorderStyle Solid    = table::BorderLineStyle::SOLID;
+    const ::editeng::SvxBorderStyle Dotted   = table::BorderLineStyle::DOTTED;
+    const ::editeng::SvxBorderStyle Dashed   = table::BorderLineStyle::DASHED;
+    const ::editeng::SvxBorderStyle FineDash = table::BorderLineStyle::FINE_DASHED;
+    const ::editeng::SvxBorderStyle DashDot  = table::BorderLineStyle::DASH_DOT;
+    const ::editeng::SvxBorderStyle DashDoDo = table::BorderLineStyle::DASH_DOT_DOT;
+    const ::editeng::SvxBorderStyle DoubThin = table::BorderLineStyle::DOUBLE_THIN;
+
+    const size_t nMaxCol = 18;
+    const size_t nMaxRow = 7;
+
+    static struct
+    {
+        ::editeng::SvxBorderStyle BorderStyleTop, BorderStyleBottom;
+        long                      WidthTop, WidthBottom;
+    } aCheckBorderWidth[nMaxCol][nMaxRow] =
+    {
+/*  Line               1                                2                              3                            4                             5                                6                              7
+                     SOLID                           DOTTED                          DASHED                     FINE_DASHED                    DASH_DOT                      DASH_DOT_DOT                  DOUBLE_THIN          */
+/*Width */
+/* 0,05 */   {{Solid   , Solid   ,  1,  1}, {Dotted  , Dotted  , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {None    , None    ,  0,  0}},
+/* 0,25 */   {{Solid   , Solid   ,  1,  1}, {Dotted  , Dotted  , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {None    , None    ,  0,  0}},
+/* 0,50 */   {{Solid   , Solid   ,  1,  1}, {Dotted  , Dotted  , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {None    , None    ,  0,  0}},
+/* 0,75 */   {{Solid   , Solid   , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {DashDot , DashDot , 15, 15}, {DashDoDo, DashDoDo, 15, 15}, {None    , None    ,  0,  0}},
+/* 1,00 */   {{Solid   , Solid   , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {DashDot , DashDot , 15, 15}, {DashDoDo, DashDoDo, 15, 15}, {None    , None    ,  0,  0}},
+/* 1,25 */   {{Solid   , Solid   , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {DashDot , DashDot , 15, 15}, {DashDoDo, DashDoDo, 15, 15}, {DoubThin, DoubThin, 35, 35}},
+/* 1,50 */   {{Solid   , Solid   , 15, 15}, {Dotted  , Dotted  , 15, 15}, {FineDash, FineDash, 15, 15}, {FineDash, FineDash, 15, 15}, {DashDot , DashDot , 15, 15}, {DashDoDo, DashDoDo, 15, 15}, {DoubThin, DoubThin, 35, 35}},
+
+/* 1,75 */   {{Solid   , Solid   , 35, 35}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 2,00 */   {{Solid   , Solid   , 35, 35}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 2,25 */   {{Solid   , Solid   , 35, 35}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+
+/* 2,50 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 2,75 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 3,00 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 3,50 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 4,00 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 5,00 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 7,00 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}},
+/* 9,00 */   {{Solid   , Solid   , 50, 50}, {FineDash, FineDash, 35, 35}, {Dashed  , Dashed  , 35, 35}, {FineDash, FineDash, 35, 35}, {DashDot , DashDot , 35, 35}, {DashDoDo, DashDoDo, 35, 35}, {DoubThin, DoubThin, 35, 35}}
+    };
+
+    ScDocShellRef xShell    = loadDoc("test_borders_export.", FORMAT_ODS);  // load the ods with our Borders
+    CPPUNIT_ASSERT(xShell.Is());
+
+    ScDocShellRef xDocSh = saveAndReload(&(*xShell), FORMAT_XLSX);          // save the ods to xlsx and load xlsx
+    CPPUNIT_ASSERT(xDocSh.Is());
+    ScDocument& rDoc    = xDocSh->GetDocument();
+
+    for (size_t mnCol = 0; mnCol < nMaxCol; ++mnCol)
+    {
+        for (size_t mnRow = 0; mnRow < nMaxRow; ++mnRow)
+        {
+            const editeng::SvxBorderLine* pLineTop    = nullptr;
+            const editeng::SvxBorderLine* pLineBottom = nullptr;
+            rDoc.GetBorderLines(mnCol + 2, (mnRow * 2) + 8, 0, nullptr, &pLineTop, nullptr, &pLineBottom);
+            if((mnCol < 5) && (mnRow == 6))
+            {   // in this range no lines
+                CPPUNIT_ASSERT(pLineTop == nullptr);
+                CPPUNIT_ASSERT(pLineBottom == nullptr);
+                continue;
+            }
+            else
+            {
+                CPPUNIT_ASSERT(pLineTop);
+                CPPUNIT_ASSERT(pLineBottom);
+            }
+
+            CPPUNIT_ASSERT_EQUAL_MESSAGE("Top Border-Line-Style wrong", aCheckBorderWidth[mnCol][mnRow].BorderStyleTop,
+                                          pLineTop->GetBorderLineStyle());
+            CPPUNIT_ASSERT_EQUAL_MESSAGE("Bottom Border-Line-Style wrong", aCheckBorderWidth[mnCol][mnRow].BorderStyleBottom,
+                                          pLineBottom->GetBorderLineStyle());
+            CPPUNIT_ASSERT_EQUAL_MESSAGE("Top Width-Line wrong", aCheckBorderWidth[mnCol][mnRow].WidthTop,
+                                          pLineTop->GetWidth());
+            CPPUNIT_ASSERT_EQUAL_MESSAGE("Bottom Width-Line wrong", aCheckBorderWidth[mnCol][mnRow].WidthBottom,
+                                          pLineBottom->GetWidth());
+        }
+    }
+
+    xDocSh->DoClose();
+}
+
 OUString toString( const ScBigRange& rRange )
 {
     OUStringBuffer aBuf;
diff --git a/sc/source/filter/excel/xestyle.cxx b/sc/source/filter/excel/xestyle.cxx
index b0cc8de..665bf41 100644
--- a/sc/source/filter/excel/xestyle.cxx
+++ b/sc/source/filter/excel/xestyle.cxx
@@ -1631,60 +1631,78 @@ void lclGetBorderLine(
         sal_uInt8& rnXclLine, sal_uInt32& rnColorId,
         const ::editeng::SvxBorderLine* pLine, XclExpPalette& rPalette, XclBiff eBiff )
 {
+    // Document: sc/qa/unit/data/README.cellborders
+
+    enum CalcLineIndex{Idx_None, Idx_Solid, Idx_Dotted, Idx_Dashed, Idx_FineDashed, Idx_DashDot, Idx_DashDotDot, Idx_DoubleThin, Idx_Last};
+    enum ExcelWidthIndex{Width_Hair, Width_Thin, Width_Medium, Width_Thick, Width_Last};
+    static sal_uInt8 Map_LineLO_toMS[Idx_Last][Width_Last] =
+    {
+    //    0,05  -  0,74                  0,75  -  1,49                   1,50  -  2,49                 2,50  -  9,00          Width Range [pt]
+    //   EXC_BORDER_HAIR                EXC_BORDER_THIN                EXC_BORDER_MEDIUM              EXC_BORDER_THICK        MS Width
+        {EXC_LINE_NONE                , EXC_LINE_NONE                , EXC_LINE_NONE                , EXC_LINE_NONE                }, //  0    BorderLineStyle::NONE
+        {EXC_LINE_HAIR                , EXC_LINE_THIN                , EXC_LINE_MEDIUM              , EXC_LINE_THICK               }, //  1    BorderLineStyle::SOLID
+        {EXC_LINE_DOTTED              , EXC_LINE_DOTTED              , EXC_LINE_MEDIUM_SLANT_DASHDOT, EXC_LINE_MEDIUM_SLANT_DASHDOT}, //  2    BorderLineStyle::DOTTED
+        {EXC_LINE_DOTTED              , EXC_LINE_DASHED              , EXC_LINE_MEDIUM_DASHED       , EXC_LINE_MEDIUM_DASHED       }, //  3    BorderLineStyle::DASHED
+        {EXC_LINE_DASHED              , EXC_LINE_DASHED              , EXC_LINE_MEDIUM_SLANT_DASHDOT, EXC_LINE_MEDIUM_SLANT_DASHDOT}, //  4    BorderLineStyle::FINE_DASHED
+        {EXC_LINE_DASHED              , EXC_LINE_THIN_DASHDOT        , EXC_LINE_MEDIUM_DASHDOT      , EXC_LINE_MEDIUM_DASHDOT      }, //  5    BorderLineStyle::DASH_DOT
+        {EXC_LINE_DASHED              , EXC_LINE_THIN_DASHDOTDOT     , EXC_LINE_MEDIUM_DASHDOTDOT   , EXC_LINE_MEDIUM_DASHDOTDOT   }, //  6    BorderLineStyle::DASH_DOT_DOT
+        {EXC_LINE_DOUBLE              , EXC_LINE_DOUBLE              , EXC_LINE_DOUBLE              , EXC_LINE_DOUBLE              }  //  7    BorderLineStyle::DOUBLE_THIN
+    };                                                                                                                                // Line  Name
+
     rnXclLine = EXC_LINE_NONE;
     if( pLine )
     {
         sal_uInt16 nOuterWidth = pLine->GetOutWidth();
-        sal_uInt16 nDistance = pLine->GetDistance();
-        if( nDistance > 0 )
-            rnXclLine = EXC_LINE_DOUBLE;
-        else if( nOuterWidth >= EXC_BORDER_THICK )
-            rnXclLine = EXC_LINE_THICK;
-        else if( nOuterWidth >= EXC_BORDER_MEDIUM )
+        ExcelWidthIndex nOuterWidthIndx;
+        CalcLineIndex  nStyleIndex;
+
+        switch (pLine->GetBorderLineStyle())
         {
-            rnXclLine = EXC_LINE_MEDIUM;
-            switch (pLine->GetBorderLineStyle())
-            {
-                case table::BorderLineStyle::DASHED:
-                    rnXclLine = EXC_LINE_MEDIUM_DASHED;
+            case table::BorderLineStyle::NONE:
+                nStyleIndex = Idx_None;
                 break;
-                case table::BorderLineStyle::DASH_DOT:
-                    rnXclLine = EXC_LINE_MEDIUM_DASHDOT;
-                    break;
-                case table::BorderLineStyle::DASH_DOT_DOT:
-                    rnXclLine = EXC_LINE_MEDIUM_DASHDOTDOT;
-                    break;
-                default:
-                    ;
-            }
+            case table::BorderLineStyle::SOLID:
+                nStyleIndex = Idx_Solid;
+                break;
+            case table::BorderLineStyle::DOTTED:
+                nStyleIndex = Idx_Dotted;
+                break;
+            case table::BorderLineStyle::DASHED:
+                nStyleIndex = Idx_Dashed;
+                break;
+            case table::BorderLineStyle::FINE_DASHED:
+                nStyleIndex = Idx_FineDashed;
+                break;
+            case table::BorderLineStyle::DASH_DOT:
+                nStyleIndex = Idx_DashDot;
+                break;
+            case table::BorderLineStyle::DASH_DOT_DOT:
+                nStyleIndex = Idx_DashDotDot;
+                break;
+            case table::BorderLineStyle::DOUBLE_THIN:
+                // the "nOuterWidth" is not right for this line type
+                // but at the moment width it not important for that
+                // the right function is nOuterWidth = (sal_uInt16) pLine->GetWidth();
+                nStyleIndex = Idx_DoubleThin;
+                break;
+            default:
+                nStyleIndex = Idx_Solid;
         }
+
+        if( nOuterWidth >= EXC_BORDER_THICK )
+            nOuterWidthIndx = Width_Thick;
+        else if( nOuterWidth >= EXC_BORDER_MEDIUM )
+            nOuterWidthIndx = Width_Medium;
         else if( nOuterWidth >= EXC_BORDER_THIN )
-        {
-            rnXclLine = EXC_LINE_THIN;
-            switch (pLine->GetBorderLineStyle())
-            {
-                case table::BorderLineStyle::DASHED:
-                case table::BorderLineStyle::FINE_DASHED:
-                    rnXclLine = EXC_LINE_DASHED;
-                    break;
-                case table::BorderLineStyle::DASH_DOT:
-                    rnXclLine = EXC_LINE_THIN_DASHDOT;
-                    break;
-                case table::BorderLineStyle::DASH_DOT_DOT:
-                    rnXclLine = EXC_LINE_THIN_DASHDOTDOT;
-                    break;
-                case table::BorderLineStyle::DOTTED:
-                    rnXclLine = EXC_LINE_DOTTED;
-                    break;
-                default:
-                    break;
-            }
-        }
-        else if (nOuterWidth >= EXC_BORDER_HAIR)
-            rnXclLine = EXC_LINE_HAIR;
+            nOuterWidthIndx = Width_Thin;
+        else if ( nOuterWidth >= EXC_BORDER_HAIR )
+            nOuterWidthIndx = Width_Hair;
         else
-            rnXclLine = EXC_LINE_NONE;
+            nOuterWidthIndx = Width_Thin;
+
+        rnXclLine = Map_LineLO_toMS[nStyleIndex][nOuterWidthIndx];
     }
+
     if( (eBiff == EXC_BIFF2) && (rnXclLine != EXC_LINE_NONE) )
         rnXclLine = EXC_LINE_THIN;
 
@@ -1828,6 +1846,7 @@ static const char* ToLineStyle( sal_uInt8 nLineStyle )
         case EXC_LINE_THIN_DASHDOTDOT:   return "dashDotDot";
         case EXC_LINE_MEDIUM_DASHDOT:    return "mediumDashDot";
         case EXC_LINE_MEDIUM_DASHDOTDOT: return "mediumDashDotDot";
+        case EXC_LINE_MEDIUM_SLANT_DASHDOT: return "slantDashDot";
     }
     return "*unknown*";
 }
diff --git a/sc/source/filter/oox/stylesbuffer.cxx b/sc/source/filter/oox/stylesbuffer.cxx
index 009e5c9..ed95632 100644
--- a/sc/source/filter/oox/stylesbuffer.cxx
+++ b/sc/source/filter/oox/stylesbuffer.cxx
@@ -1661,6 +1661,8 @@ BorderLineModel* Border::getBorderLine( sal_Int32 nElement )
 
 bool Border::convertBorderLine( BorderLine2& rBorderLine, const BorderLineModel& rModel )
 {
+    // Document: sc/qa/unit/data/README.cellborders
+
     rBorderLine.Color = rModel.maColor.getColor( getBaseFilter().getGraphicHelper(), API_RGB_BLACK );
     switch( rModel.mnStyle )
     {
@@ -1681,7 +1683,7 @@ bool Border::convertBorderLine( BorderLine2& rBorderLine, const BorderLineModel&
             rBorderLine.LineStyle = table::BorderLineStyle::DOTTED;
         break;
         case XML_double:
-            lclSetBorderLineWidth( rBorderLine, 10, 30, 10 );
+            lclSetBorderLineWidth( rBorderLine, 10, 15, 10 );
             rBorderLine.LineStyle = table::BorderLineStyle::DOUBLE_THIN;
         break;
         case XML_hair:              lclSetBorderLineWidth( rBorderLine, API_LINE_HAIR );    break;
@@ -1701,7 +1703,7 @@ bool Border::convertBorderLine( BorderLine2& rBorderLine, const BorderLineModel&
         case XML_none:              lclSetBorderLineWidth( rBorderLine, API_LINE_NONE );    break;
         case XML_slantDashDot:
             lclSetBorderLineWidth( rBorderLine, API_LINE_MEDIUM );
-            rBorderLine.LineStyle = table::BorderLineStyle::DASH_DOT;
+            rBorderLine.LineStyle = table::BorderLineStyle::FINE_DASHED;
             break;
         case XML_thick:             lclSetBorderLineWidth( rBorderLine, API_LINE_THICK );   break;
         case XML_thin:              lclSetBorderLineWidth( rBorderLine, API_LINE_THIN );    break;


More information about the Libreoffice-commits mailing list