libxlsxwriter/src/styles.c in fast_excel-0.2.6 vs libxlsxwriter/src/styles.c in fast_excel-0.3.0

- old
+ new

@@ -1,21 +1,23 @@ /***************************************************************************** * styles - A library for creating Excel XLSX styles files. * * Used in conjunction with the libxlsxwriter library. * - * Copyright 2014-2018, John McNamara, jmcnamara@cpan.org. See LICENSE.txt. + * Copyright 2014-2019, John McNamara, jmcnamara@cpan.org. See LICENSE.txt. * */ #include "xlsxwriter/xmlwriter.h" #include "xlsxwriter/styles.h" #include "xlsxwriter/utility.h" /* * Forward declarations. */ +STATIC void _write_font(lxw_styles *self, lxw_format *format, + uint8_t is_rich_string); /***************************************************************************** * * Private functions. * @@ -23,11 +25,11 @@ /* * Create a new styles object. */ lxw_styles * -lxw_styles_new() +lxw_styles_new(void) { lxw_styles *styles = calloc(1, sizeof(lxw_styles)); GOTO_LABEL_ON_MEM_ERROR(styles, mem_error); styles->xf_formats = calloc(1, sizeof(struct lxw_formats)); @@ -64,10 +66,38 @@ } free(styles); } +/* + * Write the <t> element for rich strings. + */ +void +lxw_styles_write_string_fragment(lxw_styles *self, char *string) +{ + struct xml_attribute_list attributes; + struct xml_attribute *attribute; + + LXW_INIT_ATTRIBUTES(); + + /* Add attribute to preserve leading or trailing whitespace. */ + if (isspace((unsigned char) string[0]) + || isspace((unsigned char) string[strlen(string) - 1])) + LXW_PUSH_ATTRIBUTES_STR("xml:space", "preserve"); + + lxw_xml_data_element(self->file, "t", string, &attributes); + + LXW_FREE_ATTRIBUTES(); +} + +void +lxw_styles_write_rich_font(lxw_styles *self, lxw_format *format) +{ + + _write_font(self, format, LXW_TRUE); +} + /***************************************************************************** * * XML functions. * ****************************************************************************/ @@ -123,10 +153,11 @@ _write_num_fmts(lxw_styles *self) { struct xml_attribute_list attributes; struct xml_attribute *attribute; lxw_format *format; + uint16_t last_format_index = 0; if (!self->num_format_count) return; LXW_INIT_ATTRIBUTES(); @@ -139,11 +170,17 @@ /* Ignore built-in number formats, i.e., < 164. */ if (format->num_format_index < 164) continue; + /* Ignore duplicates which have an already used index. */ + if (format->num_format_index <= last_format_index) + continue; + _write_num_fmt(self, format->num_format_index, format->num_format); + + last_format_index = format->num_format_index; } lxw_xml_end_tag(self->file, "numFmts"); LXW_FREE_ATTRIBUTES(); @@ -205,11 +242,12 @@ /* * Write the <name> element. */ STATIC void -_write_font_name(lxw_styles *self, const char *font_name) +_write_font_name(lxw_styles *self, const char *font_name, + uint8_t is_rich_string) { struct xml_attribute_list attributes; struct xml_attribute *attribute; LXW_INIT_ATTRIBUTES(); @@ -217,11 +255,14 @@ if (*font_name) LXW_PUSH_ATTRIBUTES_STR("val", font_name); else LXW_PUSH_ATTRIBUTES_STR("val", LXW_DEFAULT_FONT_NAME); - lxw_xml_empty_tag(self->file, "name", &attributes); + if (is_rich_string) + lxw_xml_empty_tag(self->file, "rFont", &attributes); + else + lxw_xml_empty_tag(self->file, "name", &attributes); LXW_FREE_ATTRIBUTES(); } /* @@ -307,13 +348,16 @@ /* * Write the <font> element. */ STATIC void -_write_font(lxw_styles *self, lxw_format *format) +_write_font(lxw_styles *self, lxw_format *format, uint8_t is_rich_string) { - lxw_xml_start_tag(self->file, "font", NULL); + if (is_rich_string) + lxw_xml_start_tag(self->file, "rPr", NULL); + else + lxw_xml_start_tag(self->file, "font", NULL); if (format->bold) lxw_xml_empty_tag(self->file, "b", NULL); if (format->italic) @@ -345,22 +389,25 @@ else if (format->font_color != LXW_COLOR_UNSET) _write_font_color_rgb(self, format->font_color); else _write_font_color_theme(self, LXW_DEFAULT_FONT_THEME); - _write_font_name(self, format->font_name); + _write_font_name(self, format->font_name, is_rich_string); _write_font_family(self, format->font_family); /* Only write the scheme element for the default font type if it * is a hyperlink. */ if ((!*format->font_name || strcmp(LXW_DEFAULT_FONT_NAME, format->font_name) == 0) && !format->hyperlink) { _write_font_scheme(self, format->font_scheme); } - lxw_xml_end_tag(self->file, "font"); + if (is_rich_string) + lxw_xml_end_tag(self->file, "rPr"); + else + lxw_xml_end_tag(self->file, "font"); } /* * Write the <fonts> element. */ @@ -376,10 +423,10 @@ lxw_xml_start_tag(self->file, "fonts", &attributes); STAILQ_FOREACH(format, self->xf_formats, list_pointers) { if (format->has_font) - _write_font(self, format); + _write_font(self, format, LXW_FALSE); } lxw_xml_end_tag(self->file, "fonts"); LXW_FREE_ATTRIBUTES();