mirror of
https://github.com/tfussell/xlnt.git
synced 2024-03-22 13:11:17 +08:00
unskip another round-trip test, making progress
This commit is contained in:
parent
b5c46ede07
commit
c3993039bc
|
@ -68,18 +68,28 @@ const std::unordered_map<std::string, std::string> &constants::get_namespaces()
|
||||||
const std::unordered_map<std::string, std::string> *namespaces =
|
const std::unordered_map<std::string, std::string> *namespaces =
|
||||||
new std::unordered_map<std::string, std::string>
|
new std::unordered_map<std::string, std::string>
|
||||||
{
|
{
|
||||||
{ "spreadsheetml", "http://schemas.openxmlformats.org/spreadsheetml/2006/main" },
|
{ "worksheet", "http://schemas.openxmlformats.org/spreadsheetml/2006/main" },
|
||||||
{ "content-types", "http://schemas.openxmlformats.org/package/2006/content-types" },
|
{ "content-types", "http://schemas.openxmlformats.org/package/2006/content-types" },
|
||||||
{ "relationships", "http://schemas.openxmlformats.org/package/2006/relationships" },
|
{ "relationships", "http://schemas.openxmlformats.org/package/2006/relationships" },
|
||||||
{ "drawingml", "http://schemas.openxmlformats.org/drawingml/2006/main" },
|
{ "drawingml", "http://schemas.openxmlformats.org/drawingml/2006/main" },
|
||||||
{ "r", "http://schemas.openxmlformats.org/officeDocument/2006/relationships" },
|
{ "workbook", "http://schemas.openxmlformats.org/spreadsheetml/2006/main" },
|
||||||
{ "cp", "http://schemas.openxmlformats.org/package/2006/metadata/core-properties" },
|
{ "core-properties", "http://schemas.openxmlformats.org/package/2006/metadata/core-properties" },
|
||||||
|
{ "extended-properties", "http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" },
|
||||||
|
|
||||||
{ "dc", "http://purl.org/dc/elements/1.1/" },
|
{ "dc", "http://purl.org/dc/elements/1.1/" },
|
||||||
{ "dcterms", "http://purl.org/dc/terms/" },
|
{ "dcterms", "http://purl.org/dc/terms/" },
|
||||||
{ "dcmitype", "http://purl.org/dc/dcmitype/" },
|
{ "dcmitype", "http://purl.org/dc/dcmitype/" },
|
||||||
{ "xsi", "http://www.w3.org/2001/XMLSchema-instance" },
|
{ "mc", "http://schemas.openxmlformats.org/markup-compatibility/2006" },
|
||||||
|
{ "mx", "http://schemas.microsoft.com/office/mac/excel/2008/main" },
|
||||||
|
{ "r", "http://schemas.openxmlformats.org/officeDocument/2006/relationships" },
|
||||||
|
{ "thm15", "http://schemas.microsoft.com/office/thememl/2012/main" },
|
||||||
{ "vt", "http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes" },
|
{ "vt", "http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes" },
|
||||||
{ "xml", "http://www.w3.org/XML/1998/namespace" }
|
{ "x14", "http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" },
|
||||||
|
{ "x14ac", "http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac" },
|
||||||
|
{ "x15", "http://schemas.microsoft.com/office/spreadsheetml/2010/11/main" },
|
||||||
|
{ "x15ac", "http://schemas.microsoft.com/office/spreadsheetml/2010/11/ac" },
|
||||||
|
{ "xml", "http://www.w3.org/XML/1998/namespace" },
|
||||||
|
{ "xsi", "http://www.w3.org/2001/XMLSchema-instance" }
|
||||||
};
|
};
|
||||||
|
|
||||||
return *namespaces;
|
return *namespaces;
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -220,15 +220,17 @@ void xlsx_producer::write_extended_properties(const relationship &rel)
|
||||||
serializer().element(xmlns, "SharedDoc", source_.is_shared_doc() ? "true" : "false");
|
serializer().element(xmlns, "SharedDoc", source_.is_shared_doc() ? "true" : "false");
|
||||||
serializer().element(xmlns, "HyperlinksChanged", source_.hyperlinks_changed() ? "true" : "false");
|
serializer().element(xmlns, "HyperlinksChanged", source_.hyperlinks_changed() ? "true" : "false");
|
||||||
serializer().element(xmlns, "AppVersion", source_.get_app_version());
|
serializer().element(xmlns, "AppVersion", source_.get_app_version());
|
||||||
|
|
||||||
|
serializer().end_element(xmlns, "Properties");
|
||||||
}
|
}
|
||||||
|
|
||||||
void xlsx_producer::write_core_properties(const relationship &rel)
|
void xlsx_producer::write_core_properties(const relationship &rel)
|
||||||
{
|
{
|
||||||
static const auto xmlns_cp = "http://schemas.openxmlformats.org/package/2006/metadata/core-properties"s;
|
static const auto xmlns_cp = constants::get_namespace("core-properties");
|
||||||
static const auto xmlns_dc = "http://purl.org/dc/elements/1.1/"s;
|
static const auto xmlns_dc = constants::get_namespace("dc");
|
||||||
static const auto xmlns_dcterms = "http://purl.org/dc/terms/"s;
|
static const auto xmlns_dcterms = constants::get_namespace("dcterms");
|
||||||
static const auto xmlns_dcmitype = "http://purl.org/dc/dcmitype/"s;
|
static const auto xmlns_dcmitype = constants::get_namespace("dcmitype");
|
||||||
static const auto xmlns_xsi = "http://www.w3.org/2001/XMLSchema-instance"s;
|
static const auto xmlns_xsi = constants::get_namespace("xsi");
|
||||||
|
|
||||||
serializer().start_element(xmlns_cp, "coreProperties");
|
serializer().start_element(xmlns_cp, "coreProperties");
|
||||||
serializer().namespace_decl(xmlns_cp, "cp");
|
serializer().namespace_decl(xmlns_cp, "cp");
|
||||||
|
@ -294,13 +296,13 @@ void xlsx_producer::write_workbook(const relationship &rel)
|
||||||
throw no_visible_worksheets();
|
throw no_visible_worksheets();
|
||||||
}
|
}
|
||||||
|
|
||||||
static const auto xmlns = "http://schemas.openxmlformats.org/spreadsheetml/2006/main"s;
|
static const auto xmlns = constants::get_namespace("workbook");
|
||||||
static const auto xmlns_mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"s;
|
static const auto xmlns_mc = constants::get_namespace("mc");
|
||||||
static const auto xmlns_mx = "http://schemas.microsoft.com/office/mac/excel/2008/main"s;
|
static const auto xmlns_mx = constants::get_namespace("mx");
|
||||||
static const auto xmlns_r = "http://schemas.openxmlformats.org/officeDocument/2006/relationships"s;
|
static const auto xmlns_r = constants::get_namespace("r");
|
||||||
static const auto xmlns_s = "http://schemas.openxmlformats.org/spreadsheetml/2006/main"s;
|
static const auto xmlns_s = constants::get_namespace("worksheet");
|
||||||
static const auto xmlns_x15 = "http://schemas.microsoft.com/office/spreadsheetml/2010/11/main"s;
|
static const auto xmlns_x15 = constants::get_namespace("x15");
|
||||||
static const auto xmlns_x15ac = "http://schemas.microsoft.com/office/spreadsheetml/2010/11/ac"s;
|
static const auto xmlns_x15ac = constants::get_namespace("x15ac");
|
||||||
|
|
||||||
serializer().start_element(xmlns, "workbook");
|
serializer().start_element(xmlns, "workbook");
|
||||||
serializer().namespace_decl(xmlns, "");
|
serializer().namespace_decl(xmlns, "");
|
||||||
|
@ -599,7 +601,7 @@ void xlsx_producer::write_pivot_table(const relationship &rel)
|
||||||
|
|
||||||
void xlsx_producer::write_shared_string_table(const relationship &rel)
|
void xlsx_producer::write_shared_string_table(const relationship &rel)
|
||||||
{
|
{
|
||||||
static const auto xmlns = "http://schemas.openxmlformats.org/spreadsheetml/2006/main"s;
|
static const auto xmlns = constants::get_namespace("worksheet");
|
||||||
|
|
||||||
serializer().start_element(xmlns, "sst");
|
serializer().start_element(xmlns, "sst");
|
||||||
serializer().namespace_decl(xmlns, "");
|
serializer().namespace_decl(xmlns, "");
|
||||||
|
@ -710,10 +712,10 @@ void xlsx_producer::write_shared_workbook_user_data(const relationship &rel)
|
||||||
|
|
||||||
void xlsx_producer::write_styles(const relationship &rel)
|
void xlsx_producer::write_styles(const relationship &rel)
|
||||||
{
|
{
|
||||||
static const auto xmlns = "http://schemas.openxmlformats.org/spreadsheetml/2006/main"s;
|
static const auto xmlns = constants::get_namespace("worksheet");
|
||||||
static const auto xmlns_mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"s;
|
static const auto xmlns_mc = constants::get_namespace("mc");
|
||||||
static const auto xmlns_x14 = "http://schemas.microsoft.com/office/spreadsheetml/2009/9/main"s;
|
static const auto xmlns_x14 = constants::get_namespace("x14");
|
||||||
static const auto xmlns_x14ac = "http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac"s;
|
static const auto xmlns_x14ac = constants::get_namespace("x14ac");
|
||||||
|
|
||||||
serializer().start_element(xmlns, "styleSheet");
|
serializer().start_element(xmlns, "styleSheet");
|
||||||
serializer().namespace_decl(xmlns, "");
|
serializer().namespace_decl(xmlns, "");
|
||||||
|
@ -1204,7 +1206,7 @@ void xlsx_producer::write_styles(const relationship &rel)
|
||||||
void xlsx_producer::write_theme(const relationship &rel)
|
void xlsx_producer::write_theme(const relationship &rel)
|
||||||
{
|
{
|
||||||
static const auto xmlns_a = constants::get_namespace("drawingml");
|
static const auto xmlns_a = constants::get_namespace("drawingml");
|
||||||
static const auto xmlns_thm15 = "http://schemas.microsoft.com/office/thememl/2012/main"s;
|
static const auto xmlns_thm15 = constants::get_namespace("thm15");
|
||||||
|
|
||||||
serializer().start_element(xmlns_a, "theme");
|
serializer().start_element(xmlns_a, "theme");
|
||||||
serializer().namespace_decl(xmlns_a, "a");
|
serializer().namespace_decl(xmlns_a, "a");
|
||||||
|
@ -1687,10 +1689,10 @@ void xlsx_producer::write_worksheet(const relationship &rel)
|
||||||
|
|
||||||
auto ws = source_.get_sheet_by_title(title);
|
auto ws = source_.get_sheet_by_title(title);
|
||||||
|
|
||||||
static const auto xmlns = "http://schemas.openxmlformats.org/spreadsheetml/2006/main"s;
|
static const auto xmlns = constants::get_namespace("worksheet");
|
||||||
static const auto xmlns_r = "http://schemas.openxmlformats.org/officeDocument/2006/relationships"s;
|
static const auto xmlns_r = constants::get_namespace("r");
|
||||||
static const auto xmlns_mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"s;
|
static const auto xmlns_mc = constants::get_namespace("mc");
|
||||||
static const auto xmlns_x14ac = "http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac"s;
|
static const auto xmlns_x14ac = constants::get_namespace("x14ac");
|
||||||
|
|
||||||
serializer().start_element(xmlns, "worksheet");
|
serializer().start_element(xmlns, "worksheet");
|
||||||
serializer().namespace_decl(xmlns, "");
|
serializer().namespace_decl(xmlns, "");
|
||||||
|
@ -1815,7 +1817,10 @@ void xlsx_producer::write_worksheet(const relationship &rel)
|
||||||
serializer().start_element(xmlns, "sheetFormatPr");
|
serializer().start_element(xmlns, "sheetFormatPr");
|
||||||
serializer().attribute("baseColWidth", "10");
|
serializer().attribute("baseColWidth", "10");
|
||||||
serializer().attribute("defaultRowHeight", "16");
|
serializer().attribute("defaultRowHeight", "16");
|
||||||
serializer().attribute(xmlns_x14ac, "dyDescent", "0.2");
|
if (ws.x14ac_enabled())
|
||||||
|
{
|
||||||
|
serializer().attribute(xmlns_x14ac, "dyDescent", "0.2");
|
||||||
|
}
|
||||||
serializer().end_element(xmlns, "sheetFormatPr");
|
serializer().end_element(xmlns, "sheetFormatPr");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1901,7 +1906,7 @@ void xlsx_producer::write_worksheet(const relationship &rel)
|
||||||
|
|
||||||
if (!skip_unknown_elements)
|
if (!skip_unknown_elements)
|
||||||
{
|
{
|
||||||
serializer().attribute("x14ac:dyDescent", 0.25);
|
serializer().attribute(xmlns_x14ac, "dyDescent", 0.25);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (auto cell : row)
|
for (auto cell : row)
|
||||||
|
|
|
@ -61,14 +61,12 @@ public:
|
||||||
|
|
||||||
void test_round_trip_minimal_wrw()
|
void test_round_trip_minimal_wrw()
|
||||||
{
|
{
|
||||||
TS_SKIP("");
|
|
||||||
xlnt::workbook wb = xlnt::workbook::minimal();
|
xlnt::workbook wb = xlnt::workbook::minimal();
|
||||||
TS_ASSERT(round_trip_matches_wrw(wb));
|
TS_ASSERT(round_trip_matches_wrw(wb));
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_round_trip_empty_excel_wrw()
|
void test_round_trip_empty_excel_wrw()
|
||||||
{
|
{
|
||||||
TS_SKIP("");
|
|
||||||
xlnt::workbook wb = xlnt::workbook::empty_excel();
|
xlnt::workbook wb = xlnt::workbook::empty_excel();
|
||||||
TS_ASSERT(round_trip_matches_wrw(wb));
|
TS_ASSERT(round_trip_matches_wrw(wb));
|
||||||
}
|
}
|
||||||
|
@ -87,6 +85,12 @@ public:
|
||||||
TS_ASSERT(round_trip_matches_wrw(wb));
|
TS_ASSERT(round_trip_matches_wrw(wb));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void test_round_trip_minimal_rw()
|
||||||
|
{
|
||||||
|
auto path = path_helper::get_data_directory("8_minimal.xlsx");
|
||||||
|
TS_ASSERT(round_trip_matches_rw(path));
|
||||||
|
}
|
||||||
|
|
||||||
void test_round_trip_empty_excel_rw()
|
void test_round_trip_empty_excel_rw()
|
||||||
{
|
{
|
||||||
TS_SKIP("");
|
TS_SKIP("");
|
||||||
|
|
Loading…
Reference in New Issue
Block a user