making changes caused by changes in qse_awk_rtx_valtostr()
This commit is contained in:
		| @ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * $Id: awk.h 87 2009-02-28 02:18:00Z hyunghwan.chung $ | ||||
|  * $Id: awk.h 88 2009-02-28 08:44:21Z hyunghwan.chung $ | ||||
|  * | ||||
|    Copyright 2006-2009 Chung, Hyung-Hwan. | ||||
|  | ||||
| @ -708,30 +708,36 @@ enum qse_awk_val_ref_id_t | ||||
| 	QSE_AWK_VAL_REF_POS | ||||
| }; | ||||
|  | ||||
| enum qse_awk_rtx_valtostr_opt_t | ||||
| enum qse_awk_valtostr_type_t | ||||
| { | ||||
| 	QSE_AWK_RTX_VALTOSTR_CLEAR = (1 << 0), | ||||
| 	QSE_AWK_RTX_VALTOSTR_FIXED = (1 << 1), /* this overrides CLEAR */ | ||||
| 	QSE_AWK_RTX_VALTOSTR_PRINT = (1 << 2) | ||||
| 	QSE_AWK_RTX_VALTOSTR_CPL       = 0x00, | ||||
| 	QSE_AWK_RTX_VALTOSTR_CPLDUP    = 0x01, | ||||
| 	QSE_AWK_RTX_VALTOSTR_STRP      = 0x02, | ||||
| 	QSE_AWK_RTX_VALTOSTR_STRPCAT   = 0x03, | ||||
|  | ||||
| 	/* can be ORed with one of the values above */ | ||||
| 	QSE_AWK_RTX_VALTOSTR_PRINT     = 0x10 | ||||
| }; | ||||
|  | ||||
| struct qse_awk_valtostr_out_t | ||||
| /****s* AWK/qse_rtx_awk_valtostr_out_t | ||||
|  * NAME | ||||
|  *  qse_awk_rtx_valtostr_out_t - define a value-to-string converion output type | ||||
|  * SYNOPSIS | ||||
|  */ | ||||
| struct qse_awk_rtx_valtostr_out_t | ||||
| { | ||||
| 	enum | ||||
| 	{ | ||||
| 		QSE_AWK_RTX_VALTOSTR_CP | ||||
| 		QSE_AWK_RTX_VALTOSTR_CPL | ||||
| 		QSE_AWK_RTX_VALTOSTR_STRP | ||||
| 	} type; | ||||
| 	int type; | ||||
|  | ||||
| 	union | ||||
| 	{ | ||||
| 		qse_char_t* cp; | ||||
| 		qse_xstr_t  cpl; | ||||
| 		qse_xstr_t  cpldup;  /* need to free cpldup.ptr */ | ||||
| 		qse_str_t*  strp; | ||||
| 		qse_str_t*  strpcat; | ||||
| 	} u; | ||||
| }; | ||||
| typedef struct qse_awk_valtostr_out_t qse_awk_valtostr_out_t; | ||||
| typedef struct qse_awk_rtx_valtostr_out_t qse_awk_rtx_valtostr_out_t; | ||||
| /******/ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| @ -1584,6 +1590,7 @@ qse_bool_t qse_awk_rtx_valtobool ( | ||||
| 	qse_awk_val_t* val | ||||
| ); | ||||
|  | ||||
| #if 0 | ||||
| qse_char_t* qse_awk_rtx_valtostr ( | ||||
| 	qse_awk_rtx_t* rtx, | ||||
| 	qse_awk_val_t* val,  | ||||
| @ -1591,6 +1598,19 @@ qse_char_t* qse_awk_rtx_valtostr ( | ||||
| 	qse_str_t*     buf, | ||||
| 	qse_size_t*    len | ||||
| ); | ||||
| #endif | ||||
|  | ||||
| /****f* AWK/qse_awk_rtx_valtostr | ||||
|  * NAME | ||||
|  *  qse_awk_rtx_valtostr - convert a value to a string | ||||
|  * SYNOPSIS | ||||
|  */ | ||||
| qse_char_t* qse_awk_rtx_valtostr ( | ||||
| 	qse_awk_rtx_t*              rtx, | ||||
| 	qse_awk_val_t*              val,  | ||||
| 	qse_awk_rtx_valtostr_out_t* out | ||||
| ); | ||||
| /******/ | ||||
|  | ||||
| /****f* AWK/qse_awk_rtx_valtonum | ||||
|  * NAME | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * $Id: run.c 77 2009-02-23 00:57:18Z hyunghwan.chung $ | ||||
|  * $Id: run.c 88 2009-02-28 08:44:21Z hyunghwan.chung $ | ||||
|  * | ||||
|    Copyright 2006-2009 Chung, Hyung-Hwan. | ||||
|  | ||||
| @ -311,18 +311,18 @@ static int set_global ( | ||||
|  | ||||
| 	if (idx == QSE_AWK_GBL_CONVFMT) | ||||
| 	{ | ||||
| 		qse_char_t* convfmt_ptr; | ||||
| 		qse_size_t convfmt_len, i; | ||||
| 		qse_size_t i; | ||||
| 		qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 		convfmt_ptr = qse_awk_rtx_valtostr (run,  | ||||
| 			val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &convfmt_len); | ||||
| 		if (convfmt_ptr == QSE_NULL) return  -1; | ||||
| 		out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 		if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
|  | ||||
| 		for (i = 0; i < convfmt_len; i++) | ||||
| 		for (i = 0; i < out.u.cpldup.len; i++) | ||||
| 		{ | ||||
| 			if (convfmt_ptr[i] == QSE_T('\0')) | ||||
| 			if (out.u.cpldup.ptr[i] == QSE_T('\0')) | ||||
| 			{ | ||||
| 				QSE_AWK_FREE (run->awk, convfmt_ptr); | ||||
| 				/* '\0' is included in the value */ | ||||
| 				QSE_AWK_FREE (run->awk, out.u.cpldup.ptr); | ||||
| 				qse_awk_rtx_seterrnum (run, QSE_AWK_ECONVFMTCHR); | ||||
| 				return -1; | ||||
| 			} | ||||
| @ -330,8 +330,8 @@ static int set_global ( | ||||
|  | ||||
| 		if (run->gbl.convfmt.ptr != QSE_NULL) | ||||
| 			QSE_AWK_FREE (run->awk, run->gbl.convfmt.ptr); | ||||
| 		run->gbl.convfmt.ptr = convfmt_ptr; | ||||
| 		run->gbl.convfmt.len = convfmt_len; | ||||
| 		run->gbl.convfmt.ptr = out.u.cpldup.ptr; | ||||
| 		run->gbl.convfmt.len = out.u.cpldup.len; | ||||
| 	} | ||||
| 	else if (idx == QSE_AWK_GBL_FNR) | ||||
| 	{ | ||||
| @ -357,13 +357,16 @@ static int set_global ( | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 			/* due to the expression evaluation rule, the  | ||||
| 			 * regular expression can not be an assigned value */ | ||||
| 			QSE_ASSERT (val->type != QSE_AWK_VAL_REX); | ||||
|  | ||||
| 			fs_ptr = qse_awk_rtx_valtostr ( | ||||
| 				run, val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &fs_len); | ||||
| 			if (fs_ptr == QSE_NULL) return -1; | ||||
| 			out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 			if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
| 			fs_ptr = out.u.cpldup.ptr; | ||||
| 			fs_len = out.u.cpldup.len; | ||||
| 		} | ||||
|  | ||||
| 		if (fs_len > 1) | ||||
| @ -439,18 +442,17 @@ static int set_global ( | ||||
| 	} | ||||
| 	else if (idx == QSE_AWK_GBL_OFMT) | ||||
| 	{ | ||||
| 		qse_char_t* ofmt_ptr; | ||||
| 		qse_size_t ofmt_len, i; | ||||
| 		qse_size_t i; | ||||
| 		qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 		ofmt_ptr = qse_awk_rtx_valtostr ( | ||||
| 			run, val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &ofmt_len); | ||||
| 		if (ofmt_ptr == QSE_NULL) return  -1; | ||||
| 		out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 		if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
|  | ||||
| 		for (i = 0; i < ofmt_len; i++) | ||||
| 		for (i = 0; i < out.u.cpldup.len; i++) | ||||
| 		{ | ||||
| 			if (ofmt_ptr[i] == QSE_T('\0')) | ||||
| 			if (out.u.cpldup.ptr[i] == QSE_T('\0')) | ||||
| 			{ | ||||
| 				QSE_AWK_FREE (run->awk, ofmt_ptr); | ||||
| 				QSE_AWK_FREE (run->awk, out.u.cpldup.ptr); | ||||
| 				qse_awk_rtx_seterrnum (run, QSE_AWK_EOFMTCHR); | ||||
| 				return -1; | ||||
| 			} | ||||
| @ -458,36 +460,32 @@ static int set_global ( | ||||
|  | ||||
| 		if (run->gbl.ofmt.ptr != QSE_NULL) | ||||
| 			QSE_AWK_FREE (run->awk, run->gbl.ofmt.ptr); | ||||
| 		run->gbl.ofmt.ptr = ofmt_ptr; | ||||
| 		run->gbl.ofmt.len = ofmt_len; | ||||
| 		run->gbl.ofmt.ptr = out.u.cpldup.ptr; | ||||
| 		run->gbl.ofmt.len = out.u.cpldup.len; | ||||
| 	} | ||||
| 	else if (idx == QSE_AWK_GBL_OFS) | ||||
| 	{	 | ||||
| 		qse_char_t* ofs_ptr; | ||||
| 		qse_size_t ofs_len; | ||||
| 		qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 		ofs_ptr = qse_awk_rtx_valtostr ( | ||||
| 			run, val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &ofs_len); | ||||
| 		if (ofs_ptr == QSE_NULL) return  -1; | ||||
| 		out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 		if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
|  | ||||
| 		if (run->gbl.ofs.ptr != QSE_NULL) | ||||
| 			QSE_AWK_FREE (run->awk, run->gbl.ofs.ptr); | ||||
| 		run->gbl.ofs.ptr = ofs_ptr; | ||||
| 		run->gbl.ofs.len = ofs_len; | ||||
| 		run->gbl.ofs.ptr = out.u.cpldup.ptr; | ||||
| 		run->gbl.ofs.len = out.u.cpldup.len; | ||||
| 	} | ||||
| 	else if (idx == QSE_AWK_GBL_ORS) | ||||
| 	{	 | ||||
| 		qse_char_t* ors_ptr; | ||||
| 		qse_size_t ors_len; | ||||
| 		qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 		ors_ptr = qse_awk_rtx_valtostr ( | ||||
| 			run, val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &ors_len); | ||||
| 		if (ors_ptr == QSE_NULL) return  -1; | ||||
| 		out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 		if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
|  | ||||
| 		if (run->gbl.ors.ptr != QSE_NULL) | ||||
| 			QSE_AWK_FREE (run->awk, run->gbl.ors.ptr); | ||||
| 		run->gbl.ors.ptr = ors_ptr; | ||||
| 		run->gbl.ors.len = ors_len; | ||||
| 		run->gbl.ors.ptr = out.u.cpldup.ptr; | ||||
| 		run->gbl.ors.len = out.u.cpldup.len; | ||||
| 	} | ||||
| 	else if (idx == QSE_AWK_GBL_RS) | ||||
| 	{ | ||||
| @ -501,13 +499,16 @@ static int set_global ( | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 			/* due to the expression evaluation rule, the  | ||||
| 			 * regular expression can not be an assigned value */ | ||||
| 			QSE_ASSERT (val->type != QSE_AWK_VAL_REX); | ||||
|  | ||||
| 			rs_ptr = qse_awk_rtx_valtostr ( | ||||
| 				run, val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &rs_len); | ||||
| 			if (rs_ptr == QSE_NULL) return -1; | ||||
| 			out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 			if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
| 			rs_ptr = out.u.cpldup.ptr; | ||||
| 			rs_len = out.u.cpldup.len; | ||||
| 		} | ||||
|  | ||||
| 		if (rs_len > 1) | ||||
| @ -536,17 +537,15 @@ static int set_global ( | ||||
| 	} | ||||
| 	else if (idx == QSE_AWK_GBL_SUBSEP) | ||||
| 	{ | ||||
| 		qse_char_t* subsep_ptr; | ||||
| 		qse_size_t subsep_len; | ||||
| 		qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 		subsep_ptr = qse_awk_rtx_valtostr ( | ||||
| 			run, val, QSE_AWK_RTX_VALTOSTR_CLEAR, QSE_NULL, &subsep_len); | ||||
| 		if (subsep_ptr == QSE_NULL) return  -1; | ||||
| 		out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 		if (qse_awk_rtx_valtostr (run, val, &out) == QSE_NULL) return -1; | ||||
|  | ||||
| 		if (run->gbl.subsep.ptr != QSE_NULL) | ||||
| 			QSE_AWK_FREE (run->awk, run->gbl.subsep.ptr); | ||||
| 		run->gbl.subsep.ptr = subsep_ptr; | ||||
| 		run->gbl.subsep.len = subsep_len; | ||||
| 		run->gbl.subsep.ptr = out.u.cpldup.ptr; | ||||
| 		run->gbl.subsep.len = out.u.cpldup.len; | ||||
| 	} | ||||
|  | ||||
| 	qse_awk_rtx_refdownval (run, old); | ||||
| @ -2562,6 +2561,7 @@ static int run_delete (qse_awk_rtx_t* run, qse_awk_nde_delete_t* nde) | ||||
| 				qse_size_t keylen; | ||||
| 				qse_awk_val_t* idx; | ||||
| 				qse_char_t buf[IDXBUFSIZE]; | ||||
| 				qse_awk_rtx_valtostr_out_t out; | ||||
|  | ||||
| 				QSE_ASSERT (var->idx != QSE_NULL); | ||||
|  | ||||
| @ -2571,16 +2571,16 @@ static int run_delete (qse_awk_rtx_t* run, qse_awk_nde_delete_t* nde) | ||||
| 				qse_awk_rtx_refupval (run, idx); | ||||
|  | ||||
| 				/* try with a fixed-size buffer */ | ||||
| 				keylen = QSE_COUNTOF(buf); | ||||
| 				key = qse_awk_rtx_valtostr ( | ||||
| 					run, idx, QSE_AWK_RTX_VALTOSTR_FIXED,  | ||||
| 					(qse_str_t*)buf, &keylen); | ||||
| 				out.type = QSE_AWK_RTX_VALTOSTR_CPL; | ||||
| 				out.u.cpl.ptr = buf; | ||||
| 				out.u.cpl.len = QSE_COUNTOF(buf); | ||||
| 				 | ||||
| 				key = qse_awk_rtx_valtostr (run, idx, &out); | ||||
| 				if (key == QSE_NULL) | ||||
| 				{ | ||||
| 					/* if it doesn't work, switch to dynamic mode */ | ||||
| 					key = qse_awk_rtx_valtostr ( | ||||
| 						run, idx, QSE_AWK_RTX_VALTOSTR_CLEAR, | ||||
| 						QSE_NULL, &keylen); | ||||
| 					out.type = QSE_AWK_RTX_VALTOSTR_CPLDUP; | ||||
| 					key = qse_awk_rtx_valtostr (run, idx, &out); | ||||
| 				} | ||||
|  | ||||
| 				qse_awk_rtx_refdownval (run, idx); | ||||
| @ -2592,8 +2592,15 @@ static int run_delete (qse_awk_rtx_t* run, qse_awk_nde_delete_t* nde) | ||||
| 					return -1; | ||||
| 				} | ||||
|  | ||||
| 				if (out.type == QSE_AWK_RTX_VALTOSTR_CPL) | ||||
| 					keylen = out.u.cpl.len; | ||||
| 				else | ||||
| 					keylen = out.u.cpldup.len; | ||||
|  | ||||
| 				qse_map_delete (map, key, keylen); | ||||
| 				if (key != buf) QSE_AWK_FREE (run->awk, key); | ||||
|  | ||||
| 				if (out.type == QSE_AWK_RTX_VALTOSTR_CPLDUP) | ||||
| 					QSE_AWK_FREE (run->awk, out.u.cpldup.ptr); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
|  | ||||
| @ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * $Id: val.c 87 2009-02-28 02:18:00Z hyunghwan.chung $ | ||||
|  * $Id: val.c 88 2009-02-28 08:44:21Z hyunghwan.chung $ | ||||
|  * | ||||
|    Copyright 2006-2009 Chung, Hyung-Hwan. | ||||
|  | ||||
| @ -741,319 +741,381 @@ how to handle CLEAR... | ||||
|  | ||||
| static qse_char_t* str_to_str ( | ||||
| 	qse_awk_rtx_t* rtx, const qse_char_t* str, qse_size_t str_len, | ||||
| 	qse_awk_valtostr_out_t* out); | ||||
| 	qse_awk_rtx_valtostr_out_t* out) | ||||
| { | ||||
| 	switch (out->type) | ||||
| 	int type = out->type & ~QSE_AWK_RTX_VALTOSTR_PRINT; | ||||
|  | ||||
| 	switch (type) | ||||
| 	{ | ||||
| 		case QSE_AWK_VALTOSTR_CPL: | ||||
| 		case QSE_AWK_RTX_VALTOSTR_CPL: | ||||
| 		{ | ||||
| 			QSE_ASSERT (buf != QSE_NULL && len != QSE_NULL); | ||||
|  | ||||
| 			if (str_len >= out.u.cpl.len) | ||||
| 			if (str_len >= out->u.cpl.len) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror (rtx, QSE_AWK_EINVAL, 0, QSE_NULL); | ||||
| 				*len = str_len + 1; | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 				out->u.cpl.len = str_len + 1; | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			out->u.cpl.len = qse_strncpy (out->u.cpl.ptr, str, str_len); | ||||
| 			return (qse_char_t*)buf; | ||||
| 			out->u.cpl.len =  | ||||
| 				qse_strncpy (out->u.cpl.ptr, str, str_len); | ||||
| 			return out->u.cpl.ptr; | ||||
| 		} | ||||
|  | ||||
| 		case QSE_AWK_VALTOSTR_STR: | ||||
| 		{ | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 			qse_str_clear (buf); | ||||
| 			n = qse_str_ncat (out->u.cpl.str, str, str_len); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror (rtx, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			return QSE_STR_PTR(buf); | ||||
| 		} | ||||
|  | ||||
| 		case QSE_AWK_VALTOSTR_CAT: | ||||
| 		{ | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 			n = qse_str_ncat (out->u.cpl.str, str, str_len); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror (rtx, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			return QSE_STR_PTR(buf); | ||||
| 		} | ||||
|  | ||||
| 		case QSE_AWK_VALTOSTR_NEW: | ||||
| 		case QSE_AWK_RTX_VALTOSTR_CPLDUP: | ||||
| 		{ | ||||
| 			qse_char_t* tmp; | ||||
|  | ||||
| 			tmp = QSE_AWK_STRXDUP (rtx->awk, str, str_len); | ||||
| 			if (tmp == QSE_NULL)  | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror (rtx, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			if (len != QSE_NULL) *len = str_len; | ||||
| 			out->u.cpldup.ptr = tmp; | ||||
| 			out->u.cpldup.len = str_len; | ||||
| 			return tmp; | ||||
| 		} | ||||
| 			 | ||||
| 		case QSE_AWK_RTX_VALTOSTR_STRP: | ||||
| 		{ | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 			qse_str_clear (out->u.strp); | ||||
| 			n = qse_str_ncat (out->u.strp, str, str_len); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			return QSE_STR_PTR(out->u.strp); | ||||
| 		} | ||||
|  | ||||
| 		case QSE_AWK_RTX_VALTOSTR_STRPCAT: | ||||
| 		{ | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 			n = qse_str_ncat (out->u.strpcat, str, str_len); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			return QSE_STR_PTR(out->u.strpcat); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	qse_awk_rtx_seterror (rtx, QSE_AWK_EINVAL, 0, QSE_NULL); | ||||
| 	return ASE_NULL; | ||||
| 	qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 	return QSE_NULL; | ||||
| } | ||||
|  | ||||
| static qse_char_t* val_int_to_str ( | ||||
| 	qse_awk_rtx_t* run, qse_awk_val_int_t* v, | ||||
| 	int opt, qse_str_t* buf, qse_size_t* len) | ||||
| 	qse_awk_rtx_t* rtx, qse_awk_val_int_t* v, | ||||
| 	qse_awk_rtx_valtostr_out_t* out) | ||||
| { | ||||
| 	qse_char_t* tmp; | ||||
| 	qse_long_t t; | ||||
| 	qse_size_t rlen = 0; | ||||
| 	int type = out->type & ~QSE_AWK_RTX_VALTOSTR_PRINT; | ||||
|  | ||||
| 	t = v->val;  | ||||
| 	if (t == 0) | ||||
| 	{ | ||||
| 		/* handle zero */ | ||||
| 		if (buf == QSE_NULL) | ||||
| 		switch (type) | ||||
| 		{ | ||||
| 			tmp = QSE_AWK_ALLOC ( | ||||
| 				run->awk, 2 * QSE_SIZEOF(qse_char_t)); | ||||
| 			if (tmp == QSE_NULL) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror ( | ||||
| 					run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
| 			case QSE_AWK_RTX_VALTOSTR_CPL: | ||||
| 				if (out->u.cpl.len <= 1) | ||||
| 				{ | ||||
| 					qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 					/* store the buffer size needed */ | ||||
| 					out->u.cpl.len = 2;  | ||||
| 					return QSE_NULL; | ||||
| 				} | ||||
|  | ||||
| 			tmp[0] = QSE_T('0'); | ||||
| 			tmp[1] = QSE_T('\0'); | ||||
| 			if (len != QSE_NULL) *len = 1; | ||||
| 			return tmp; | ||||
| 		} | ||||
| 		else if (opt & QSE_AWK_RTX_VALTOSTR_FIXED) | ||||
| 		{ | ||||
| 			QSE_ASSERT (buf != QSE_NULL && len != QSE_NULL); | ||||
| 	 | ||||
| 			if (1 >= *len) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror ( | ||||
| 					run, QSE_AWK_EINVAL, 0, QSE_NULL); | ||||
| 				*len = 2; /* buffer size required */ | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
| 				out->u.cpl.len = 1; /* actual length */ | ||||
| 				out->u.cpl.ptr[0] = QSE_T('0'); | ||||
| 				out->u.cpl.ptr[1] = QSE_T('\0'); | ||||
| 				return out->u.cpl.ptr; | ||||
|  | ||||
| 			tmp = (qse_char_t*)buf; | ||||
| 			tmp[0] = QSE_T('0'); | ||||
| 			tmp[1] = QSE_T('\0'); | ||||
| 			*len = 1; /* actual length */ | ||||
| 			return tmp; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			if (opt & QSE_AWK_RTX_VALTOSTR_CLEAR) qse_str_clear (buf); | ||||
| 			if (qse_str_cat (buf, QSE_T("0")) == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterror ( | ||||
| 					run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
| 			case QSE_AWK_RTX_VALTOSTR_CPLDUP: | ||||
| 				tmp = QSE_AWK_ALLOC ( | ||||
| 					rtx->awk, 2 * QSE_SIZEOF(qse_char_t)); | ||||
| 				if (tmp == QSE_NULL) | ||||
| 				{ | ||||
| 					qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 					return QSE_NULL; | ||||
| 				} | ||||
|  | ||||
| 			if (len != QSE_NULL) *len = QSE_STR_LEN(buf); | ||||
| 			return QSE_STR_PTR(buf); | ||||
| 				tmp[0] = QSE_T('0'); | ||||
| 				tmp[1] = QSE_T('\0'); | ||||
| 				 | ||||
| 				out->u.cpldup.ptr = tmp; | ||||
| 				out->u.cpldup.len = 1; /* actual length */ | ||||
| 				return out->u.cpldup.ptr; | ||||
|  | ||||
| 			case QSE_AWK_RTX_VALTOSTR_STRP: | ||||
| 				qse_str_clear (out->u.strp); | ||||
| 				if (qse_str_ccat (out->u.strp, QSE_T('0')) == (qse_size_t)-1) | ||||
| 				{ | ||||
| 					qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 					return QSE_NULL; | ||||
| 				} | ||||
| 				return QSE_STR_PTR(out->u.strp); | ||||
|  | ||||
| 			case QSE_AWK_RTX_VALTOSTR_STRPCAT: | ||||
| 				if (qse_str_ccat (out->u.strpcat, QSE_T('0')) == (qse_size_t)-1) | ||||
| 				{ | ||||
| 					qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 					return QSE_NULL; | ||||
| 				} | ||||
| 				return QSE_STR_PTR(out->u.strpcat); | ||||
| 		} | ||||
|  | ||||
| 		qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 		return QSE_NULL; | ||||
| 	} | ||||
|  | ||||
| 	/* non-zero values */ | ||||
| 	if (t < 0) { t = -t; rlen++; } | ||||
| 	while (t > 0) { rlen++; t /= 10; } | ||||
|  | ||||
| 	if (buf == QSE_NULL) | ||||
| 	switch (type) | ||||
| 	{ | ||||
| 		tmp = QSE_AWK_ALLOC ( | ||||
| 			run->awk, (rlen + 1) * QSE_SIZEOF(qse_char_t)); | ||||
| 		if (tmp == QSE_NULL) | ||||
| 		case QSE_AWK_RTX_VALTOSTR_CPL: | ||||
| 			if (rlen >= out->u.cpl.len) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 				/* store the buffer size needed */ | ||||
| 				out->u.cpl.len = rlen + 1;  | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			tmp = out->u.cpl.ptr; | ||||
| 			tmp[rlen] = QSE_T('\0'); | ||||
| 			out->u.cpl.len = rlen; | ||||
| 			break; | ||||
|  | ||||
| 		case QSE_AWK_RTX_VALTOSTR_CPLDUP: | ||||
| 			tmp = QSE_AWK_ALLOC ( | ||||
| 				rtx->awk, (rlen + 1) * QSE_SIZEOF(qse_char_t)); | ||||
| 			if (tmp == QSE_NULL) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			tmp[rlen] = QSE_T('\0'); | ||||
| 			out->u.cpldup.ptr = tmp; | ||||
| 			out->u.cpldup.len = rlen; | ||||
| 			break; | ||||
|  | ||||
| 		case QSE_AWK_RTX_VALTOSTR_STRP: | ||||
| 		{ | ||||
| 			qse_awk_rtx_seterror (run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 			return QSE_NULL; | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 			qse_str_clear (out->u.strp); | ||||
| 			QSE_ASSERT (QSE_STR_LEN(out->u.strp) == 0); | ||||
|  | ||||
| 			/* point to the beginning of the buffer */ | ||||
| 			tmp = QSE_STR_PTR(out->u.strp); | ||||
|  | ||||
| 			/* extend the buffer */ | ||||
| 			n = qse_str_nccat (out->u.strp, QSE_T(' '), rlen); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
| 			break; | ||||
| 		} | ||||
|  | ||||
| 		tmp[rlen] = QSE_T('\0'); | ||||
| 		if (len != QSE_NULL) *len = rlen; | ||||
| 	} | ||||
| 	else if (opt & QSE_AWK_RTX_VALTOSTR_FIXED) | ||||
| 	{ | ||||
| 		QSE_ASSERT (buf != QSE_NULL && len != QSE_NULL); | ||||
|  | ||||
| 		if (rlen >= *len) | ||||
| 		case QSE_AWK_RTX_VALTOSTR_STRPCAT: | ||||
| 		{ | ||||
| 			qse_awk_rtx_seterror (run, QSE_AWK_EINVAL, 0, QSE_NULL); | ||||
| 			*len = rlen + 1; /* buffer size required */ | ||||
| 			return QSE_NULL; | ||||
| 		} | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 		tmp = (qse_char_t*)buf; | ||||
| 		tmp[rlen] = QSE_T('\0'); | ||||
| 		*len = rlen; /* actual length */ | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		/* clear the buffer */ | ||||
| 		if (opt & QSE_AWK_RTX_VALTOSTR_CLEAR) qse_str_clear (buf); | ||||
| 			/* point to the insertion point */ | ||||
| 			tmp = QSE_STR_PTR(out->u.strpcat) + QSE_STR_LEN(out->u.strpcat); | ||||
|  | ||||
| 		tmp = QSE_STR_PTR(buf) + QSE_STR_LEN(buf); | ||||
|  | ||||
| 		/* extend the buffer */ | ||||
| 		if (qse_str_nccat ( | ||||
| 			buf, QSE_T(' '), rlen) == (qse_size_t)-1) | ||||
| 		{ | ||||
| 			qse_awk_rtx_seterror ( | ||||
| 				run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 			return QSE_NULL; | ||||
| 			/* extend the buffer */ | ||||
| 			n = qse_str_nccat (out->u.strpcat, QSE_T(' '), rlen); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
| 			break; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	t = v->val;  | ||||
| 	if (t < 0) t = -t; | ||||
|  | ||||
| 	/* fill in the buffer with digits */ | ||||
| 	while (t > 0)  | ||||
| 	{ | ||||
| 		tmp[--rlen] = (qse_char_t)(t % 10) + QSE_T('0'); | ||||
| 		t /= 10; | ||||
| 	} | ||||
|  | ||||
| 	/* insert the negative sign if necessary */ | ||||
| 	if (v->val < 0) tmp[--rlen] = QSE_T('-'); | ||||
|  | ||||
| 	if (buf != QSE_NULL && !(opt & QSE_AWK_RTX_VALTOSTR_FIXED)) | ||||
| 	if (type == QSE_AWK_RTX_VALTOSTR_STRPCAT) | ||||
| 	{ | ||||
| 		tmp = QSE_STR_PTR(buf); | ||||
| 		if (len != QSE_NULL) *len = QSE_STR_LEN(buf); | ||||
| 		/* for concatenation type, change tmp to | ||||
| 		 * point to the buffer */ | ||||
| 		tmp = QSE_STR_PTR(out->u.strpcat); | ||||
| 	} | ||||
|  | ||||
| 	return tmp; | ||||
| } | ||||
|  | ||||
| static qse_char_t* val_real_to_str ( | ||||
| 	qse_awk_rtx_t* run, qse_awk_val_real_t* v, | ||||
| 	int opt, qse_str_t* buf, qse_size_t* len) | ||||
| 	qse_awk_rtx_t* rtx, qse_awk_val_real_t* v, | ||||
| 	qse_awk_rtx_valtostr_out_t* out) | ||||
| { | ||||
| 	qse_char_t* tmp; | ||||
| 	qse_size_t tmp_len; | ||||
| 	qse_str_t out, fbu; | ||||
| 	qse_str_t buf, fbu; | ||||
| 	int type = out->type & ~QSE_AWK_RTX_VALTOSTR_PRINT; | ||||
|  | ||||
| 	if (opt & QSE_AWK_RTX_VALTOSTR_PRINT) | ||||
| 	if (out->type & QSE_AWK_RTX_VALTOSTR_PRINT) | ||||
| 	{ | ||||
| 		tmp = run->gbl.ofmt.ptr; | ||||
| 		tmp_len = run->gbl.ofmt.len; | ||||
| 		tmp = rtx->gbl.ofmt.ptr; | ||||
| 		tmp_len = rtx->gbl.ofmt.len; | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		tmp = run->gbl.convfmt.ptr; | ||||
| 		tmp_len = run->gbl.convfmt.len; | ||||
| 		tmp = rtx->gbl.convfmt.ptr; | ||||
| 		tmp_len = rtx->gbl.convfmt.len; | ||||
| 	} | ||||
|  | ||||
| 	if (qse_str_init (&out, run->awk->mmgr, 256) == QSE_NULL) | ||||
| 	if (qse_str_init (&buf, rtx->awk->mmgr, 256) == QSE_NULL) | ||||
| 	{ | ||||
| 		qse_awk_rtx_seterror (run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 		qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 		return QSE_NULL; | ||||
| 	} | ||||
|  | ||||
| 	if (qse_str_init (&fbu, run->awk->mmgr, 256) == QSE_NULL) | ||||
| 	if (qse_str_init (&fbu, rtx->awk->mmgr, 256) == QSE_NULL) | ||||
| 	{ | ||||
| 		qse_str_fini (&out); | ||||
| 		qse_awk_rtx_seterror (run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 		qse_str_fini (&buf); | ||||
| 		qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 		return QSE_NULL; | ||||
| 	} | ||||
|  | ||||
| 	tmp = qse_awk_rtx_format (run, &out, &fbu, tmp, tmp_len,  | ||||
| 	tmp = qse_awk_rtx_format (rtx, &buf, &fbu, tmp, tmp_len,  | ||||
| 		(qse_size_t)-1, (qse_awk_nde_t*)v, &tmp_len); | ||||
| 	if (tmp == QSE_NULL)  | ||||
| 	{ | ||||
| 		qse_str_fini (&fbu); | ||||
| 		qse_str_fini (&out); | ||||
| 		qse_str_fini (&buf); | ||||
| 		return QSE_NULL; | ||||
| 	} | ||||
|  | ||||
| 	if (buf == QSE_NULL)  | ||||
| 	switch (type) | ||||
| 	{ | ||||
| 		qse_str_fini (&fbu); | ||||
| 		case QSE_AWK_RTX_VALTOSTR_CPL: | ||||
|  | ||||
| 		qse_str_yield (&out, QSE_NULL, 0); | ||||
| 		qse_str_fini (&out); | ||||
| 			if (out->u.cpl.len <= tmp_len) | ||||
| 			{ | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 				/* store the buffer size required */ | ||||
| 				out->u.cpl.len = tmp_len + 1;  | ||||
| 				qse_str_close (&fbu); | ||||
| 				qse_str_close (&buf); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 		if (len != QSE_NULL) *len = tmp_len; | ||||
| 	} | ||||
| 	else if (opt & QSE_AWK_RTX_VALTOSTR_FIXED) | ||||
| 	{ | ||||
| 		QSE_ASSERT (buf != QSE_NULL && len != QSE_NULL); | ||||
| 			qse_strncpy (out->u.cpl.ptr, tmp, tmp_len); | ||||
| 			out->u.cpl.len = tmp_len; | ||||
| 			tmp = out->u.cpl.ptr; | ||||
|  | ||||
| 		if (tmp_len >= *len) | ||||
| 		{ | ||||
| 			qse_awk_rtx_seterror ( | ||||
| 				run, QSE_AWK_EINVAL, 0, QSE_NULL); | ||||
| 			*len = tmp_len + 1; /* buffer size required */ | ||||
| 			qse_str_close (&fbu); | ||||
| 			qse_str_close (&out); | ||||
| 			return QSE_NULL; | ||||
| 		} | ||||
|  | ||||
| 		qse_strncpy ((qse_char_t*)buf, tmp, tmp_len); | ||||
| 		tmp = (qse_char_t*)buf; | ||||
| 		*len = tmp_len; | ||||
|  | ||||
| 		qse_str_fini (&fbu); | ||||
| 		qse_str_fini (&out); | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		if (opt & QSE_AWK_RTX_VALTOSTR_CLEAR) qse_str_clear (buf); | ||||
|  | ||||
| 		if (qse_str_ncat (buf, tmp, tmp_len) == (qse_size_t)-1) | ||||
| 		{ | ||||
| 			qse_str_fini (&fbu); | ||||
| 			qse_str_fini (&out); | ||||
| 			qse_awk_rtx_seterror ( | ||||
| 				run, QSE_AWK_ENOMEM, 0, QSE_NULL); | ||||
| 			return QSE_NULL; | ||||
| 			qse_str_fini (&buf); | ||||
| 			return tmp; | ||||
|  | ||||
| 		case QSE_AWK_RTX_VALTOSTR_CPLDUP: | ||||
| 			qse_str_fini (&fbu); | ||||
|  | ||||
| 			qse_str_yield (&buf, QSE_NULL, 0); | ||||
| 			qse_str_fini (&buf); | ||||
|  | ||||
| 			out->u.cpldup.ptr = tmp; | ||||
| 			out->u.cpldup.len = tmp_len; | ||||
| 			return tmp; | ||||
|  | ||||
| 		case QSE_AWK_RTX_VALTOSTR_STRP: | ||||
| 		{ | ||||
| 			qse_size_t n; | ||||
|  | ||||
| 			qse_str_clear (out->u.strp); | ||||
|  | ||||
| 			n = qse_str_ncat (out->u.strp, tmp, tmp_len); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_str_fini (&fbu); | ||||
| 				qse_str_fini (&buf); | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 			tmp = QSE_STR_PTR(out->u.strp); | ||||
|  | ||||
| 			qse_str_fini (&fbu); | ||||
| 			qse_str_fini (&buf); | ||||
| 			return tmp; | ||||
| 		} | ||||
|  | ||||
| 		tmp = QSE_STR_PTR(buf); | ||||
| 		if (len != QSE_NULL) *len = QSE_STR_LEN(buf); | ||||
| 		case QSE_AWK_RTX_VALTOSTR_STRPCAT: | ||||
| 		{ | ||||
| 			qse_size_t n; | ||||
| 	 | ||||
| 			n = qse_str_ncat (out->u.strpcat, tmp, tmp_len); | ||||
| 			if (n == (qse_size_t)-1) | ||||
| 			{ | ||||
| 				qse_str_fini (&fbu); | ||||
| 				qse_str_fini (&buf); | ||||
| 				qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM); | ||||
| 				return QSE_NULL; | ||||
| 			} | ||||
|  | ||||
| 		qse_str_fini (&fbu); | ||||
| 		qse_str_fini (&out); | ||||
| 			tmp = QSE_STR_PTR(out->u.strpcat); | ||||
|  | ||||
| 			qse_str_fini (&fbu); | ||||
| 			qse_str_fini (&buf); | ||||
| 			return tmp; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return tmp; | ||||
| 	qse_str_fini (&fbu); | ||||
| 	qse_str_fini (&buf); | ||||
| 	qse_awk_rtx_seterrnum (rtx, QSE_AWK_EINVAL); | ||||
| 	return QSE_NULL; | ||||
| } | ||||
|  | ||||
| qse_char_t* qse_awk_rtx_valtostr ( | ||||
| 	qse_awk_rtx_t* run, qse_awk_val_t* v,  | ||||
| 	qse_awk_rtx_valtostr_opt_t opt, qse_awk_rtx_valtostr_out_t* out) | ||||
| 	qse_awk_rtx_t* rtx, qse_awk_val_t* v, qse_awk_rtx_valtostr_out_t* out) | ||||
| { | ||||
| 	switch (v->type) | ||||
| 	{ | ||||
| 		case QSE_AWK_VAL_NIL: | ||||
| 			return str_to_str (run, QSE_T(""), 0, opt, buf, len); | ||||
| 			return str_to_str (rtx, QSE_T(""), 0, out); | ||||
|  | ||||
| 		case QSE_AWK_VAL_INT: | ||||
| 			return val_int_to_str ( | ||||
| 				run, (qse_awk_val_int_t*)vi, opt, buf, len); | ||||
| 				rtx, (qse_awk_val_int_t*)v, out); | ||||
|  | ||||
| 		case QSE_AWK_VAL_REAL: | ||||
| 			return val_real_to_str ( | ||||
| 				run, (qse_awk_val_real_t*)v, opt, buf, len); | ||||
| 				rtx, (qse_awk_val_real_t*)v, out); | ||||
|  | ||||
| 		case QSE_AWK_VAL_STR: | ||||
| 		{ | ||||
| 			qse_awk_val_str_t* vs = (qse_awk_val_str_t*)v; | ||||
| 			return str_to_str ( | ||||
| 				run, vs->ptr, vs->len, opt, buf, len); | ||||
| 			return str_to_str (rtx, vs->ptr, vs->len, out); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @ -1063,11 +1125,10 @@ qse_char_t* qse_awk_rtx_valtostr ( | ||||
| 		v->type); | ||||
| #endif | ||||
|  | ||||
| 	qse_awk_rtx_seterror (run, QSE_AWK_EVALTYPE, 0, QSE_NULL); | ||||
| 	qse_awk_rtx_seterrnum (rtx, QSE_AWK_EVALTYPE); | ||||
| 	return QSE_NULL; | ||||
| } | ||||
|  | ||||
|  | ||||
| int qse_awk_rtx_valtonum ( | ||||
| 	qse_awk_rtx_t* run, qse_awk_val_t* v, qse_long_t* l, qse_real_t* r) | ||||
| { | ||||
|  | ||||
		Reference in New Issue
	
	Block a user