| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-08-16 03:47:55 +00:00
										 |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-07-20 04:13:39 +00:00
										 |  |  |     Copyright 2006-2012 Chung, Hyung-Hwan. | 
					
						
							| 
									
										
										
										
											2009-09-16 04:01:02 +00:00
										 |  |  |     This file is part of QSE. | 
					
						
							| 
									
										
										
										
											2008-12-27 04:35:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 04:01:02 +00:00
										 |  |  |     QSE is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |     it under the terms of the GNU Lesser General Public License as  | 
					
						
							|  |  |  |     published by the Free Software Foundation, either version 3 of  | 
					
						
							|  |  |  |     the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2008-12-27 04:35:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 04:01:02 +00:00
										 |  |  |     QSE is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |     but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |     GNU Lesser General Public License for more details. | 
					
						
							| 
									
										
										
										
											2008-12-27 04:35:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 04:01:02 +00:00
										 |  |  |     You should have received a copy of the GNU Lesser General Public  | 
					
						
							|  |  |  |     License along with QSE. If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-21 03:17:25 +00:00
										 |  |  | #include "awk.h"
 | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | void* qse_awk_allocmem (qse_awk_t* awk, qse_size_t size) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | 	void* ptr = QSE_AWK_ALLOC (awk, size); | 
					
						
							| 
									
										
										
										
											2012-10-28 14:46:37 +00:00
										 |  |  | 	if (ptr == QSE_NULL) qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void* qse_awk_callocmem (qse_awk_t* awk, qse_size_t size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	void* ptr = QSE_AWK_ALLOC (awk, size); | 
					
						
							|  |  |  | 	if (ptr) QSE_MEMSET (ptr, 0, size); | 
					
						
							|  |  |  | 	else qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | 	return ptr; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | void* qse_awk_reallocmem (qse_awk_t* awk, void* ptr, qse_size_t size) | 
					
						
							| 
									
										
										
										
											2009-07-02 07:14:39 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | 	void* nptr = QSE_AWK_REALLOC (awk, ptr, size); | 
					
						
							|  |  |  | 	if (nptr == QSE_NULL) qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return nptr; | 
					
						
							| 
									
										
										
										
											2009-07-02 07:14:39 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | void qse_awk_freemem (qse_awk_t* awk, void* ptr) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	QSE_AWK_FREE (awk, ptr); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | qse_char_t* qse_awk_strdup (qse_awk_t* awk, const qse_char_t* s) | 
					
						
							| 
									
										
										
										
											2007-05-11 10:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | 	qse_char_t* ptr = QSE_AWK_STRDUP (awk, s); | 
					
						
							|  |  |  | 	if (ptr == QSE_NULL) qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							| 
									
										
										
										
											2008-07-20 23:53:29 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | qse_char_t* qse_awk_strxdup (qse_awk_t* awk, const qse_char_t* s, qse_size_t l) | 
					
						
							| 
									
										
										
										
											2008-07-20 23:53:29 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | 	qse_char_t* ptr = QSE_AWK_STRXDUP (awk, s, l); | 
					
						
							|  |  |  | 	if (ptr == QSE_NULL) qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							| 
									
										
										
										
											2007-05-11 10:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-28 14:46:37 +00:00
										 |  |  | qse_char_t* qse_awk_cstrdup (qse_awk_t* awk, const qse_cstr_t* s) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	qse_char_t* ptr = qse_cstrdup (s, awk->mmgr); | 
					
						
							|  |  |  | 	if (ptr == QSE_NULL) qse_awk_seterrnum (awk, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | qse_long_t qse_awk_strxtolong ( | 
					
						
							|  |  |  | 	qse_awk_t* awk, const qse_char_t* str, qse_size_t len, | 
					
						
							|  |  |  | 	int base, const qse_char_t** endptr) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	qse_long_t n = 0; | 
					
						
							|  |  |  | 	const qse_char_t* p; | 
					
						
							|  |  |  | 	const qse_char_t* end; | 
					
						
							|  |  |  | 	qse_size_t rem; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	int digit, negative = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	QSE_ASSERT (base < 37);  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	p = str;  | 
					
						
							|  |  |  | 	end = str + len; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-10-21 16:19:03 +00:00
										 |  |  | 	if (awk->opt.trait & QSE_AWK_STRIPSTRSPC) | 
					
						
							| 
									
										
										
										
											2009-07-17 06:43:47 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		/* strip off leading spaces */ | 
					
						
							| 
									
										
										
										
											2009-12-13 07:24:40 +00:00
										 |  |  | 		while (p < end && QSE_AWK_ISSPACE(awk,*p)) p++; | 
					
						
							| 
									
										
										
										
											2009-07-17 06:43:47 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* check for a sign */ | 
					
						
							|  |  |  | 	while (p < end) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p == QSE_T('-'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			negative = ~negative; | 
					
						
							|  |  |  | 			p++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		else if (*p == QSE_T('+')) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		else break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* check for a binary/octal/hexadecimal notation */ | 
					
						
							|  |  |  | 	rem = end - p; | 
					
						
							|  |  |  | 	if (base == 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (rem >= 1 && *p == QSE_T('0'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			p++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (rem == 1) base = 8; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			else if (*p == QSE_T('x') || *p == QSE_T('X')) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				p++; base = 16; | 
					
						
							|  |  |  | 			}  | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			else if (*p == QSE_T('b') || *p == QSE_T('B')) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				p++; base = 2; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else base = 8; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else base = 10; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else if (rem >= 2 && base == 16) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p == QSE_T('0') &&  | 
					
						
							|  |  |  | 		    (*(p+1) == QSE_T('x') || *(p+1) == QSE_T('X'))) p += 2;  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (rem >= 2 && base == 2) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p == QSE_T('0') &&  | 
					
						
							|  |  |  | 		    (*(p+1) == QSE_T('b') || *(p+1) == QSE_T('B'))) p += 2;  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* process the digits */ | 
					
						
							|  |  |  | 	while (p < end) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p >= QSE_T('0') && *p <= QSE_T('9')) | 
					
						
							|  |  |  | 			digit = *p - QSE_T('0'); | 
					
						
							|  |  |  | 		else if (*p >= QSE_T('A') && *p <= QSE_T('Z')) | 
					
						
							|  |  |  | 			digit = *p - QSE_T('A') + 10; | 
					
						
							|  |  |  | 		else if (*p >= QSE_T('a') && *p <= QSE_T('z')) | 
					
						
							|  |  |  | 			digit = *p - QSE_T('a') + 10; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		else break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (digit >= base) break; | 
					
						
							|  |  |  | 		n = n * base + digit; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		p++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-13 07:24:40 +00:00
										 |  |  | 	if (endptr) *endptr = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	return (negative)? -n: n; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  |  * qse_awk_strtoreal is almost a replica of strtod. | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * strtod.c -- | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *      Source code for the "strtod" library procedure. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 1988-1993 The Regents of the University of California. | 
					
						
							|  |  |  |  * Copyright (c) 1994 Sun Microsystems, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Permission to use, copy, modify, and distribute this | 
					
						
							|  |  |  |  * software and its documentation for any purpose and without | 
					
						
							|  |  |  |  * fee is hereby granted, provided that the above copyright | 
					
						
							|  |  |  |  * notice appear in all copies.  The University of California | 
					
						
							|  |  |  |  * makes no representations about the suitability of this | 
					
						
							|  |  |  |  * software for any purpose.  It is provided "as is" without | 
					
						
							|  |  |  |  * express or implied warranty. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MAX_EXPONENT 511
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | qse_flt_t qse_awk_strtoreal (qse_awk_t* awk, const qse_char_t* str) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* 
 | 
					
						
							|  |  |  | 	 * Table giving binary powers of 10. Entry is 10^2^i.   | 
					
						
							|  |  |  | 	 * Used to convert decimal exponents into floating-point numbers. | 
					
						
							|  |  |  | 	 */  | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | 	static qse_flt_t powers_of_10[] =  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		10.,    100.,   1.0e4,   1.0e8,   1.0e16, | 
					
						
							|  |  |  | 		1.0e32, 1.0e64, 1.0e128, 1.0e256 | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | 	qse_flt_t fraction, dbl_exp, * d; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	const qse_char_t* p; | 
					
						
							|  |  |  | 	qse_cint_t c; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	int exp = 0;		/* Esseonent read from "EX" field */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* 
 | 
					
						
							|  |  |  | 	 * Esseonent that derives from the fractional part.  Under normal  | 
					
						
							|  |  |  | 	 * circumstatnces, it is the negative of the number of digits in F. | 
					
						
							|  |  |  | 	 * However, if I is very long, the last digits of I get dropped  | 
					
						
							|  |  |  | 	 * (otherwise a long I with a large negative exponent could cause an | 
					
						
							|  |  |  | 	 * unnecessary overflow on I alone).  In this case, frac_exp is  | 
					
						
							|  |  |  | 	 * incremented one for each dropped digit.  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int frac_exp; | 
					
						
							|  |  |  | 	int mant_size; /* Number of digits in mantissa. */ | 
					
						
							|  |  |  | 	int dec_pt;    /* Number of mantissa digits BEFORE decimal point */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	const qse_char_t *pexp;  /* Temporarily holds location of exponent in string */ | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	int negative = 0, exp_negative = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	p = str; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 16:19:03 +00:00
										 |  |  | 	if (awk->opt.trait & QSE_AWK_STRIPSTRSPC) | 
					
						
							| 
									
										
										
										
											2009-07-17 06:43:47 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		/* strip off leading spaces */  | 
					
						
							|  |  |  | 		while (QSE_AWK_ISSPACE(awk,*p)) p++; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* check for a sign */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	while (*p != QSE_T('\0'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p == QSE_T('-'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			negative = ~negative; | 
					
						
							|  |  |  | 			p++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		else if (*p == QSE_T('+')) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		else break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Count the number of digits in the mantissa (including the decimal
 | 
					
						
							|  |  |  | 	 * point), and also locate the decimal point. */ | 
					
						
							|  |  |  | 	dec_pt = -1; | 
					
						
							|  |  |  | 	for (mant_size = 0; ; mant_size++)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		c = *p; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (!QSE_AWK_ISDIGIT (awk, c))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if ((c != QSE_T('.')) || (dec_pt >= 0)) break; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			dec_pt = mant_size; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		p++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Now suck up the digits in the mantissa.  Use two integers to | 
					
						
							|  |  |  | 	 * collect 9 digits each (this is faster than using floating-point). | 
					
						
							|  |  |  | 	 * If the mantissa has more than 18 digits, ignore the extras, since | 
					
						
							|  |  |  | 	 * they can't affect the value anyway. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	pexp = p; | 
					
						
							|  |  |  | 	p -= mant_size; | 
					
						
							|  |  |  | 	if (dec_pt < 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		dec_pt = mant_size; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		mant_size--;	/* One of the digits was the point */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (mant_size > 18)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		frac_exp = dec_pt - 18; | 
					
						
							|  |  |  | 		mant_size = 18; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		frac_exp = dec_pt - mant_size; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (mant_size == 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		fraction = 0.0; | 
					
						
							|  |  |  | 		/*p = str;*/ | 
					
						
							|  |  |  | 		p = pexp; | 
					
						
							|  |  |  | 		goto done; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int frac1, frac2; | 
					
						
							|  |  |  | 		frac1 = 0; | 
					
						
							|  |  |  | 		for ( ; mant_size > 9; mant_size--)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			c = *p; | 
					
						
							|  |  |  | 			p++; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (c == QSE_T('.'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				c = *p; | 
					
						
							|  |  |  | 				p++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			frac1 = 10 * frac1 + (c - QSE_T('0')); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		frac2 = 0; | 
					
						
							|  |  |  | 		for (; mant_size > 0; mant_size--) { | 
					
						
							|  |  |  | 			c = *p; | 
					
						
							|  |  |  | 			p++; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (c == QSE_T('.'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				c = *p; | 
					
						
							|  |  |  | 				p++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			frac2 = 10*frac2 + (c - QSE_T('0')); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		fraction = (1.0e9 * frac1) + frac2; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Skim off the exponent */ | 
					
						
							|  |  |  | 	p = pexp; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if ((*p == QSE_T('E')) || (*p == QSE_T('e')))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		p++; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p == QSE_T('-'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			exp_negative = 1; | 
					
						
							|  |  |  | 			p++; | 
					
						
							|  |  |  | 		}  | 
					
						
							|  |  |  | 		else  | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (*p == QSE_T('+')) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			exp_negative = 0; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (!QSE_AWK_ISDIGIT (awk, *p))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			/* p = pexp; */ | 
					
						
							|  |  |  | 			/* goto done; */ | 
					
						
							|  |  |  | 			goto no_exp; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		while (QSE_AWK_ISDIGIT (awk, *p))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			exp = exp * 10 + (*p - QSE_T('0')); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			p++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | no_exp: | 
					
						
							|  |  |  | 	if (exp_negative) exp = frac_exp - exp; | 
					
						
							|  |  |  | 	else exp = frac_exp + exp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Generate a floating-point number that represents the exponent. | 
					
						
							|  |  |  | 	 * Do this by processing the exponent one bit at a time to combine | 
					
						
							|  |  |  | 	 * many powers of 2 of 10. Then combine the exponent with the | 
					
						
							|  |  |  | 	 * fraction. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (exp < 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		exp_negative = 1; | 
					
						
							|  |  |  | 		exp = -exp; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else exp_negative = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (exp > MAX_EXPONENT) exp = MAX_EXPONENT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dbl_exp = 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (d = powers_of_10; exp != 0; exp >>= 1, d++)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (exp & 01) dbl_exp *= *d; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (exp_negative) fraction /= dbl_exp; | 
					
						
							|  |  |  | 	else fraction *= dbl_exp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | done: | 
					
						
							|  |  |  | 	return (negative)? -fraction: fraction; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | qse_flt_t qse_awk_strxtoflt ( | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	qse_awk_t* awk, const qse_char_t* str, qse_size_t len,  | 
					
						
							|  |  |  | 	const qse_char_t** endptr) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* 
 | 
					
						
							|  |  |  | 	 * Table giving binary powers of 10. Entry is 10^2^i.   | 
					
						
							|  |  |  | 	 * Used to convert decimal exponents into floating-point numbers. | 
					
						
							|  |  |  | 	 */  | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | 	static qse_flt_t powers_of_10[] =  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		10.,    100.,   1.0e4,   1.0e8,   1.0e16, | 
					
						
							|  |  |  | 		1.0e32, 1.0e64, 1.0e128, 1.0e256 | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | 	qse_flt_t fraction, dbl_exp, * d; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	const qse_char_t* p, * end; | 
					
						
							|  |  |  | 	qse_cint_t c; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	int exp = 0; /* Esseonent read from "EX" field */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* 
 | 
					
						
							|  |  |  | 	 * Esseonent that derives from the fractional part.  Under normal  | 
					
						
							|  |  |  | 	 * circumstatnces, it is the negative of the number of digits in F. | 
					
						
							|  |  |  | 	 * However, if I is very long, the last digits of I get dropped  | 
					
						
							|  |  |  | 	 * (otherwise a long I with a large negative exponent could cause an | 
					
						
							|  |  |  | 	 * unnecessary overflow on I alone).  In this case, frac_exp is  | 
					
						
							|  |  |  | 	 * incremented one for each dropped digit.  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int frac_exp; | 
					
						
							|  |  |  | 	int mant_size; /* Number of digits in mantissa. */ | 
					
						
							|  |  |  | 	int dec_pt;    /* Number of mantissa digits BEFORE decimal point */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	const qse_char_t *pexp;  /* Temporarily holds location of exponent in string */ | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	int negative = 0, exp_negative = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	p = str; | 
					
						
							|  |  |  | 	end = str + len; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Strip off leading blanks and check for a sign */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	/*while (QSE_AWK_ISSPACE(awk,*p)) p++;*/ | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	/*while (*p != QSE_T('\0')) */ | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	while (p < end) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (*p == QSE_T('-'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			negative = ~negative; | 
					
						
							|  |  |  | 			p++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		else if (*p == QSE_T('+')) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		else break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Count the number of digits in the mantissa (including the decimal
 | 
					
						
							|  |  |  | 	 * point), and also locate the decimal point. */ | 
					
						
							|  |  |  | 	dec_pt = -1; | 
					
						
							|  |  |  | 	/*for (mant_size = 0; ; mant_size++) */ | 
					
						
							|  |  |  | 	for (mant_size = 0; p < end; mant_size++)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		c = *p; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (!QSE_AWK_ISDIGIT (awk, c))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (c != QSE_T('.') || dec_pt >= 0) break; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			dec_pt = mant_size; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		p++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Now suck up the digits in the mantissa.  Use two integers to | 
					
						
							|  |  |  | 	 * collect 9 digits each (this is faster than using floating-point). | 
					
						
							|  |  |  | 	 * If the mantissa has more than 18 digits, ignore the extras, since | 
					
						
							|  |  |  | 	 * they can't affect the value anyway. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	pexp = p; | 
					
						
							|  |  |  | 	p -= mant_size; | 
					
						
							|  |  |  | 	if (dec_pt < 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		dec_pt = mant_size; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		mant_size--;	/* One of the digits was the point */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | 	if (mant_size > 18)  /* TODO: is 18 correct for qse_flt_t??? */ | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		frac_exp = dec_pt - 18; | 
					
						
							|  |  |  | 		mant_size = 18; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		frac_exp = dec_pt - mant_size; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (mant_size == 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		fraction = 0.0; | 
					
						
							|  |  |  | 		/*p = str;*/ | 
					
						
							|  |  |  | 		p = pexp; | 
					
						
							|  |  |  | 		goto done; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int frac1, frac2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		frac1 = 0; | 
					
						
							|  |  |  | 		for ( ; mant_size > 9; mant_size--)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			c = *p; | 
					
						
							|  |  |  | 			p++; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (c == QSE_T('.'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				c = *p; | 
					
						
							|  |  |  | 				p++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			frac1 = 10 * frac1 + (c - QSE_T('0')); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		frac2 = 0; | 
					
						
							|  |  |  | 		for (; mant_size > 0; mant_size--) { | 
					
						
							|  |  |  | 			c = *p++; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (c == QSE_T('.'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				c = *p; | 
					
						
							|  |  |  | 				p++; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			frac2 = 10 * frac2 + (c - QSE_T('0')); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		fraction = (1.0e9 * frac1) + frac2; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Skim off the exponent */ | 
					
						
							|  |  |  | 	p = pexp; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (p < end && (*p == QSE_T('E') || *p == QSE_T('e')))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		p++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (p < end)  | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (*p == QSE_T('-'))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				exp_negative = 1; | 
					
						
							|  |  |  | 				p++; | 
					
						
							|  |  |  | 			}  | 
					
						
							|  |  |  | 			else  | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 				if (*p == QSE_T('+')) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				exp_negative = 0; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else exp_negative = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (!(p < end && QSE_AWK_ISDIGIT (awk, *p)))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			/*p = pexp;*/ | 
					
						
							|  |  |  | 			/*goto done;*/ | 
					
						
							|  |  |  | 			goto no_exp; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		while (p < end && QSE_AWK_ISDIGIT (awk, *p))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			exp = exp * 10 + (*p - QSE_T('0')); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			p++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | no_exp: | 
					
						
							|  |  |  | 	if (exp_negative) exp = frac_exp - exp; | 
					
						
							|  |  |  | 	else exp = frac_exp + exp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * Generate a floating-point number that represents the exponent. | 
					
						
							|  |  |  | 	 * Do this by processing the exponent one bit at a time to combine | 
					
						
							|  |  |  | 	 * many powers of 2 of 10. Then combine the exponent with the | 
					
						
							|  |  |  | 	 * fraction. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	if (exp < 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		exp_negative = 1; | 
					
						
							|  |  |  | 		exp = -exp; | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else exp_negative = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (exp > MAX_EXPONENT) exp = MAX_EXPONENT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dbl_exp = 1.0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (d = powers_of_10; exp != 0; exp >>= 1, d++)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (exp & 01) dbl_exp *= *d; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (exp_negative) fraction /= dbl_exp; | 
					
						
							|  |  |  | 	else fraction *= dbl_exp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | done: | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (endptr != QSE_NULL) *endptr = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	return (negative)? -fraction: fraction; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | qse_size_t qse_awk_longtostr ( | 
					
						
							| 
									
										
										
										
											2009-06-25 02:29:33 +00:00
										 |  |  | 	qse_awk_t* awk, qse_long_t value,  | 
					
						
							|  |  |  | 	int radix, const qse_char_t* prefix, qse_char_t* buf, qse_size_t size) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	qse_long_t t, rem; | 
					
						
							|  |  |  | 	qse_size_t len, ret, i; | 
					
						
							|  |  |  | 	qse_size_t prefix_len; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	prefix_len = (prefix != QSE_NULL)? qse_strlen(prefix): 0; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	t = value; | 
					
						
							|  |  |  | 	if (t == 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* zero */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (buf == QSE_NULL)  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			/* if buf is not given, 
 | 
					
						
							|  |  |  | 			 * return the number of bytes required */ | 
					
						
							|  |  |  | 			return prefix_len + 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (size < prefix_len+1)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			/* buffer too small */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			return (qse_size_t)-1; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (i = 0; i < prefix_len; i++) buf[i] = prefix[i]; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		buf[prefix_len] = QSE_T('0'); | 
					
						
							|  |  |  | 		if (size > prefix_len+1) buf[prefix_len+1] = QSE_T('\0'); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		return prefix_len+1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* non-zero values */ | 
					
						
							|  |  |  | 	len = prefix_len; | 
					
						
							|  |  |  | 	if (t < 0) { t = -t; len++; } | 
					
						
							|  |  |  | 	while (t > 0) { len++; t /= radix; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (buf == QSE_NULL) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		/* if buf is not given, return the number of bytes required */ | 
					
						
							|  |  |  | 		return len; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (size < len) return (qse_size_t)-1; /* buffer too small */ | 
					
						
							|  |  |  | 	if (size > len) buf[len] = QSE_T('\0'); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	ret = len; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	t = value; | 
					
						
							|  |  |  | 	if (t < 0) t = -t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (t > 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		rem = t % radix; | 
					
						
							|  |  |  | 		if (rem >= 10) | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			buf[--len] = (qse_char_t)rem + QSE_T('a') - 10; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			buf[--len] = (qse_char_t)rem + QSE_T('0'); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		t /= radix; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (value < 0)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		for (i = 1; i <= prefix_len; i++)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			buf[i] = prefix[i-1]; | 
					
						
							|  |  |  | 			len--; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		buf[--len] = QSE_T('-'); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		for (i = 0; i < prefix_len; i++) buf[i] = prefix[i]; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ret; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | qse_char_t* qse_awk_rtx_strtok ( | 
					
						
							|  |  |  | 	qse_awk_rtx_t* rtx, const qse_char_t* s,  | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	const qse_char_t* delim, qse_cstr_t* tok) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 	return qse_awk_rtx_strxntok ( | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		rtx, s, qse_strlen(s), delim, qse_strlen(delim), tok); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | qse_char_t* qse_awk_rtx_strxtok ( | 
					
						
							|  |  |  | 	qse_awk_rtx_t* rtx, const qse_char_t* s, qse_size_t len, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	const qse_char_t* delim, qse_cstr_t* tok) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 	return qse_awk_rtx_strxntok ( | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		rtx, s, len, delim, qse_strlen(delim), tok); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | qse_char_t* qse_awk_rtx_strntok ( | 
					
						
							|  |  |  | 	qse_awk_rtx_t* rtx, const qse_char_t* s,  | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	const qse_char_t* delim, qse_size_t delim_len, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	qse_cstr_t* tok) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 	return qse_awk_rtx_strxntok ( | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		rtx, s, qse_strlen(s), delim, delim_len, tok); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | qse_char_t* qse_awk_rtx_strxntok ( | 
					
						
							|  |  |  | 	qse_awk_rtx_t* rtx, const qse_char_t* s, qse_size_t len, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	const qse_char_t* delim, qse_size_t delim_len, qse_cstr_t* tok) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	const qse_char_t* p = s, *d; | 
					
						
							|  |  |  | 	const qse_char_t* end = s + len;	 | 
					
						
							|  |  |  | 	const qse_char_t* sp = QSE_NULL, * ep = QSE_NULL; | 
					
						
							|  |  |  | 	const qse_char_t* delim_end = delim + delim_len; | 
					
						
							|  |  |  | 	qse_char_t c;  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	int delim_mode; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define __DELIM_NULL      0
 | 
					
						
							|  |  |  | #define __DELIM_EMPTY     1
 | 
					
						
							|  |  |  | #define __DELIM_SPACES    2
 | 
					
						
							|  |  |  | #define __DELIM_NOSPACES  3
 | 
					
						
							|  |  |  | #define __DELIM_COMPOSITE 4
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (delim == QSE_NULL) delim_mode = __DELIM_NULL; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		delim_mode = __DELIM_EMPTY; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		for (d = delim; d < delim_end; d++)  | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 			if (QSE_AWK_ISSPACE(rtx->awk,*d))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							|  |  |  | 				if (delim_mode == __DELIM_EMPTY) | 
					
						
							|  |  |  | 					delim_mode = __DELIM_SPACES; | 
					
						
							|  |  |  | 				else if (delim_mode == __DELIM_NOSPACES) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					delim_mode = __DELIM_COMPOSITE; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (delim_mode == __DELIM_EMPTY) | 
					
						
							|  |  |  | 					delim_mode = __DELIM_NOSPACES; | 
					
						
							|  |  |  | 				else if (delim_mode == __DELIM_SPACES) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					delim_mode = __DELIM_COMPOSITE; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* TODO: verify the following statement... */ | 
					
						
							|  |  |  | 		if (delim_mode == __DELIM_SPACES &&  | 
					
						
							|  |  |  | 		    delim_len == 1 &&  | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		    delim[0] != QSE_T(' ')) delim_mode = __DELIM_NOSPACES; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	}		 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (delim_mode == __DELIM_NULL)  | 
					
						
							|  |  |  | 	{  | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		/* when QSE_NULL is given as "delim", it trims off the 
 | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		 * leading and trailing spaces characters off the source | 
					
						
							|  |  |  | 		 * string "s" eventually. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 		while (p < end && QSE_AWK_ISSPACE(rtx->awk,*p)) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		while (p < end)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			c = *p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 			if (!QSE_AWK_ISSPACE(rtx->awk,c))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 				if (sp == QSE_NULL) sp = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				ep = p; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			p++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (delim_mode == __DELIM_EMPTY) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* each character in the source string "s" becomes a token. */ | 
					
						
							|  |  |  | 		if (p < end) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			c = *p; | 
					
						
							|  |  |  | 			sp = p; | 
					
						
							|  |  |  | 			ep = p++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if (delim_mode == __DELIM_SPACES)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* each token is delimited by space characters. all leading
 | 
					
						
							|  |  |  | 		 * and trailing spaces are removed. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 		while (p < end && QSE_AWK_ISSPACE(rtx->awk,*p)) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		while (p < end)  | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			c = *p; | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 			if (QSE_AWK_ISSPACE(rtx->awk,c)) break; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			if (sp == QSE_NULL) sp = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			ep = p++; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 		while (p < end && QSE_AWK_ISSPACE(rtx->awk,*p)) p++; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (delim_mode == __DELIM_NOSPACES) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* each token is delimited by one of charaters 
 | 
					
						
							|  |  |  | 		 * in the delimeter set "delim". */ | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 		if (rtx->gbl.ignorecase) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			while (p < end)  | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 				c = QSE_AWK_TOUPPER(rtx->awk, *p); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				for (d = delim; d < delim_end; d++)  | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 					if (c == QSE_AWK_TOUPPER(rtx->awk,*d)) goto exit_loop; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 				if (sp == QSE_NULL) sp = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				ep = p++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			while (p < end)  | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				c = *p; | 
					
						
							|  |  |  | 				for (d = delim; d < delim_end; d++)  | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					if (c == *d) goto exit_loop; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 				if (sp == QSE_NULL) sp = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				ep = p++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else /* if (delim_mode == __DELIM_COMPOSITE) */  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* each token is delimited by one of non-space charaters
 | 
					
						
							|  |  |  | 		 * in the delimeter set "delim". however, all space characters | 
					
						
							|  |  |  | 		 * surrounding the token are removed */ | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 		while (p < end && QSE_AWK_ISSPACE(rtx->awk,*p)) p++; | 
					
						
							|  |  |  | 		if (rtx->gbl.ignorecase) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			while (p < end)  | 
					
						
							|  |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 				c = QSE_AWK_TOUPPER(rtx->awk, *p); | 
					
						
							|  |  |  | 				if (QSE_AWK_ISSPACE(rtx->awk,c))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				{ | 
					
						
							|  |  |  | 					p++; | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				for (d = delim; d < delim_end; d++)  | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2009-09-22 07:28:18 +00:00
										 |  |  | 					if (c == QSE_AWK_TOUPPER(rtx->awk,*d)) | 
					
						
							|  |  |  | 						goto exit_loop; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 				if (sp == QSE_NULL) sp = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				ep = p++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			while (p < end)  | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				c = *p; | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 				if (QSE_AWK_ISSPACE(rtx->awk,c))  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				{ | 
					
						
							|  |  |  | 					p++; | 
					
						
							|  |  |  | 					continue; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				for (d = delim; d < delim_end; d++)  | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					if (c == *d) goto exit_loop; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 				if (sp == QSE_NULL) sp = p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				ep = p++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit_loop: | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (sp == QSE_NULL)  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		tok->ptr = QSE_NULL; | 
					
						
							|  |  |  | 		tok->len = (qse_size_t)0; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else  | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		tok->ptr = sp; | 
					
						
							|  |  |  | 		tok->len = ep - sp + 1; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-22 07:28:18 +00:00
										 |  |  | 	/* if QSE_NULL is returned, this function should not be called again */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (p >= end) return QSE_NULL; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	if (delim_mode == __DELIM_EMPTY ||  | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	    delim_mode == __DELIM_SPACES) return (qse_char_t*)p; | 
					
						
							|  |  |  | 	return (qse_char_t*)++p; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | qse_char_t* qse_awk_rtx_strxntokbyrex ( | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 	qse_awk_rtx_t* rtx,  | 
					
						
							|  |  |  | 	const qse_char_t* str, qse_size_t len, | 
					
						
							|  |  |  | 	const qse_char_t* substr, qse_size_t sublen, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	void* rex, qse_cstr_t* tok, | 
					
						
							| 
									
										
										
										
											2009-06-02 03:34:34 +00:00
										 |  |  | 	qse_awk_errnum_t* errnum) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int n; | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	qse_size_t i; | 
					
						
							|  |  |  | 	qse_cstr_t match, s, cursub, realsub; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	s.ptr = str; | 
					
						
							|  |  |  | 	s.len = len; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	cursub.ptr = substr; | 
					
						
							|  |  |  | 	cursub.len = sublen; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	realsub.ptr = substr; | 
					
						
							|  |  |  | 	realsub.len = sublen; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (cursub.len > 0) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		n = QSE_AWK_MATCHREX ( | 
					
						
							| 
									
										
										
										
											2009-02-15 00:21:19 +00:00
										 |  |  | 			rtx->awk, rex,  | 
					
						
							| 
									
										
										
										
											2009-12-11 07:03:54 +00:00
										 |  |  | 			((rtx->gbl.ignorecase)? QSE_REX_IGNORECASE: 0), | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 			&s, &cursub, &match, errnum); | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		if (n == -1) return QSE_NULL; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		if (n == 0) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			/* no match has been found. 
 | 
					
						
							|  |  |  | 			 * return the entire string as a token */ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 			tok->ptr = realsub.ptr; | 
					
						
							|  |  |  | 			tok->len = realsub.len; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			*errnum = QSE_AWK_ENOERR; | 
					
						
							|  |  |  | 			return QSE_NULL;  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		QSE_ASSERT (n == 1); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 		if (match.len == 0) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 			/* the match length is zero. */ | 
					
						
							|  |  |  | 			cursub.ptr++; | 
					
						
							|  |  |  | 			cursub.len--; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-10-21 16:19:03 +00:00
										 |  |  | 		else if (rtx->awk->opt.trait & QSE_AWK_STRIPRECSPC) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			/* match at the beginning of the input string */ | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 			if (match.ptr == substr)  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 				for (i = 0; i < match.len; i++) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 					if (!QSE_AWK_ISSPACE(rtx->awk, match.ptr[i])) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 						goto exit_loop; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 				/* the match that is all spaces at the 
 | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 				 * beginning of the input string is skipped */ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 				cursub.ptr += match.len; | 
					
						
							|  |  |  | 				cursub.len -= match.len; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				/* adjust the substring by skipping the leading
 | 
					
						
							|  |  |  | 				 * spaces and retry matching */ | 
					
						
							|  |  |  | 				realsub.ptr = substr + match.len; | 
					
						
							|  |  |  | 				realsub.len -= match.len; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 			else break; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | exit_loop: | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	if (cursub.len <= 0) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		tok->ptr = realsub.ptr; | 
					
						
							|  |  |  | 		tok->len = realsub.len; | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 		*errnum = QSE_AWK_ENOERR; | 
					
						
							|  |  |  | 		return QSE_NULL;  | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	tok->ptr = realsub.ptr; | 
					
						
							|  |  |  | 	tok->len = match.ptr - realsub.ptr; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 	for (i = 0; i < match.len; i++) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 		if (!QSE_AWK_ISSPACE(rtx->awk, match.ptr[i])) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 			/* the match contains a non-space character. */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 			*errnum = QSE_AWK_ENOERR; | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 			return (qse_char_t*)match.ptr+match.len; | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	/* the match is all spaces */ | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	*errnum = QSE_AWK_ENOERR; | 
					
						
							| 
									
										
										
										
											2012-10-21 16:19:03 +00:00
										 |  |  | 	if (rtx->awk->opt.trait & QSE_AWK_STRIPRECSPC) | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		/* if the match reached the last character in the input string,
 | 
					
						
							|  |  |  | 		 * it returns QSE_NULL to terminate tokenization. */ | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 		return (match.ptr+match.len >= substr+sublen)?  | 
					
						
							|  |  |  | 			QSE_NULL: ((qse_char_t*)match.ptr+match.len); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		/* if the match went beyond the the last character in the input 
 | 
					
						
							|  |  |  | 		 * string, it returns QSE_NULL to terminate tokenization. */ | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 		return (match.ptr+match.len > substr+sublen)?  | 
					
						
							|  |  |  | 			QSE_NULL: ((qse_char_t*)match.ptr+match.len); | 
					
						
							| 
									
										
										
										
											2007-05-02 01:07:00 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-22 07:28:18 +00:00
										 |  |  | qse_char_t* qse_awk_rtx_strxnfld ( | 
					
						
							|  |  |  | 	qse_awk_rtx_t* rtx, qse_char_t* str, qse_size_t len, | 
					
						
							| 
									
										
										
										
											2009-09-24 04:19:30 +00:00
										 |  |  | 	qse_char_t fs, qse_char_t ec, qse_char_t lq, qse_char_t rq, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	qse_cstr_t* tok) | 
					
						
							| 
									
										
										
										
											2009-09-22 07:28:18 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-24 04:19:30 +00:00
										 |  |  | 	qse_char_t* p = str; | 
					
						
							|  |  |  | 	qse_char_t* end = str + len; | 
					
						
							|  |  |  | 	int escaped = 0, quoted = 0; | 
					
						
							|  |  |  | 	qse_char_t* ts; /* token start */ | 
					
						
							|  |  |  | 	qse_char_t* tp; /* points to one char past the last token char */ | 
					
						
							|  |  |  | 	qse_char_t* xp; /* points to one char past the last effective char */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* skip leading spaces */ | 
					
						
							|  |  |  | 	while (p < end && QSE_ISSPACE(*p)) p++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* initialize token pointers */ | 
					
						
							|  |  |  | 	ts = tp = xp = p;  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (p < end) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		char c = *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (escaped) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			*tp++ = c; xp = tp; p++; | 
					
						
							|  |  |  | 			escaped = 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if (c == ec) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				escaped = 1; | 
					
						
							|  |  |  | 				p++; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else if (quoted) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (c == rq) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					quoted = 0; | 
					
						
							|  |  |  | 					p++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					*tp++ = c; xp = tp; p++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else  | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if (c == fs) | 
					
						
							|  |  |  | 				{ | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 					tok->ptr = ts; | 
					
						
							|  |  |  | 					tok->len = xp - ts; | 
					
						
							| 
									
										
										
										
											2009-09-24 04:19:30 +00:00
										 |  |  | 					p++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if (QSE_ISSPACE(fs)) | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						while (p < end && *p == fs) p++; | 
					
						
							|  |  |  | 						if (p >= end) return QSE_NULL; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					return p; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 				if (c == lq) | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					quoted = 1; | 
					
						
							|  |  |  | 					p++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					*tp++ = c; p++; | 
					
						
							|  |  |  | 					if (!QSE_ISSPACE(c)) xp = tp;  | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (escaped)  | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		/* if it is still escaped, the last character must be 
 | 
					
						
							|  |  |  | 		 * the escaper itself. treat it as a normal character */ | 
					
						
							|  |  |  | 		*xp++ = ec; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	tok->ptr = ts; | 
					
						
							|  |  |  | 	tok->len = xp - ts; | 
					
						
							| 
									
										
										
										
											2009-09-22 07:28:18 +00:00
										 |  |  | 	return QSE_NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | #define QSE_AWK_REXERRTOERR(err) \
 | 
					
						
							| 
									
										
										
										
											2009-06-11 07:18:25 +00:00
										 |  |  | 	((err == QSE_REX_ENOERR)?      QSE_AWK_ENOERR: \ | 
					
						
							|  |  |  | 	 (err == QSE_REX_ENOMEM)?      QSE_AWK_ENOMEM: \ | 
					
						
							| 
									
										
										
										
											2009-11-26 07:32:20 +00:00
										 |  |  | 	 (err == QSE_REX_ENOCOMP)?     QSE_AWK_EREXNOCOMP: \ | 
					
						
							| 
									
										
										
										
											2009-06-11 07:18:25 +00:00
										 |  |  | 	 (err == QSE_REX_ERECUR)?      QSE_AWK_EREXRECUR: \ | 
					
						
							|  |  |  | 	 (err == QSE_REX_ERPAREN)?     QSE_AWK_EREXRPAREN: \ | 
					
						
							| 
									
										
										
										
											2009-11-26 07:32:20 +00:00
										 |  |  | 	 (err == QSE_REX_ERBRACK)?     QSE_AWK_EREXRBRACK: \ | 
					
						
							| 
									
										
										
										
											2009-06-11 07:18:25 +00:00
										 |  |  | 	 (err == QSE_REX_ERBRACE)?     QSE_AWK_EREXRBRACE: \ | 
					
						
							|  |  |  | 	 (err == QSE_REX_ECOLON)?      QSE_AWK_EREXCOLON: \ | 
					
						
							|  |  |  | 	 (err == QSE_REX_ECRANGE)?     QSE_AWK_EREXCRANGE: \ | 
					
						
							|  |  |  | 	 (err == QSE_REX_ECCLASS)?     QSE_AWK_EREXCCLASS: \ | 
					
						
							| 
									
										
										
										
											2009-11-23 07:58:53 +00:00
										 |  |  | 	 (err == QSE_REX_EBOUND)?      QSE_AWK_EREXBOUND: \ | 
					
						
							| 
									
										
										
										
											2009-12-10 05:35:54 +00:00
										 |  |  | 	 (err == QSE_REX_ESPCAWP)?     QSE_AWK_EREXSPCAWP: \ | 
					
						
							| 
									
										
										
										
											2009-11-26 07:32:20 +00:00
										 |  |  | 	 (err == QSE_REX_EPREEND)?     QSE_AWK_EREXPREEND: \ | 
					
						
							| 
									
										
										
										
											2009-06-11 07:18:25 +00:00
										 |  |  | 	                               QSE_AWK_EINTERN) | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void* qse_awk_buildrex ( | 
					
						
							| 
									
										
										
										
											2009-06-02 03:34:34 +00:00
										 |  |  | 	qse_awk_t* awk, const qse_char_t* ptn,  | 
					
						
							|  |  |  | 	qse_size_t len, qse_awk_errnum_t* errnum) | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 	qse_rex_errnum_t err; | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | 	void* p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	p = qse_buildrex ( | 
					
						
							| 
									
										
										
										
											2012-10-21 16:19:03 +00:00
										 |  |  | 		awk->mmgr, awk->opt.depth.s.rex_build, | 
					
						
							|  |  |  | 		((awk->opt.trait&QSE_AWK_REXBOUND)? 0: QSE_REX_NOBOUND), | 
					
						
							| 
									
										
										
										
											2009-06-11 07:18:25 +00:00
										 |  |  | 		ptn, len, &err | 
					
						
							|  |  |  | 	); | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	if (p == QSE_NULL) *errnum = QSE_AWK_REXERRTOERR(err); | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | 	return p; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | int qse_awk_matchrex ( | 
					
						
							|  |  |  | 	qse_awk_t* awk, void* code, int option, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 	const qse_cstr_t* str, const qse_cstr_t* substr, | 
					
						
							| 
									
										
										
										
											2009-06-02 03:34:34 +00:00
										 |  |  | 	qse_cstr_t* match, qse_awk_errnum_t* errnum) | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-16 07:31:43 +00:00
										 |  |  | 	int x; | 
					
						
							|  |  |  | 	qse_rex_errnum_t err; | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-21 21:35:07 +00:00
										 |  |  | 	x = qse_matchrex ( | 
					
						
							| 
									
										
										
										
											2012-10-21 16:19:03 +00:00
										 |  |  | 		awk->mmgr, awk->opt.depth.s.rex_match, | 
					
						
							| 
									
										
										
										
											2011-05-19 08:36:40 +00:00
										 |  |  | 		code, option, str, substr, match, &err); | 
					
						
							| 
									
										
										
										
											2012-01-25 15:39:02 +00:00
										 |  |  | 	if (x <= -1) *errnum = QSE_AWK_REXERRTOERR(err); | 
					
						
							| 
									
										
										
										
											2008-03-04 03:31:41 +00:00
										 |  |  | 	return x; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-03-01 09:27:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | void* qse_awk_rtx_allocmem (qse_awk_rtx_t* rtx, qse_size_t size) | 
					
						
							| 
									
										
										
										
											2009-03-01 09:27:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-28 14:46:37 +00:00
										 |  |  | 	void* ptr = QSE_AWK_ALLOC (rtx->awk, size); | 
					
						
							|  |  |  | 	if (ptr == QSE_NULL) qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							| 
									
										
										
										
											2009-03-01 09:27:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | void* qse_awk_rtx_reallocmem (qse_awk_rtx_t* rtx, void* ptr, qse_size_t size) | 
					
						
							| 
									
										
										
										
											2009-07-14 02:51:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-28 14:46:37 +00:00
										 |  |  | 	void* nptr = QSE_AWK_REALLOC (rtx->awk, ptr, size); | 
					
						
							|  |  |  | 	if (nptr == QSE_NULL) qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return nptr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void* qse_awk_rtx_callocmem (qse_awk_rtx_t* rtx, qse_size_t size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	void* ptr = QSE_AWK_ALLOC (rtx->awk, size); | 
					
						
							|  |  |  | 	if (ptr) QSE_MEMSET (ptr, 0, size); | 
					
						
							|  |  |  | 	else qse_awk_rtx_seterrnum (rtx, QSE_AWK_ENOMEM, QSE_NULL); | 
					
						
							|  |  |  | 	return ptr; | 
					
						
							| 
									
										
										
										
											2009-07-14 02:51:23 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-21 10:17:16 +00:00
										 |  |  | void qse_awk_rtx_freemem (qse_awk_rtx_t* rtx, void* ptr) | 
					
						
							| 
									
										
										
										
											2009-03-01 09:27:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-28 14:46:37 +00:00
										 |  |  | 	QSE_AWK_FREE (rtx->awk, ptr); | 
					
						
							| 
									
										
										
										
											2009-03-01 09:27:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-22 05:03:31 +00:00
										 |  |  | int qse_awk_sprintflt ( | 
					
						
							|  |  |  | 	qse_awk_t* awk, qse_char_t* buf, qse_size_t len, qse_flt_t num) | 
					
						
							| 
									
										
										
										
											2011-07-23 09:37:46 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	return awk->prm.sprintf ( | 
					
						
							|  |  |  | 		awk, buf, len, | 
					
						
							|  |  |  | 	#if QSE_SIZEOF_LONG_DOUBLE > 0
 | 
					
						
							| 
									
										
										
										
											2011-07-26 07:08:07 +00:00
										 |  |  | 		QSE_T("%Lf"), (long double)num | 
					
						
							| 
									
										
										
										
											2011-07-23 09:37:46 +00:00
										 |  |  | 	#elif QSE_SIZEOF_DOUBLE > 0
 | 
					
						
							|  |  |  | 		QSE_T("%f"), (double)num | 
					
						
							|  |  |  | 	#else
 | 
					
						
							|  |  |  | 		#error unsupported size	
 | 
					
						
							|  |  |  | 	#endif
 | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | } |