| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %{ | 
					
						
							|  |  |  | /* Written by Pace Willisson (pace@blitz.com)  | 
					
						
							|  |  |  |  * and placed in the public domain. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Largely rewritten by J.T. Conklin (jtc@wimsey.com) | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  |  * And then overhauled twice by Steve Murphy (murf@digium.com) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  |  * to add double-quoted strings, allow mult. spaces, improve | 
					
						
							|  |  |  |  * error messages, and then to fold in a flex scanner for the  | 
					
						
							|  |  |  |  * yylex operation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * $FreeBSD: src/bin/expr/expr.y,v 1.16 2000/07/22 10:59:36 se Exp $ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-12 09:58:52 -04:00
										 |  |  | #define ASTMM_LIBC ASTMM_REDIRECT | 
					
						
							| 
									
										
										
										
											2008-09-27 15:52:56 +00:00
										 |  |  | #include "asterisk.h" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-02 22:53:39 +03:00
										 |  |  | #include <sys/cdefs.h> | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | #include <sys/types.h> | 
					
						
							|  |  |  | #include <stdio.h> | 
					
						
							| 
									
										
										
										
											2008-09-27 15:52:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-26 22:40:49 -04:00
										 |  |  | #if defined(STANDALONE) || defined(STANDALONE2) | 
					
						
							| 
									
										
										
										
											2008-01-16 01:35:10 +00:00
										 |  |  | #ifndef __USE_ISOC99 | 
					
						
							|  |  |  | #define __USE_ISOC99 1 | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2006-06-07 18:54:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-16 01:35:10 +00:00
										 |  |  | #ifdef __USE_ISOC99 | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FP___PRINTF "%.18Lg" | 
					
						
							|  |  |  | #define FP___TYPE    long double | 
					
						
							| 
									
										
										
										
											2008-01-16 01:35:10 +00:00
										 |  |  | #else | 
					
						
							|  |  |  | #define FP___PRINTF "%.16g" | 
					
						
							|  |  |  | #define FP___TYPE    double | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_COSL | 
					
						
							|  |  |  | #define FUNC_COS   cosl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_COS) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_COS	(long double)cos | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #ifdef HAVE_SINL | 
					
						
							|  |  |  | #define FUNC_SIN   sinl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_SIN) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_SIN	(long double)sin | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_TANL | 
					
						
							|  |  |  | #define FUNC_TAN   tanl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_TAN) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_TAN	(long double)tan | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_ACOSL | 
					
						
							|  |  |  | #define FUNC_ACOS   acosl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_ACOS) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_ACOS	(long double)acos | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_ASINL | 
					
						
							|  |  |  | #define FUNC_ASIN   asinl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_ASIN) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_ASIN	(long double)asin | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_ATANL | 
					
						
							|  |  |  | #define FUNC_ATAN   atanl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_ATAN) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_ATAN	(long double)atan | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_ATAN2L | 
					
						
							|  |  |  | #define FUNC_ATAN2   atan2l | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_ATAN2) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_ATAN2	(long double)atan2 | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_POWL | 
					
						
							|  |  |  | #define FUNC_POW   powl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_POW) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_POW	(long double)pow | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_SQRTL | 
					
						
							|  |  |  | #define FUNC_SQRT   sqrtl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_SQRT) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_SQRT	(long double)sqrt | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_RINTL | 
					
						
							|  |  |  | #define FUNC_RINT   rintl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_RINT) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_RINT	(long double)rint | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_EXPL | 
					
						
							|  |  |  | #define FUNC_EXP   expl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_EXP) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_EXP	(long double)exp | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_LOGL | 
					
						
							|  |  |  | #define FUNC_LOG   logl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_LOG) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_LOG	(long double)log | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-28 22:09:40 +00:00
										 |  |  | #ifdef HAVE_REMAINDERL | 
					
						
							|  |  |  | #define FUNC_REMAINDER   remainderl | 
					
						
							|  |  |  | #elif defined(HAVE_REMAINDER) | 
					
						
							|  |  |  | #define FUNC_REMAINDER	(long double)remainder | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_FMODL | 
					
						
							|  |  |  | #define FUNC_FMOD   fmodl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_FMOD) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_FMOD	(long double)fmod | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_STRTOLD | 
					
						
							|  |  |  | #define FUNC_STRTOD  strtold | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_STRTOD) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_STRTOD  (long double)strtod | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_FLOORL | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | #define FUNC_FLOOR      floorl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_FLOOR) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_FLOOR	(long double)floor | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_CEILL | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | #define FUNC_CEIL      ceill | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_CEIL) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_CEIL	(long double)ceil | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_ROUNDL | 
					
						
							|  |  |  | #define FUNC_ROUND     roundl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_ROUND) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_ROUND     (long double)round | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_TRUNCL | 
					
						
							|  |  |  | #define FUNC_TRUNC     truncl | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_TRUNC) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define FUNC_TRUNC     (long double)trunc | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*! \note | 
					
						
							|  |  |  |  * Oddly enough, some platforms have some ISO C99 functions, but not others, so | 
					
						
							|  |  |  |  * we define the missing functions in terms of their mathematical identities. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-07-08 21:01:28 +00:00
										 |  |  | #ifdef HAVE_EXP2L | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | #define FUNC_EXP2       exp2l | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif (defined(HAVE_EXPL) && defined(HAVE_LOGL)) | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #define	FUNC_EXP2(x)	expl((x) * logl(2.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif (defined(HAVE_EXP) && defined(HAVE_LOG)) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define	FUNC_EXP2(x)	(long double)exp((x) * log(2.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-08 21:01:28 +00:00
										 |  |  | #ifdef HAVE_EXP10L | 
					
						
							|  |  |  | #define FUNC_EXP10       exp10l | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif (defined(HAVE_EXPL) && defined(HAVE_LOGL)) | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #define	FUNC_EXP10(x)	expl((x) * logl(10.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif (defined(HAVE_EXP) && defined(HAVE_LOG)) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define	FUNC_EXP10(x)	(long double)exp((x) * log(10.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-08 21:01:28 +00:00
										 |  |  | #ifdef HAVE_LOG2L | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | #define FUNC_LOG2       log2l | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_LOGL) | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #define	FUNC_LOG2(x)	(logl(x) / logl(2.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_LOG10L) | 
					
						
							|  |  |  | #define	FUNC_LOG2(x)	(log10l(x) / log10l(2.0)) | 
					
						
							|  |  |  | #elif defined(HAVE_LOG2) | 
					
						
							|  |  |  | #define FUNC_LOG2       (long double)log2 | 
					
						
							|  |  |  | #elif defined(HAVE_LOG) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define	FUNC_LOG2(x)	((long double)log(x) / log(2.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-08 21:01:28 +00:00
										 |  |  | #ifdef HAVE_LOG10L | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | #define FUNC_LOG10       log10l | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_LOGL) | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #define	FUNC_LOG10(x)	(logl(x) / logl(10.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #elif defined(HAVE_LOG2L) | 
					
						
							|  |  |  | #define	FUNC_LOG10(x)	(log2l(x) / log2l(10.0)) | 
					
						
							|  |  |  | #elif defined(HAVE_LOG10) | 
					
						
							|  |  |  | #define	FUNC_LOG10(x)	(long double)log10(x) | 
					
						
							|  |  |  | #elif defined(HAVE_LOG) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #define	FUNC_LOG10(x)	((long double)log(x) / log(10.0)) | 
					
						
							| 
									
										
										
										
											2007-10-17 21:16:40 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #include <stdlib.h> | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | #ifndef _GNU_SOURCE | 
					
						
							|  |  |  | #define _GNU_SOURCE | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #include <string.h> | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | #include <math.h> | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #include <locale.h> | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | #include <unistd.h> | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #include <ctype.h> | 
					
						
							| 
									
										
										
										
											2005-11-01 21:53:30 +00:00
										 |  |  | #if !defined(SOLARIS) && !defined(__CYGWIN__) | 
					
						
							| 
									
										
										
										
											2006-12-28 17:56:21 +00:00
										 |  |  | 	/* #include <err.h> */ | 
					
						
							| 
									
										
										
										
											2005-05-20 03:18:35 +00:00
										 |  |  | #else | 
					
						
							| 
									
										
										
										
											2005-08-29 20:17:25 +00:00
										 |  |  | #define quad_t int64_t | 
					
						
							| 
									
										
										
										
											2005-05-20 03:18:35 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #include <errno.h> | 
					
						
							|  |  |  | #include <regex.h> | 
					
						
							|  |  |  | #include <limits.h> | 
					
						
							| 
									
										
										
										
											2006-04-24 17:11:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "asterisk/ast_expr.h" | 
					
						
							|  |  |  | #include "asterisk/logger.h" | 
					
						
							| 
									
										
										
										
											2009-03-03 22:12:02 +00:00
										 |  |  | #if !defined(STANDALONE) && !defined(STANDALONE2) | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | #include "asterisk/pbx.h" | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-16 20:11:05 +00:00
										 |  |  | #if defined(LONG_LONG_MIN) && !defined(QUAD_MIN) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #define QUAD_MIN LONG_LONG_MIN | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2006-03-16 20:11:05 +00:00
										 |  |  | #if defined(LONG_LONG_MAX) && !defined(QUAD_MAX) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #define QUAD_MAX LONG_LONG_MAX | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #  if ! defined(QUAD_MIN) | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | #   define QUAD_MIN     (-0x7fffffffffffffffLL-1) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #  endif | 
					
						
							|  |  |  | #  if ! defined(QUAD_MAX) | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | #   define QUAD_MAX     (0x7fffffffffffffffLL) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #  endif | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | #define YYENABLE_NLS 0 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #define YYPARSE_PARAM parseio | 
					
						
							|  |  |  | #define YYLEX_PARAM ((struct parse_io *)parseio)->scanner | 
					
						
							|  |  |  | #define YYERROR_VERBOSE 1 | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | extern char extra_error_message[4095]; | 
					
						
							|  |  |  | extern int extra_error_message_supplied; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | enum valtype { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	AST_EXPR_number, AST_EXPR_numeric_string, AST_EXPR_string | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | } ; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-03 22:12:02 +00:00
										 |  |  | #if defined(STANDALONE) || defined(STANDALONE2) | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...) __attribute__ ((format (printf,5,6))); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | struct val { | 
					
						
							|  |  |  | 	enum valtype type; | 
					
						
							|  |  |  | 	union { | 
					
						
							|  |  |  | 		char *s; | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		FP___TYPE i; /* either long double, or just double, on a bad day */ | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} u; | 
					
						
							|  |  |  | } ; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | enum node_type { | 
					
						
							|  |  |  | 	AST_EXPR_NODE_COMMA, AST_EXPR_NODE_STRING, AST_EXPR_NODE_VAL | 
					
						
							|  |  |  | } ; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct expr_node  | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	enum node_type type; | 
					
						
							|  |  |  | 	struct val *val; | 
					
						
							|  |  |  | 	struct expr_node *left; | 
					
						
							|  |  |  | 	struct expr_node *right; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | typedef void *yyscan_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct parse_io | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	char *string; | 
					
						
							|  |  |  | 	struct val *val; | 
					
						
							|  |  |  | 	yyscan_t scanner; | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 	struct ast_channel *chan; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | }; | 
					
						
							|  |  |  |   | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | static int		chk_div __P((FP___TYPE, FP___TYPE)); | 
					
						
							|  |  |  | static int		chk_minus __P((FP___TYPE, FP___TYPE, FP___TYPE)); | 
					
						
							|  |  |  | static int		chk_plus __P((FP___TYPE, FP___TYPE, FP___TYPE)); | 
					
						
							|  |  |  | static int		chk_times __P((FP___TYPE, FP___TYPE, FP___TYPE)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static void		free_value __P((struct val *)); | 
					
						
							|  |  |  | static int		is_zero_or_null __P((struct val *)); | 
					
						
							|  |  |  | static int		isstring __P((struct val *)); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | static struct val	*make_number __P((FP___TYPE)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static struct val	*make_str __P((const char *)); | 
					
						
							|  |  |  | static struct val	*op_and __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_colon __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_eqtilde __P((struct val *, struct val *)); | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | static struct val	*op_tildetilde __P((struct val *, struct val *)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static struct val	*op_div __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_eq __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_ge __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_gt __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_le __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_lt __P((struct val *, struct val *)); | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | static struct val	*op_cond __P((struct val *, struct val *, struct val *)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static struct val	*op_minus __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_negate __P((struct val *)); | 
					
						
							|  |  |  | static struct val	*op_compl __P((struct val *)); | 
					
						
							|  |  |  | static struct val	*op_ne __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_or __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_plus __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_rem __P((struct val *, struct val *)); | 
					
						
							|  |  |  | static struct val	*op_times __P((struct val *, struct val *)); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | static struct val   *op_func(struct val *funcname, struct expr_node *arglist, struct ast_channel *chan); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | static int		to_number __P((struct val *)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static void		to_string __P((struct val *)); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | static struct expr_node *alloc_expr_node(enum node_type); | 
					
						
							|  |  |  | static void destroy_arglist(struct expr_node *arglist); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* uh, if I want to predeclare yylex with a YYLTYPE, I have to predeclare the yyltype... sigh */ | 
					
						
							|  |  |  | typedef struct yyltype | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   int first_line; | 
					
						
							|  |  |  |   int first_column; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   int last_line; | 
					
						
							|  |  |  |   int last_column; | 
					
						
							|  |  |  | } yyltype; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # define YYLTYPE yyltype | 
					
						
							|  |  |  | # define YYLTYPE_IS_TRIVIAL 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* we will get warning about no prototype for yylex! But we can't | 
					
						
							|  |  |  |    define it here, we have no definition yet for YYSTYPE. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int		ast_yyerror(const char *,YYLTYPE *, struct parse_io *); | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | /* I wanted to add args to the yyerror routine, so I could print out | 
					
						
							|  |  |  |    some useful info about the error. Not as easy as it looks, but it | 
					
						
							|  |  |  |    is possible. */ | 
					
						
							|  |  |  | #define ast_yyerror(x) ast_yyerror(x,&yyloc,parseio) | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | #define DESTROY(x) {if((x)->type == AST_EXPR_numeric_string || (x)->type == AST_EXPR_string) free((x)->u.s); (x)->u.s = 0; free(x);} | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %} | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | %pure-parser | 
					
						
							|  |  |  | %locations | 
					
						
							|  |  |  | /* %debug  for when you are having big problems */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* %name-prefix="ast_yy" */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %union | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *val; | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 	struct expr_node *arglist; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %{ | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | extern int		ast_yylex __P((YYSTYPE *, YYLTYPE *, yyscan_t)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %} | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | %left <val> TOK_COMMA | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | %left <val> TOK_COND TOK_COLONCOLON | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %left <val> TOK_OR | 
					
						
							|  |  |  | %left <val> TOK_AND | 
					
						
							|  |  |  | %left <val> TOK_EQ TOK_GT TOK_LT TOK_GE TOK_LE TOK_NE | 
					
						
							|  |  |  | %left <val> TOK_PLUS TOK_MINUS | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | %left <val> TOK_MULT TOK_DIV TOK_MOD  | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | %right <val> TOK_COMPL | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | %left <val> TOK_COLON TOK_EQTILDE TOK_TILDETILDE | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %left <val> TOK_RP TOK_LP | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %token <val> TOKEN | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | %type <arglist> arglist | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %type <val> start expr | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | %destructor {  free_value($$); }  expr TOKEN TOK_COND TOK_COLONCOLON TOK_OR TOK_AND TOK_EQ  | 
					
						
							|  |  |  |                                  TOK_GT TOK_LT TOK_GE TOK_LE TOK_NE TOK_PLUS TOK_MINUS TOK_MULT TOK_DIV TOK_MOD TOK_COMPL TOK_COLON TOK_EQTILDE  | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  |                                  TOK_RP TOK_LP TOK_TILDETILDE | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | %% | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | start: expr { ((struct parse_io *)parseio)->val = (struct val *)calloc(sizeof(struct val),1); | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  |               ((struct parse_io *)parseio)->val->type = $1->type; | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  |               if( $1->type == AST_EXPR_number ) | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 				  ((struct parse_io *)parseio)->val->u.i = $1->u.i; | 
					
						
							| 
									
										
										
										
											2005-09-25 17:03:18 +00:00
										 |  |  |               else | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 				  ((struct parse_io *)parseio)->val->u.s = $1->u.s;  | 
					
						
							|  |  |  | 			  free($1); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 	| {/* nothing */ ((struct parse_io *)parseio)->val = (struct val *)calloc(sizeof(struct val),1); | 
					
						
							|  |  |  |               ((struct parse_io *)parseio)->val->type = AST_EXPR_string; | 
					
						
							|  |  |  | 			  ((struct parse_io *)parseio)->val->u.s = strdup("");  | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | arglist: expr { $$ = alloc_expr_node(AST_EXPR_NODE_VAL); $$->val = $1;} | 
					
						
							| 
									
										
										
										
											2009-01-15 20:54:59 +00:00
										 |  |  |        | arglist TOK_COMMA expr %prec TOK_RP {struct expr_node *x = alloc_expr_node(AST_EXPR_NODE_VAL); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  |                                  struct expr_node *t; | 
					
						
							|  |  |  | 								 DESTROY($2); | 
					
						
							|  |  |  |                                  for (t=$1;t->right;t=t->right) | 
					
						
							|  |  |  | 						         	  ; | 
					
						
							|  |  |  |                                  $$ = $1; t->right = x; x->val = $3;} | 
					
						
							| 
									
										
										
										
											2009-01-15 20:54:59 +00:00
										 |  |  |        | arglist TOK_COMMA %prec TOK_RP {struct expr_node *x = alloc_expr_node(AST_EXPR_NODE_VAL); | 
					
						
							|  |  |  |                                  struct expr_node *t;  /* NULL args should OK */ | 
					
						
							|  |  |  | 								 DESTROY($2); | 
					
						
							|  |  |  |                                  for (t=$1;t->right;t=t->right) | 
					
						
							|  |  |  | 						         	  ; | 
					
						
							|  |  |  |                                  $$ = $1; t->right = x; x->val = make_str("");} | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  |        ; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | expr:  | 
					
						
							|  |  |  |       TOKEN TOK_LP arglist TOK_RP { $$ = op_func($1,$3, ((struct parse_io *)parseio)->chan); | 
					
						
							|  |  |  | 		                            DESTROY($2); | 
					
						
							|  |  |  | 									DESTROY($4); | 
					
						
							|  |  |  | 									DESTROY($1); | 
					
						
							|  |  |  | 									destroy_arglist($3); | 
					
						
							|  |  |  |                                   } | 
					
						
							|  |  |  |     | TOKEN {$$ = $1;} | 
					
						
							|  |  |  | 	| TOK_LP expr TOK_RP { $$ = $2; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                       @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						   @$.first_line=0; @$.last_line=0; | 
					
						
							|  |  |  | 							DESTROY($1); DESTROY($3); } | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	| expr TOK_OR expr { $$ = op_or ($1, $3); | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  |                          @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						 @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_AND expr { $$ = op_and ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                      @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  |                           @$.first_line=0; @$.last_line=0;} | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	| expr TOK_EQ expr { $$ = op_eq ($1, $3); | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	                     @$.first_column = @1.first_column; @$.last_column = @3.last_column; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 						 @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_GT expr { $$ = op_gt ($1, $3); | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  |                          @$.first_column = @1.first_column; @$.last_column = @3.last_column; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 						 @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_LT expr { $$ = op_lt ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                     @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						 @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_GE expr  { $$ = op_ge ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                      @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						  @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_LE expr  { $$ = op_le ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                      @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						  @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_NE expr  { $$ = op_ne ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                      @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						  @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_PLUS expr { $$ = op_plus ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                       @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						   @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_MINUS expr { $$ = op_minus ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	| TOK_MINUS expr %prec TOK_COMPL { $$ = op_negate ($2);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($1);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @2.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	| TOK_COMPL expr   { $$ = op_compl ($2);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($1);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @2.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_MULT expr { $$ = op_times ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                       @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						   @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_DIV expr { $$ = op_div ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                      @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						  @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_MOD expr { $$ = op_rem ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                      @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 						  @$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_COLON expr { $$ = op_colon ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							|  |  |  | 	| expr TOK_EQTILDE expr { $$ = op_eqtilde ($1, $3);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	| expr TOK_COND expr TOK_COLONCOLON expr  { $$ = op_cond ($1, $3, $5);  | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 						DESTROY($2);	 | 
					
						
							|  |  |  | 						DESTROY($4);	 | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | 	| expr TOK_TILDETILDE expr { $$ = op_tildetilde ($1, $3);  | 
					
						
							|  |  |  | 						DESTROY($2);	 | 
					
						
							|  |  |  | 	                        @$.first_column = @1.first_column; @$.last_column = @3.last_column;  | 
					
						
							|  |  |  | 							@$.first_line=0; @$.last_line=0;} | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | %% | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | static struct expr_node *alloc_expr_node(enum node_type nt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct expr_node *x = calloc(1,sizeof(struct expr_node)); | 
					
						
							|  |  |  | 	if (!x) { | 
					
						
							|  |  |  | 		ast_log(LOG_ERROR, "Allocation for expr_node FAILED!!\n"); | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	x->type = nt; | 
					
						
							|  |  |  | 	return x; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static struct val * | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | make_number (FP___TYPE i) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	struct val *vp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	vp = (struct val *) malloc (sizeof (*vp)); | 
					
						
							|  |  |  | 	if (vp == NULL) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "malloc() failed\n"); | 
					
						
							|  |  |  | 		return(NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	vp->type = AST_EXPR_number; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	vp->u.i  = i; | 
					
						
							|  |  |  | 	return vp;  | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | make_str (const char *s) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *vp; | 
					
						
							|  |  |  | 	size_t i; | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	int isint; /* this started out being a test for an integer, but then ended up being a test for a float */ | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	vp = (struct val *) malloc (sizeof (*vp)); | 
					
						
							|  |  |  | 	if (vp == NULL || ((vp->u.s = strdup (s)) == NULL)) { | 
					
						
							| 
									
										
										
										
											2012-03-24 02:42:42 +00:00
										 |  |  | 		if (vp) { | 
					
						
							|  |  |  | 			free(vp); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		ast_log(LOG_WARNING,"malloc() failed\n"); | 
					
						
							|  |  |  | 		return(NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	for (i = 0, isint = (isdigit(s[0]) || s[0] == '-' || s[0]=='.'); isint && i < strlen(s); i++) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		if (!isdigit(s[i]) && s[i] != '.') { | 
					
						
							|  |  |  | 			isint = 0; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (isint) | 
					
						
							|  |  |  | 		vp->type = AST_EXPR_numeric_string; | 
					
						
							|  |  |  | 	else	 | 
					
						
							|  |  |  | 		vp->type = AST_EXPR_string; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return vp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | free_value (struct val *vp) | 
					
						
							|  |  |  | {	 | 
					
						
							|  |  |  | 	if (vp==NULL) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (vp->type == AST_EXPR_string || vp->type == AST_EXPR_numeric_string) | 
					
						
							|  |  |  | 		free (vp->u.s);	 | 
					
						
							| 
									
										
										
										
											2006-01-19 19:18:51 +00:00
										 |  |  | 	free(vp); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | static int | 
					
						
							|  |  |  | to_number (struct val *vp) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	FP___TYPE i; | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (vp == NULL) { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		ast_log(LOG_WARNING,"vp==NULL in to_number()\n"); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		return(0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (vp->type == AST_EXPR_number) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (vp->type == AST_EXPR_string) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* vp->type == AST_EXPR_numeric_string, make it numeric */ | 
					
						
							|  |  |  | 	errno = 0; | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | 	i  = FUNC_STRTOD(vp->u.s, (char**)0); /* either strtod, or strtold on a good day */ | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (errno != 0) { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		ast_log(LOG_WARNING,"Conversion of %s to number under/overflowed!\n", vp->u.s); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free(vp->u.s); | 
					
						
							| 
									
										
										
										
											2005-06-17 00:33:00 +00:00
										 |  |  | 		vp->u.s = 0; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		return(0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	free (vp->u.s); | 
					
						
							|  |  |  | 	vp->u.i = i; | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	vp->type = AST_EXPR_number; | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | strip_quotes(struct val *vp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (vp->type != AST_EXPR_string && vp->type != AST_EXPR_numeric_string) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if( vp->u.s[0] == '"' && vp->u.s[strlen(vp->u.s)-1] == '"' ) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		char *f, *t; | 
					
						
							|  |  |  | 		f = vp->u.s; | 
					
						
							|  |  |  | 		t = vp->u.s; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		while( *f ) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if( *f  && *f != '"' ) | 
					
						
							|  |  |  | 				*t++ = *f++; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				f++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		*t = *f; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | to_string (struct val *vp) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	char *tmp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (vp->type == AST_EXPR_string || vp->type == AST_EXPR_numeric_string) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tmp = malloc ((size_t)25); | 
					
						
							|  |  |  | 	if (tmp == NULL) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING,"malloc() failed\n"); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	sprintf(tmp, FP___PRINTF, vp->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	vp->type = AST_EXPR_string; | 
					
						
							|  |  |  | 	vp->u.s  = tmp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | isstring (struct val *vp) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	/* only TRUE if this string is not a valid number */ | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	return (vp->type == AST_EXPR_string); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | is_zero_or_null (struct val *vp) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (vp->type == AST_EXPR_number) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		return (vp->u.i == 0); | 
					
						
							|  |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return (*vp->u.s == 0 || (to_number(vp) && vp->u.i == 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	/* NOTREACHED */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-03 22:12:02 +00:00
										 |  |  | #ifdef STANDALONE2 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ast_log(int level, const char *file, int line, const char *function, const char *fmt, ...) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	va_list vars; | 
					
						
							|  |  |  | 	va_start(vars,fmt); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  |         printf("LOG: lev:%d file:%s  line:%d func: %s  ", | 
					
						
							|  |  |  |                    level, file, line, function); | 
					
						
							|  |  |  | 	vprintf(fmt, vars); | 
					
						
							|  |  |  | 	fflush(stdout); | 
					
						
							|  |  |  | 	va_end(vars); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int main(int argc,char **argv) { | 
					
						
							|  |  |  | 	char s[4096]; | 
					
						
							|  |  |  | 	char out[4096]; | 
					
						
							|  |  |  | 	FILE *infile; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if( !argv[1] ) | 
					
						
							|  |  |  | 		exit(20); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if( access(argv[1],F_OK)== 0 ) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int ret; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		infile = fopen(argv[1],"r"); | 
					
						
							|  |  |  | 		if( !infile ) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			printf("Sorry, couldn't open %s for reading!\n", argv[1]); | 
					
						
							|  |  |  | 			exit(10); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		while( fgets(s,sizeof(s),infile) ) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			if( s[strlen(s)-1] == '\n' ) | 
					
						
							|  |  |  | 				s[strlen(s)-1] = 0; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			ret = ast_expr(s, out, sizeof(out), NULL); | 
					
						
							|  |  |  | 			printf("Expression: %s    Result: [%d] '%s'\n", | 
					
						
							|  |  |  | 				   s, ret, out); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		fclose(infile); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if (ast_expr(argv[1], s, sizeof(s), NULL)) | 
					
						
							|  |  |  | 			printf("=====%s======\n",s); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			printf("No result\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | #undef ast_yyerror | 
					
						
							|  |  |  | #define ast_yyerror(x) ast_yyerror(x, YYLTYPE *yylloc, struct parse_io *parseio) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* I put the ast_yyerror func in the flex input file, | 
					
						
							|  |  |  |    because it refers to the buffer state. Best to | 
					
						
							|  |  |  |    let it access the BUFFER stuff there and not trying | 
					
						
							|  |  |  |    define all the structs, macros etc. in this file! */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | static void destroy_arglist(struct expr_node *arglist) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct expr_node *arglist_next; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	while (arglist) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		arglist_next = arglist->right; | 
					
						
							|  |  |  | 		if (arglist->val) | 
					
						
							|  |  |  | 			free_value(arglist->val); | 
					
						
							|  |  |  | 		arglist->val = 0; | 
					
						
							|  |  |  | 		arglist->right = 0; | 
					
						
							|  |  |  | 		free(arglist); | 
					
						
							|  |  |  | 		arglist = arglist_next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-03 22:12:02 +00:00
										 |  |  | #if !defined(STANDALONE) && !defined(STANDALONE2) | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | static char *compose_func_args(struct expr_node *arglist) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct expr_node *t = arglist; | 
					
						
							|  |  |  | 	char *argbuf; | 
					
						
							|  |  |  | 	int total_len = 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	while (t) { | 
					
						
							|  |  |  | 		if (t != arglist) | 
					
						
							|  |  |  | 			total_len += 1; /* for the sep */ | 
					
						
							|  |  |  | 		if (t->val) { | 
					
						
							|  |  |  | 			if (t->val->type == AST_EXPR_number) | 
					
						
							|  |  |  | 				total_len += 25; /* worst case */ | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				total_len += strlen(t->val->u.s); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		t = t->right; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	total_len++; /* for the null */ | 
					
						
							|  |  |  | 	ast_log(LOG_NOTICE,"argbuf allocated %d bytes;\n", total_len); | 
					
						
							|  |  |  | 	argbuf = malloc(total_len); | 
					
						
							|  |  |  | 	argbuf[0] = 0; | 
					
						
							|  |  |  | 	t = arglist; | 
					
						
							|  |  |  | 	while (t) { | 
					
						
							|  |  |  | 		char numbuf[30]; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (t != arglist) | 
					
						
							| 
									
										
										
										
											2009-01-15 20:54:59 +00:00
										 |  |  | 			strcat(argbuf,","); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		if (t->val) { | 
					
						
							|  |  |  | 			if (t->val->type == AST_EXPR_number) { | 
					
						
							|  |  |  | 				sprintf(numbuf,FP___PRINTF,t->val->u.i); | 
					
						
							|  |  |  | 				strcat(argbuf,numbuf); | 
					
						
							|  |  |  | 			} else | 
					
						
							|  |  |  | 				strcat(argbuf,t->val->u.s); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		t = t->right; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-07-05 20:52:29 +00:00
										 |  |  | 	ast_log(LOG_NOTICE,"argbuf uses %d bytes;\n", (int) strlen(argbuf)); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 	return argbuf; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int is_really_num(char *str) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if ( strspn(str,"-0123456789. 	") == strlen(str)) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-09-27 15:52:56 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static struct val *op_func(struct val *funcname, struct expr_node *arglist, struct ast_channel *chan) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (strspn(funcname->u.s,"ABCDEFGHIJKLMNOPQRSTUVWXYZ_0123456789") == strlen(funcname->u.s)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		struct val *result; | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | 		if (0) { | 
					
						
							|  |  |  | #ifdef FUNC_COS | 
					
						
							|  |  |  | 		} else if (strcmp(funcname->u.s,"COS") == 0) { | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_COS(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_SIN | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"SIN") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_SIN(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_TAN | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"TAN") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_TAN(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_ACOS | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"ACOS") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_ACOS(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_ASIN | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"ASIN") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_ASIN(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_ATAN | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"ATAN") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_ATAN(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_ATAN2 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"ATAN2") == 0) { | 
					
						
							|  |  |  | 			if (arglist && arglist->right && !arglist->right->right && arglist->val && arglist->right->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				to_number(arglist->right->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_ATAN2(arglist->val->u.i, arglist->right->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_POW | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"POW") == 0) { | 
					
						
							|  |  |  | 			if (arglist && arglist->right && !arglist->right->right && arglist->val && arglist->right->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				to_number(arglist->right->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_POW(arglist->val->u.i, arglist->right->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_SQRT | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"SQRT") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_SQRT(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_FLOOR | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"FLOOR") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_FLOOR(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_CEIL | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"CEIL") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_CEIL(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #ifdef FUNC_ROUND | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"ROUND") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_ROUND(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #endif /* defined(FUNC_ROUND) */ | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #ifdef FUNC_RINT | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"RINT") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_RINT(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #ifdef FUNC_TRUNC | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"TRUNC") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_TRUNC(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-21 14:25:51 +00:00
										 |  |  | #endif /* defined(FUNC_TRUNC) */ | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #ifdef FUNC_EXP | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"EXP") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_EXP(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_EXP2 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"EXP2") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_EXP2(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_EXP10 | 
					
						
							| 
									
										
										
										
											2007-07-08 21:01:28 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"EXP10") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_EXP10(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_LOG | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"LOG") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_LOG(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_LOG2 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"LOG2") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_LOG2(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_LOG10 | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"LOG10") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_LOG10(arglist->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							|  |  |  | #ifdef FUNC_REMAINDER | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s,"REMAINDER") == 0) { | 
					
						
							|  |  |  | 			if (arglist && arglist->right && !arglist->right->right && arglist->val && arglist->right->val){ | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				to_number(arglist->right->val); | 
					
						
							|  |  |  | 				result = make_number(FUNC_REMAINDER(arglist->val->u.i, arglist->right->val->u.i)); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Wrong args to %s() function\n",funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | #endif | 
					
						
							| 
									
										
										
										
											2012-01-16 19:49:50 +00:00
										 |  |  | 		} else if (strcmp(funcname->u.s, "ABS") == 0) { | 
					
						
							|  |  |  | 			if (arglist && !arglist->right && arglist->val) { | 
					
						
							|  |  |  | 				to_number(arglist->val); | 
					
						
							|  |  |  | 				result = make_number(arglist->val->u.i < 0 ? arglist->val->u.i * -1 : arglist->val->u.i); | 
					
						
							|  |  |  | 				return result; | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING, "Wrong args to %s() function\n", funcname->u.s); | 
					
						
							|  |  |  | 				return make_number(0.0); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		} else { | 
					
						
							|  |  |  | 			/* is this a custom function we should execute and collect the results of? */ | 
					
						
							| 
									
										
										
										
											2009-03-03 22:12:02 +00:00
										 |  |  | #if !defined(STANDALONE) && !defined(STANDALONE2) | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 			struct ast_custom_function *f = ast_custom_function_find(funcname->u.s); | 
					
						
							|  |  |  | 			if (!chan) | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Hey! chan is NULL.\n"); | 
					
						
							|  |  |  | 			if (!f) | 
					
						
							|  |  |  | 				ast_log(LOG_WARNING,"Hey! could not find func %s.\n", funcname->u.s); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			if (f && chan) { | 
					
						
							|  |  |  | 				if (f->read) { | 
					
						
							|  |  |  | 					char workspace[512]; | 
					
						
							|  |  |  | 					char *argbuf = compose_func_args(arglist); | 
					
						
							|  |  |  | 					f->read(chan, funcname->u.s, argbuf, workspace, sizeof(workspace)); | 
					
						
							|  |  |  | 					free(argbuf); | 
					
						
							|  |  |  | 					if (is_really_num(workspace)) | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | 						return make_number(FUNC_STRTOD(workspace,(char **)NULL)); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 					else | 
					
						
							|  |  |  | 						return make_str(workspace); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					ast_log(LOG_ERROR,"Error! Function '%s' cannot be read!\n", funcname->u.s); | 
					
						
							|  |  |  | 					return (make_number ((FP___TYPE)0.0)); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2010-06-02 17:25:05 +00:00
										 |  |  | 				ast_log(LOG_ERROR, "Error! '%s' doesn't appear to be an available function!\n", funcname->u.s); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 				return (make_number ((FP___TYPE)0.0)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | #else | 
					
						
							| 
									
										
										
										
											2010-06-02 17:25:05 +00:00
										 |  |  | 			ast_log(LOG_ERROR, "Error! '%s' is not available in the standalone version!\n", funcname->u.s); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 			return (make_number ((FP___TYPE)0.0)); | 
					
						
							|  |  |  | #endif | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2010-06-02 17:25:05 +00:00
										 |  |  | 		ast_log(LOG_ERROR, "Error! '%s' is not possibly a function name!\n", funcname->u.s); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		return (make_number ((FP___TYPE)0.0)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return (make_number ((FP___TYPE)0.0)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_or (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (is_zero_or_null (a)) { | 
					
						
							|  |  |  | 		free_value (a); | 
					
						
							|  |  |  | 		return (b); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		free_value (b); | 
					
						
							|  |  |  | 		return (a); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_and (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (is_zero_or_null (a) || is_zero_or_null (b)) { | 
					
						
							|  |  |  | 		free_value (a); | 
					
						
							|  |  |  | 		free_value (b); | 
					
						
							| 
									
										
										
											
												In regards to changes for 9508, expr2 system choking on floating point numbers, I'm adding this update to round out (no pun intended) and make this FP-capable version of the Expr2 stuff interoperate better with previous integer-only usage, by providing Functions syntax, with 20 builtin functions for floating pt to integer conversions, and some general floating point math routines that might commonly be used also. Along with this, I made it so if a function was not a builtin, it will try and find it in the ast_custom_function list, and if found, execute it and collect the results. Thus, you can call system functions like CDR(), CHANNEL(), etc, from within $\[..\] exprs, without having to wrap them in $\{...\} (curly brace) notation. Did a valgrind on the standalone and made sure there's no mem leaks. Looks good. Updated the docs, too.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@73449 65c4cc65-6c06-0410-ace0-fbb531ad65f3
											
										 
											2007-07-05 18:15:22 +00:00
										 |  |  | 		return (make_number ((FP___TYPE)0.0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		free_value (b); | 
					
						
							|  |  |  | 		return (a); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_eq (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r;  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (isstring (a) || isstring (b)) { | 
					
						
							|  |  |  | 		to_string (a); | 
					
						
							|  |  |  | 		to_string (b);	 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(strcoll (a->u.s, b->u.s) == 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2005-06-17 00:33:00 +00:00
										 |  |  | #ifdef DEBUG_FOR_CONVERSIONS | 
					
						
							|  |  |  | 		char buffer[2000]; | 
					
						
							|  |  |  | 		sprintf(buffer,"Converting '%s' and '%s' ", a->u.s, b->u.s); | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							|  |  |  | 		(void)to_number(b); | 
					
						
							| 
									
										
										
										
											2005-06-17 00:33:00 +00:00
										 |  |  | #ifdef DEBUG_FOR_CONVERSIONS | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING,"%s to '%lld' and '%lld'\n", buffer, a->u.i, b->u.i); | 
					
						
							|  |  |  | #endif | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(a->u.i == b->u.i)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_gt (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (isstring (a) || isstring (b)) { | 
					
						
							|  |  |  | 		to_string (a); | 
					
						
							|  |  |  | 		to_string (b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(strcoll (a->u.s, b->u.s) > 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							|  |  |  | 		(void)to_number(b); | 
					
						
							|  |  |  | 		r = make_number ((FP___TYPE)(a->u.i > b->u.i)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_lt (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (isstring (a) || isstring (b)) { | 
					
						
							|  |  |  | 		to_string (a); | 
					
						
							|  |  |  | 		to_string (b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(strcoll (a->u.s, b->u.s) < 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							|  |  |  | 		(void)to_number(b); | 
					
						
							|  |  |  | 		r = make_number ((FP___TYPE)(a->u.i < b->u.i)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_ge (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (isstring (a) || isstring (b)) { | 
					
						
							|  |  |  | 		to_string (a); | 
					
						
							|  |  |  | 		to_string (b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(strcoll (a->u.s, b->u.s) >= 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							|  |  |  | 		(void)to_number(b); | 
					
						
							|  |  |  | 		r = make_number ((FP___TYPE)(a->u.i >= b->u.i)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_le (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (isstring (a) || isstring (b)) { | 
					
						
							|  |  |  | 		to_string (a); | 
					
						
							|  |  |  | 		to_string (b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(strcoll (a->u.s, b->u.s) <= 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							|  |  |  | 		(void)to_number(b); | 
					
						
							|  |  |  | 		r = make_number ((FP___TYPE)(a->u.i <= b->u.i)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | static struct val * | 
					
						
							|  |  |  | op_cond (struct val *a, struct val *b, struct val *c) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( isstring(a) ) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		if( strlen(a->u.s) && strcmp(a->u.s, "\"\"") != 0 && strcmp(a->u.s,"0") != 0 ) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(c); | 
					
						
							|  |  |  | 			r = b; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(b); | 
					
						
							|  |  |  | 			r = c; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							| 
									
										
										
										
											2005-06-24 02:51:47 +00:00
										 |  |  | 		if( a->u.i ) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(c); | 
					
						
							|  |  |  | 			r = b; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(b); | 
					
						
							|  |  |  | 			r = c; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | static struct val * | 
					
						
							|  |  |  | op_ne (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (isstring (a) || isstring (b)) { | 
					
						
							|  |  |  | 		to_string (a); | 
					
						
							|  |  |  | 		to_string (b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		r = make_number ((FP___TYPE)(strcoll (a->u.s, b->u.s) != 0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		(void)to_number(a); | 
					
						
							|  |  |  | 		(void)to_number(b); | 
					
						
							|  |  |  | 		r = make_number ((FP___TYPE)(a->u.i != b->u.i)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | chk_plus (FP___TYPE a, FP___TYPE b, FP___TYPE r) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* sum of two positive numbers must be positive */ | 
					
						
							|  |  |  | 	if (a > 0 && b > 0 && r <= 0) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	/* sum of two negative numbers must be negative */ | 
					
						
							|  |  |  | 	if (a < 0 && b < 0 && r >= 0) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	/* all other cases are OK */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_plus (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (!to_number (a)) { | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING,"non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		if (!to_number (b)) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			return make_number(0); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		} else { | 
					
						
							|  |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			return (b); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	} else if (!to_number(b)) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(b); | 
					
						
							|  |  |  | 		return (a); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	r = make_number (a->u.i + b->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (chk_plus (a->u.i, b->u.i, r->u.i)) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING,"overflow\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | chk_minus (FP___TYPE a, FP___TYPE b, FP___TYPE r) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* special case subtraction of QUAD_MIN */ | 
					
						
							|  |  |  | 	if (b == QUAD_MIN) { | 
					
						
							|  |  |  | 		if (a >= 0) | 
					
						
							|  |  |  | 			return 1; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	/* this is allowed for b != QUAD_MIN */ | 
					
						
							|  |  |  | 	return chk_plus (a, -b, r); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_minus (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (!to_number (a)) { | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		if (!to_number (b)) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			return make_number(0); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			r = make_number(0 - b->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 			free_value(a); | 
					
						
							|  |  |  | 			free_value(b); | 
					
						
							|  |  |  | 			return (r); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	} else if (!to_number(b)) { | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(b); | 
					
						
							|  |  |  | 		return (a); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	r = make_number (a->u.i - b->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (chk_minus (a->u.i, b->u.i, r->u.i)) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "overflow\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_negate (struct val *a) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (!to_number (a) ) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return make_number(0); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	r = make_number (- a->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (chk_minus (0, a->u.i, r->u.i)) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "overflow\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_compl (struct val *a) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int v1 = 1; | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if( !a ) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		v1 = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		switch( a->type ) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		case AST_EXPR_number: | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 			if( a->u.i == 0 ) | 
					
						
							|  |  |  | 				v1 = 0; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		case AST_EXPR_string: | 
					
						
							|  |  |  | 			if( a->u.s == 0 ) | 
					
						
							|  |  |  | 				v1 = 0; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if( a->u.s[0] == 0 ) | 
					
						
							|  |  |  | 					v1 = 0; | 
					
						
							|  |  |  | 				else if (strlen(a->u.s) == 1 && a->u.s[0] == '0' ) | 
					
						
							|  |  |  | 					v1 = 0; | 
					
						
							| 
									
										
										
										
											2010-10-28 20:01:28 +00:00
										 |  |  | 				else | 
					
						
							|  |  |  | 					v1 = atoi(a->u.s); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		case AST_EXPR_numeric_string: | 
					
						
							|  |  |  | 			if( a->u.s == 0 ) | 
					
						
							|  |  |  | 				v1 = 0; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				if( a->u.s[0] == 0 ) | 
					
						
							|  |  |  | 					v1 = 0; | 
					
						
							|  |  |  | 				else if (strlen(a->u.s) == 1 && a->u.s[0] == '0' ) | 
					
						
							|  |  |  | 					v1 = 0; | 
					
						
							| 
									
										
										
										
											2010-10-28 20:01:28 +00:00
										 |  |  | 				else | 
					
						
							|  |  |  | 					v1 = atoi(a->u.s); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	r = make_number (!v1); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | chk_times (FP___TYPE a, FP___TYPE b, FP___TYPE r) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* special case: first operand is 0, no overflow possible */ | 
					
						
							|  |  |  | 	if (a == 0) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	/* cerify that result of division matches second operand */ | 
					
						
							|  |  |  | 	if (r / a != b) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_times (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (!to_number (a) || !to_number (b)) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return(make_number(0)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	r = make_number (a->u.i * b->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (chk_times (a->u.i, b->u.i, r->u.i)) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "overflow\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return (r); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | chk_div (FP___TYPE a, FP___TYPE b) | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* div by zero has been taken care of before */ | 
					
						
							|  |  |  | 	/* only QUAD_MIN / -1 causes overflow */ | 
					
						
							|  |  |  | 	if (a == QUAD_MIN && b == -1) | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	/* everything else is OK */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_div (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (!to_number (a)) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return make_number(0); | 
					
						
							|  |  |  | 	} else if (!to_number (b)) { | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return make_number(INT_MAX); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (b->u.i == 0) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "division by zero\n");		 | 
					
						
							|  |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return make_number(INT_MAX); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	r = make_number (a->u.i / b->u.i); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	if (chk_div (a->u.i, b->u.i)) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "overflow\n"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_rem (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *r; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 	if (!to_number (a) || !to_number (b)) { | 
					
						
							| 
									
										
										
										
											2006-04-24 17:41:27 +00:00
										 |  |  | 		if( !extra_error_message_supplied ) | 
					
						
							|  |  |  | 			ast_log(LOG_WARNING, "non-numeric argument\n"); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 		return make_number(0); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (b->u.i == 0) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "div by zero\n"); | 
					
						
							|  |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		return(b); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-22 02:07:53 +00:00
										 |  |  | 	r = make_number (FUNC_FMOD(a->u.i, b->u.i)); /* either fmod or fmodl if FP___TYPE is available */ | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 	/* chk_rem necessary ??? */ | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	return r; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_colon (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	regex_t rp; | 
					
						
							|  |  |  | 	regmatch_t rm[2]; | 
					
						
							|  |  |  | 	char errbuf[256]; | 
					
						
							|  |  |  | 	int eval; | 
					
						
							|  |  |  | 	struct val *v; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* coerce to both arguments to strings */ | 
					
						
							|  |  |  | 	to_string(a); | 
					
						
							|  |  |  | 	to_string(b); | 
					
						
							|  |  |  | 	/* strip double quotes from both -- they'll screw up the pattern, and the search string starting at ^ */ | 
					
						
							|  |  |  | 	strip_quotes(a); | 
					
						
							|  |  |  | 	strip_quotes(b); | 
					
						
							|  |  |  | 	/* compile regular expression */ | 
					
						
							|  |  |  | 	if ((eval = regcomp (&rp, b->u.s, REG_EXTENDED)) != 0) { | 
					
						
							|  |  |  | 		regerror (eval, &rp, errbuf, sizeof(errbuf)); | 
					
						
							| 
									
										
										
										
											2010-06-02 17:25:05 +00:00
										 |  |  | 		ast_log(LOG_WARNING, "regcomp() error : %s\n", errbuf); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							|  |  |  | 		return make_str("");		 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* compare string against pattern */ | 
					
						
							|  |  |  | 	/* remember that patterns are anchored to the beginning of the line */ | 
					
						
							|  |  |  | 	if (regexec(&rp, a->u.s, (size_t)2, rm, 0) == 0 && rm[0].rm_so == 0) { | 
					
						
							|  |  |  | 		if (rm[1].rm_so >= 0) { | 
					
						
							|  |  |  | 			*(a->u.s + rm[1].rm_eo) = '\0'; | 
					
						
							|  |  |  | 			v = make_str (a->u.s + rm[1].rm_so); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			v = make_number ((FP___TYPE)(rm[0].rm_eo - rm[0].rm_so)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		if (rp.re_nsub == 0) { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			v = make_number ((FP___TYPE)0); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		} else { | 
					
						
							|  |  |  | 			v = make_str (""); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* free arguments and pattern buffer */ | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	regfree (&rp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct val * | 
					
						
							|  |  |  | op_eqtilde (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	regex_t rp; | 
					
						
							|  |  |  | 	regmatch_t rm[2]; | 
					
						
							|  |  |  | 	char errbuf[256]; | 
					
						
							|  |  |  | 	int eval; | 
					
						
							|  |  |  | 	struct val *v; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* coerce to both arguments to strings */ | 
					
						
							|  |  |  | 	to_string(a); | 
					
						
							|  |  |  | 	to_string(b); | 
					
						
							|  |  |  | 	/* strip double quotes from both -- they'll screw up the pattern, and the search string starting at ^ */ | 
					
						
							|  |  |  | 	strip_quotes(a); | 
					
						
							|  |  |  | 	strip_quotes(b); | 
					
						
							|  |  |  | 	/* compile regular expression */ | 
					
						
							|  |  |  | 	if ((eval = regcomp (&rp, b->u.s, REG_EXTENDED)) != 0) { | 
					
						
							|  |  |  | 		regerror (eval, &rp, errbuf, sizeof(errbuf)); | 
					
						
							| 
									
										
										
										
											2010-06-02 17:25:05 +00:00
										 |  |  | 		ast_log(LOG_WARNING, "regcomp() error : %s\n", errbuf); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							|  |  |  | 		return make_str("");		 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* compare string against pattern */ | 
					
						
							|  |  |  | 	/* remember that patterns are anchored to the beginning of the line */ | 
					
						
							|  |  |  | 	if (regexec(&rp, a->u.s, (size_t)2, rm, 0) == 0 ) { | 
					
						
							|  |  |  | 		if (rm[1].rm_so >= 0) { | 
					
						
							|  |  |  | 			*(a->u.s + rm[1].rm_eo) = '\0'; | 
					
						
							|  |  |  | 			v = make_str (a->u.s + rm[1].rm_so); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			v = make_number ((FP___TYPE)(rm[0].rm_eo - rm[0].rm_so)); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		if (rp.re_nsub == 0) { | 
					
						
							| 
									
										
										
										
											2007-07-02 21:50:15 +00:00
										 |  |  | 			v = make_number ((FP___TYPE)0.0); | 
					
						
							| 
									
										
										
										
											2005-05-16 00:35:38 +00:00
										 |  |  | 		} else { | 
					
						
							|  |  |  | 			v = make_str (""); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* free arguments and pattern buffer */ | 
					
						
							|  |  |  | 	free_value (a); | 
					
						
							|  |  |  | 	free_value (b); | 
					
						
							|  |  |  | 	regfree (&rp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return v; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static struct val *  /* this is a string concat operator */ | 
					
						
							|  |  |  | op_tildetilde (struct val *a, struct val *b) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	struct val *v; | 
					
						
							|  |  |  | 	char *vs; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* coerce to both arguments to strings */ | 
					
						
							|  |  |  | 	to_string(a); | 
					
						
							|  |  |  | 	to_string(b); | 
					
						
							|  |  |  | 	/* strip double quotes from both -- */ | 
					
						
							|  |  |  | 	strip_quotes(a); | 
					
						
							|  |  |  | 	strip_quotes(b); | 
					
						
							| 
									
										
										
										
											2016-06-17 14:51:57 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | 	vs = malloc(strlen(a->u.s)+strlen(b->u.s)+1); | 
					
						
							| 
									
										
										
										
											2016-06-17 14:51:57 -04:00
										 |  |  | 	if (vs == NULL) { | 
					
						
							|  |  |  | 		ast_log(LOG_WARNING, "malloc() failed\n"); | 
					
						
							| 
									
										
										
										
											2016-07-11 13:42:55 -05:00
										 |  |  | 		free_value(a); | 
					
						
							|  |  |  | 		free_value(b); | 
					
						
							| 
									
										
										
										
											2016-06-17 14:51:57 -04:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | 	strcpy(vs,a->u.s); | 
					
						
							|  |  |  | 	strcat(vs,b->u.s); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	v = make_str(vs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-17 14:51:57 -04:00
										 |  |  | 	free(vs); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-21 21:13:02 +00:00
										 |  |  | 	/* free arguments */ | 
					
						
							|  |  |  | 	free_value(a); | 
					
						
							|  |  |  | 	free_value(b); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return v; | 
					
						
							|  |  |  | } |