12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- /*
- +----------------------------------------------------------------------+
- | XlsWriter Extension |
- +----------------------------------------------------------------------+
- | Copyright (c) 2017-2018 The Viest |
- +----------------------------------------------------------------------+
- | http://www.viest.me |
- +----------------------------------------------------------------------+
- | Author: viest <[email protected]> |
- +----------------------------------------------------------------------+
- */
- #include "xlswriter.h"
- #include "php_streams.h"
- #include "ext/standard/file.h"
- /* {{{ */
- unsigned int xlsx_to_csv(zval *stream_resource, xlsxioreadersheet sheet_t, zval *zv_type_arr_t, unsigned int flag)
- {
- zval *_zv_type_arr_t = NULL;
- php_stream *_stream_t;
- ssize_t ret;
- char delimiter = ',';
- char enclosure = '"';
- int escape_char = (unsigned char) '\\';
- ZEND_ASSERT(Z_TYPE_P(stream_resource) == IS_RESOURCE);
- if (((_stream_t) = (php_stream *)zend_fetch_resource2((Z_RES_P(stream_resource)),
- "stream", php_file_le_stream(), php_file_le_pstream())) == NULL) {
- return XLSWRITER_FALSE;
- }
- if (Z_TYPE_P(zv_type_arr_t) == IS_ARRAY) {
- _zv_type_arr_t = zv_type_arr_t;
- }
- zval _zv_tmp_row;
- ZVAL_NULL(&_zv_tmp_row);
- while (sheet_read_row(sheet_t))
- {
- load_sheet_current_row_data(sheet_t, &_zv_tmp_row, _zv_type_arr_t, flag);
- ret = php_fputcsv(_stream_t, &_zv_tmp_row, delimiter, enclosure, escape_char);
- zend_hash_clean(Z_ARRVAL(_zv_tmp_row));
- if (ret < 0) {
- return XLSWRITER_FALSE;
- }
- }
- zval_dtor(&_zv_tmp_row);
- return XLSWRITER_TRUE;
- }
- /* }}} */
|