mirror of
https://github.com/jmcnamara/libxlsxwriter
synced 2025-03-28 21:13:14 +00:00
Refactored tmpfile() usage for that it can be over-ridden.
This commit is contained in:
parent
1222fa8ef8
commit
b2ed3a34a8
@ -126,6 +126,8 @@ uint16_t lxw_get_col_2(const char *col_str);
|
|||||||
|
|
||||||
double _datetime_to_excel_date(lxw_datetime *datetime, uint8_t date_1904);
|
double _datetime_to_excel_date(lxw_datetime *datetime, uint8_t date_1904);
|
||||||
|
|
||||||
|
FILE * lxw_tmpfile(void);
|
||||||
|
|
||||||
/* Declarations required for unit testing. */
|
/* Declarations required for unit testing. */
|
||||||
#ifdef TESTING
|
#ifdef TESTING
|
||||||
|
|
||||||
|
@ -97,7 +97,7 @@ _write_workbook_file(lxw_packager *self)
|
|||||||
{
|
{
|
||||||
lxw_workbook *workbook = self->workbook;
|
lxw_workbook *workbook = self->workbook;
|
||||||
|
|
||||||
workbook->file = tmpfile();
|
workbook->file = lxw_tmpfile();
|
||||||
|
|
||||||
_workbook_assemble_xml_file(workbook);
|
_workbook_assemble_xml_file(workbook);
|
||||||
|
|
||||||
@ -126,7 +126,7 @@ _write_worksheet_files(lxw_packager *self)
|
|||||||
if (worksheet->optimize_row)
|
if (worksheet->optimize_row)
|
||||||
_worksheet_write_single_row(worksheet);
|
_worksheet_write_single_row(worksheet);
|
||||||
|
|
||||||
worksheet->file = tmpfile();
|
worksheet->file = lxw_tmpfile();
|
||||||
|
|
||||||
_worksheet_assemble_xml_file(worksheet);
|
_worksheet_assemble_xml_file(worksheet);
|
||||||
|
|
||||||
@ -150,7 +150,7 @@ _write_shared_strings_file(lxw_packager *self)
|
|||||||
if (!sst->string_count)
|
if (!sst->string_count)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
sst->file = tmpfile();
|
sst->file = lxw_tmpfile();
|
||||||
|
|
||||||
_sst_assemble_xml_file(sst);
|
_sst_assemble_xml_file(sst);
|
||||||
|
|
||||||
@ -172,7 +172,7 @@ _write_app_file(lxw_packager *self)
|
|||||||
lxw_app *app = _new_app();
|
lxw_app *app = _new_app();
|
||||||
char num_sheets[ATTR_32] = { 0 };
|
char num_sheets[ATTR_32] = { 0 };
|
||||||
|
|
||||||
app->file = tmpfile();
|
app->file = lxw_tmpfile();
|
||||||
|
|
||||||
__builtin_snprintf(num_sheets, ATTR_32, "%d", self->workbook->num_sheets);
|
__builtin_snprintf(num_sheets, ATTR_32, "%d", self->workbook->num_sheets);
|
||||||
|
|
||||||
@ -201,7 +201,7 @@ _write_core_file(lxw_packager *self)
|
|||||||
{
|
{
|
||||||
lxw_core *core = _new_core();
|
lxw_core *core = _new_core();
|
||||||
|
|
||||||
core->file = tmpfile();
|
core->file = lxw_tmpfile();
|
||||||
|
|
||||||
core->properties = self->workbook->properties;
|
core->properties = self->workbook->properties;
|
||||||
|
|
||||||
@ -224,7 +224,7 @@ _write_theme_file(lxw_packager *self)
|
|||||||
{
|
{
|
||||||
lxw_theme *theme = _new_theme();
|
lxw_theme *theme = _new_theme();
|
||||||
|
|
||||||
theme->file = tmpfile();
|
theme->file = lxw_tmpfile();
|
||||||
|
|
||||||
_theme_assemble_xml_file(theme);
|
_theme_assemble_xml_file(theme);
|
||||||
|
|
||||||
@ -263,7 +263,7 @@ _write_styles_file(lxw_packager *self)
|
|||||||
styles->num_format_count = self->workbook->num_format_count;
|
styles->num_format_count = self->workbook->num_format_count;
|
||||||
styles->xf_count = self->workbook->xf_format_indices->unique_count;
|
styles->xf_count = self->workbook->xf_format_indices->unique_count;
|
||||||
|
|
||||||
styles->file = tmpfile();
|
styles->file = lxw_tmpfile();
|
||||||
|
|
||||||
_styles_assemble_xml_file(styles);
|
_styles_assemble_xml_file(styles);
|
||||||
|
|
||||||
@ -288,7 +288,7 @@ _write_content_types_file(lxw_packager *self)
|
|||||||
char sheetname[FILENAME_LEN] = { 0 };
|
char sheetname[FILENAME_LEN] = { 0 };
|
||||||
uint16_t index = 1;
|
uint16_t index = 1;
|
||||||
|
|
||||||
content_types->file = tmpfile();
|
content_types->file = lxw_tmpfile();
|
||||||
|
|
||||||
STAILQ_FOREACH(worksheet, workbook->worksheets, list_pointers) {
|
STAILQ_FOREACH(worksheet, workbook->worksheets, list_pointers) {
|
||||||
__builtin_snprintf(sheetname, FILENAME_LEN, "sheet%d", index++);
|
__builtin_snprintf(sheetname, FILENAME_LEN, "sheet%d", index++);
|
||||||
@ -321,7 +321,7 @@ _write_workbook_rels_file(lxw_packager *self)
|
|||||||
char sheetname[FILENAME_LEN] = { 0 };
|
char sheetname[FILENAME_LEN] = { 0 };
|
||||||
uint16_t index = 1;
|
uint16_t index = 1;
|
||||||
|
|
||||||
rels->file = tmpfile();
|
rels->file = lxw_tmpfile();
|
||||||
|
|
||||||
STAILQ_FOREACH(worksheet, workbook->worksheets, list_pointers) {
|
STAILQ_FOREACH(worksheet, workbook->worksheets, list_pointers) {
|
||||||
__builtin_snprintf(sheetname, FILENAME_LEN, "worksheets/sheet%d.xml",
|
__builtin_snprintf(sheetname, FILENAME_LEN, "worksheets/sheet%d.xml",
|
||||||
@ -354,7 +354,7 @@ _write_root_rels_file(lxw_packager *self)
|
|||||||
{
|
{
|
||||||
lxw_relationships *rels = _new_relationships();
|
lxw_relationships *rels = _new_relationships();
|
||||||
|
|
||||||
rels->file = tmpfile();
|
rels->file = lxw_tmpfile();
|
||||||
|
|
||||||
_add_document_relationship(rels, "/officeDocument", "xl/workbook.xml");
|
_add_document_relationship(rels, "/officeDocument", "xl/workbook.xml");
|
||||||
_add_package_relationship(rels, "/metadata/core-properties",
|
_add_package_relationship(rels, "/metadata/core-properties",
|
||||||
|
@ -322,3 +322,14 @@ _datetime_to_excel_date(lxw_datetime *datetime, uint8_t date_1904)
|
|||||||
|
|
||||||
return days + seconds;
|
return days + seconds;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Thin wrapper for tmpfile() so it can be over-ridden with a safer version if
|
||||||
|
* required.
|
||||||
|
*/
|
||||||
|
FILE *
|
||||||
|
lxw_tmpfile(void)
|
||||||
|
{
|
||||||
|
return tmpfile();
|
||||||
|
}
|
||||||
|
@ -63,7 +63,7 @@ _new_worksheet(lxw_worksheet_init_data *init_data)
|
|||||||
TAILQ_INIT(worksheet->table);
|
TAILQ_INIT(worksheet->table);
|
||||||
|
|
||||||
if (init_data && init_data->optimize) {
|
if (init_data && init_data->optimize) {
|
||||||
worksheet->optimize_tmpfile = tmpfile();
|
worksheet->optimize_tmpfile = lxw_tmpfile();
|
||||||
worksheet->file = worksheet->optimize_tmpfile;
|
worksheet->file = worksheet->optimize_tmpfile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user