mirror of
https://github.com/brechtsanders/xlsxio
synced 2025-03-28 21:13:24 +00:00
This commit is contained in:
parent
7522f8f857
commit
cfd9ed5174
@ -1,3 +1,10 @@
|
||||
0.2.29
|
||||
|
||||
2020-07-10 Brecht Sanders https://github.com/brechtsanders/
|
||||
|
||||
* only treat sheet as a table (with header rows) when XLSXIOREAD_SKIP_EXTRA_CELLS flag is used (issue #75)
|
||||
* added xlsxioread_free() to fix crashes when calling library build with different compiler (issue #73)
|
||||
|
||||
0.2.28
|
||||
|
||||
2020-07-06 Brecht Sanders https://github.com/brechtsanders/
|
||||
|
@ -1,5 +1,5 @@
|
||||
# depslib dependency file v1.0
|
||||
1521232544 source:z:\xlsxio\examples\example_xlsxio_read.c
|
||||
1521236144 source:z:\xlsxio\examples\example_xlsxio_read.c
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<string.h>
|
||||
@ -12,7 +12,7 @@
|
||||
<fcntl.h>
|
||||
"xlsxio_read.h"
|
||||
|
||||
1521131524 z:\xlsxio\include\xlsxio_read.h
|
||||
1594390761 z:\xlsxio\include\xlsxio_read.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
|
@ -35,3 +35,39 @@
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
|
||||
1594390670 source:z:\xlsxio\lib\xlsxio_read.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
"xlsxio_read.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<inttypes.h>
|
||||
<string.h>
|
||||
<expat.h>
|
||||
<minizip/unzip.h>
|
||||
<io.h>
|
||||
<unistd.h>
|
||||
<zip.h>
|
||||
|
||||
1521234538 z:\xlsxio\lib\xlsxio_private.h
|
||||
<wchar.h>
|
||||
|
||||
1522321419 z:\xlsxio\lib\xlsxio_read_sharedstrings.h
|
||||
<stdint.h>
|
||||
<expat.h>
|
||||
|
||||
1594390761 z:\xlsxio\include\xlsxio_read.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
<wchar.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1522321402 source:z:\xlsxio\lib\xlsxio_read_sharedstrings.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
|
||||
|
@ -48,7 +48,7 @@
|
||||
<stdint.h>
|
||||
<expat.h>
|
||||
|
||||
1585050777 source:z:\xlsxio\lib\xlsxio_read.c
|
||||
1594390670 source:z:\xlsxio\lib\xlsxio_read.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
"xlsxio_read.h"
|
||||
@ -63,11 +63,11 @@
|
||||
<unistd.h>
|
||||
<zip.h>
|
||||
|
||||
1585050781 z:\xlsxio\include\xlsxio_read.h
|
||||
1594390761 z:\xlsxio\include\xlsxio_read.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
<wchar.h>
|
||||
|
||||
1585051485 z:\xlsxio\include\xlsxio_version.h
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
|
@ -35,3 +35,39 @@
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
|
||||
1594390670 source:z:\xlsxio\lib\xlsxio_read.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
"xlsxio_read.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<inttypes.h>
|
||||
<string.h>
|
||||
<expat.h>
|
||||
<minizip/unzip.h>
|
||||
<io.h>
|
||||
<unistd.h>
|
||||
<zip.h>
|
||||
|
||||
1521234538 z:\xlsxio\lib\xlsxio_private.h
|
||||
<wchar.h>
|
||||
|
||||
1522321419 z:\xlsxio\lib\xlsxio_read_sharedstrings.h
|
||||
<stdint.h>
|
||||
<expat.h>
|
||||
|
||||
1594390761 z:\xlsxio\include\xlsxio_read.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
<wchar.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1522321402 source:z:\xlsxio\lib\xlsxio_read_sharedstrings.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
|
||||
|
@ -35,3 +35,39 @@
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
|
||||
1594390670 source:z:\xlsxio\lib\xlsxio_read.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
"xlsxio_read.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<inttypes.h>
|
||||
<string.h>
|
||||
<expat.h>
|
||||
<minizip/unzip.h>
|
||||
<io.h>
|
||||
<unistd.h>
|
||||
<zip.h>
|
||||
|
||||
1521234538 z:\xlsxio\lib\xlsxio_private.h
|
||||
<wchar.h>
|
||||
|
||||
1522321419 z:\xlsxio\lib\xlsxio_read_sharedstrings.h
|
||||
<stdint.h>
|
||||
<expat.h>
|
||||
|
||||
1594390761 z:\xlsxio\include\xlsxio_read.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
<wchar.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1522321402 source:z:\xlsxio\lib\xlsxio_read_sharedstrings.c
|
||||
"xlsxio_private.h"
|
||||
"xlsxio_read_sharedstrings.h"
|
||||
<stdlib.h>
|
||||
<string.h>
|
||||
|
||||
|
@ -22,3 +22,26 @@
|
||||
|
||||
1585051485 \\server\users\brecht\sources\cpp\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1584727926 source:z:\xlsxio\lib\xlsxio_write.c
|
||||
"xlsxio_write.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<string.h>
|
||||
<time.h>
|
||||
<inttypes.h>
|
||||
<unistd.h>
|
||||
<fcntl.h>
|
||||
<stdarg.h>
|
||||
<minizip/zip.h>
|
||||
<zip.h>
|
||||
<windows.h>
|
||||
<pthread.h>
|
||||
|
||||
1583785145 z:\xlsxio\include\xlsxio_write.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
|
@ -22,3 +22,26 @@
|
||||
|
||||
1585051485 \\server\users\brecht\sources\cpp\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1584727926 source:z:\xlsxio\lib\xlsxio_write.c
|
||||
"xlsxio_write.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<string.h>
|
||||
<time.h>
|
||||
<inttypes.h>
|
||||
<unistd.h>
|
||||
<fcntl.h>
|
||||
<stdarg.h>
|
||||
<minizip/zip.h>
|
||||
<zip.h>
|
||||
<windows.h>
|
||||
<pthread.h>
|
||||
|
||||
1583785145 z:\xlsxio\include\xlsxio_write.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
|
@ -22,3 +22,26 @@
|
||||
|
||||
1585051485 \\server\users\brecht\sources\cpp\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1584727926 source:z:\xlsxio\lib\xlsxio_write.c
|
||||
"xlsxio_write.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<string.h>
|
||||
<time.h>
|
||||
<inttypes.h>
|
||||
<unistd.h>
|
||||
<fcntl.h>
|
||||
<stdarg.h>
|
||||
<minizip/zip.h>
|
||||
<zip.h>
|
||||
<windows.h>
|
||||
<pthread.h>
|
||||
|
||||
1583785145 z:\xlsxio\include\xlsxio_write.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
|
@ -22,3 +22,26 @@
|
||||
|
||||
1585051485 \\server\users\brecht\sources\cpp\xlsxio\include\xlsxio_version.h
|
||||
|
||||
1584727926 source:z:\xlsxio\lib\xlsxio_write.c
|
||||
"xlsxio_write.h"
|
||||
"xlsxio_version.h"
|
||||
<stdlib.h>
|
||||
<stdio.h>
|
||||
<string.h>
|
||||
<time.h>
|
||||
<inttypes.h>
|
||||
<unistd.h>
|
||||
<fcntl.h>
|
||||
<stdarg.h>
|
||||
<minizip/zip.h>
|
||||
<zip.h>
|
||||
<windows.h>
|
||||
<pthread.h>
|
||||
|
||||
1583785145 z:\xlsxio\include\xlsxio_write.h
|
||||
<stdlib.h>
|
||||
<stdint.h>
|
||||
<time.h>
|
||||
|
||||
1594390364 z:\xlsxio\include\xlsxio_version.h
|
||||
|
||||
|
@ -267,17 +267,19 @@ DLL_EXPORT_XLSXIO int xlsxioread_sheet_next_row (xlsxioreadersheet sheethandle);
|
||||
|
||||
/*! \brief get next cell from worksheet
|
||||
* \param sheethandle read handle for worksheet object
|
||||
* \return value (caller must free the result) or NULL if no more cells are available in the current row
|
||||
* \return value (caller must free the result using xlsxioread_free()) or NULL if no more cells are available in the current row
|
||||
* \sa xlsxioread_sheet_open()
|
||||
* \sa xlsxioread_free()
|
||||
*/
|
||||
DLL_EXPORT_XLSXIO XLSXIOCHAR* xlsxioread_sheet_next_cell (xlsxioreadersheet sheethandle);
|
||||
|
||||
/*! \brief get next cell from worksheet as a string
|
||||
* \param sheethandle read handle for worksheet object
|
||||
* \param pvalue pointer where string will be stored if data is available (caller must free the result)
|
||||
* \param pvalue pointer where string will be stored if data is available (caller must free the result using xlsxioread_free())
|
||||
* \return non-zero if a new cell was available in the current row
|
||||
* \sa xlsxioread_sheet_open()
|
||||
* \sa xlsxioread_sheet_next_cell()
|
||||
* \sa xlsxioread_free()
|
||||
*/
|
||||
DLL_EXPORT_XLSXIO int xlsxioread_sheet_next_cell_string (xlsxioreadersheet sheethandle, XLSXIOCHAR** pvalue);
|
||||
|
||||
@ -308,6 +310,15 @@ DLL_EXPORT_XLSXIO int xlsxioread_sheet_next_cell_float (xlsxioreadersheet sheeth
|
||||
*/
|
||||
DLL_EXPORT_XLSXIO int xlsxioread_sheet_next_cell_datetime (xlsxioreadersheet sheethandle, time_t* pvalue);
|
||||
|
||||
|
||||
|
||||
/*! \brief free memory allocated by the library
|
||||
* \param data memory to be freed
|
||||
* \sa xlsxioread_sheet_next_cell()
|
||||
* \sa xlsxioread_sheet_next_cell_string()
|
||||
*/
|
||||
DLL_EXPORT_XLSXIO void xlsxioread_free (XLSXIOCHAR* data);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@ -49,7 +49,7 @@ THE SOFTWARE.
|
||||
/*! \brief minor version number */
|
||||
#define XLSXIO_VERSION_MINOR 2
|
||||
/*! \brief micro version number */
|
||||
#define XLSXIO_VERSION_MICRO 28
|
||||
#define XLSXIO_VERSION_MICRO 29
|
||||
/*! @} */
|
||||
|
||||
/*! \cond PRIVATE */
|
||||
|
@ -1049,7 +1049,7 @@ void data_sheet_expat_callback_find_row_end (void* callbackdata, const XML_Char*
|
||||
struct data_sheet_callback_data* data = (struct data_sheet_callback_data*)callbackdata;
|
||||
if (XML_Char_icmp_ins(name, X("row")) == 0) {
|
||||
//determine number of columns based on first row
|
||||
if ((data->flags && XLSXIOREAD_SKIP_EXTRA_CELLS) && data->rownr == 1 && data->cols == 0)
|
||||
if ((data->flags & XLSXIOREAD_SKIP_EXTRA_CELLS) && data->rownr == 1 && data->cols == 0)
|
||||
data->cols = data->colnr;
|
||||
//add empty columns if needed
|
||||
if (!(data->flags & XLSXIOREAD_NO_CALLBACK) && data->sheet_cell_callback && !(data->flags & XLSXIOREAD_SKIP_EMPTY_CELLS)) {
|
||||
@ -1500,10 +1500,9 @@ DLL_EXPORT_XLSXIO XLSXIOCHAR* xlsxioread_sheet_next_cell (xlsxioreadersheet shee
|
||||
XML_Char* result;
|
||||
if (!sheethandle)
|
||||
return NULL;
|
||||
//append empty column if needed
|
||||
//if (!(sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EMPTY_CELLS) && sheethandle->paddingcol) {
|
||||
if ((!(sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EMPTY_CELLS) && sheethandle->paddingcol) || (!(sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EMPTY_ROWS) && sheethandle->paddingrow)) {
|
||||
if (sheethandle->paddingcol > sheethandle->processcallbackdata.cols || (sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EMPTY_CELLS)) {
|
||||
if ((/*sheethandle->processcallbackdata.cols > 0 &&*/ sheethandle->paddingcol > sheethandle->processcallbackdata.cols) || (sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EMPTY_CELLS)) {
|
||||
//last empty column added, finish row
|
||||
sheethandle->paddingcol = 0;
|
||||
//when padding rows prepare for the next one
|
||||
@ -1524,6 +1523,9 @@ DLL_EXPORT_XLSXIO XLSXIOCHAR* xlsxioread_sheet_next_cell (xlsxioreadersheet shee
|
||||
sheethandle->lastcolnr++;
|
||||
return XML_Char_dup(X(""));
|
||||
}
|
||||
} else if ((sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EXTRA_CELLS) && sheethandle->processcallbackdata.cols > 0 && sheethandle->lastcolnr >= sheethandle->processcallbackdata.cols) {
|
||||
//end of line when out of bounds
|
||||
return NULL;
|
||||
}
|
||||
//get value
|
||||
if (!sheethandle->processcallbackdata.celldata)
|
||||
@ -1538,7 +1540,8 @@ DLL_EXPORT_XLSXIO XLSXIOCHAR* xlsxioread_sheet_next_cell (xlsxioreadersheet shee
|
||||
//insert empty column before if needed
|
||||
if (!(sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EMPTY_CELLS)) {
|
||||
if (sheethandle->lastcolnr + 1 < sheethandle->processcallbackdata.colnr) {
|
||||
if (0) {//if ((sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EXTRA_CELLS) && sheethandle->processcallbackdata.cols > 0 && sheethandle->lastcolnr >= sheethandle->processcallbackdata.cols) {
|
||||
if (0) {
|
||||
//if ((sheethandle->processcallbackdata.flags & XLSXIOREAD_SKIP_EXTRA_CELLS) && sheethandle->processcallbackdata.cols > 0 && sheethandle->lastcolnr >= sheethandle->processcallbackdata.cols) {
|
||||
//end of line when out of bounds
|
||||
return NULL;
|
||||
} else {
|
||||
@ -1617,3 +1620,7 @@ DLL_EXPORT_XLSXIO int xlsxioread_sheet_next_cell_datetime (xlsxioreadersheet she
|
||||
return 1;
|
||||
}
|
||||
|
||||
DLL_EXPORT_XLSXIO void xlsxioread_free (XLSXIOCHAR* data)
|
||||
{
|
||||
free(data);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user