Blame exp/expression-parser.l

Packit Service 0e769b
%{
Packit Service 0e769b
Packit Service 0e769b
/*
Packit Service 0e769b
 * (C) Copyright 2014, Stephen M. Cameron.
Packit Service 0e769b
 *
Packit Service 0e769b
 *  This program is free software; you can redistribute it and/or modify
Packit Service 0e769b
 *  it under the terms of the GNU General Public License version 2 as
Packit Service 0e769b
 *  published by the Free Software Foundation.
Packit Service 0e769b
 *
Packit Service 0e769b
 *  This program is distributed in the hope that it will be useful,
Packit Service 0e769b
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 0e769b
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 0e769b
 *  GNU General Public License for more details.
Packit Service 0e769b
 *
Packit Service 0e769b
 *  You should have received a copy of the GNU General Public License
Packit Service 0e769b
 *  along with this program; if not, write to the Free Software
Packit Service 0e769b
 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Packit Service 0e769b
 *
Packit Service 0e769b
 */
Packit Service 0e769b
Packit Service 0e769b
#include <stdio.h>
Packit Service 0e769b
#include <string.h>
Packit Service 0e769b
#include "y.tab.h"
Packit Service 0e769b
Packit Service 0e769b
#define YYSTYPE PARSER_VALUE_TYPE
Packit Service 0e769b
Packit Service 0e769b
extern int lexer_input(char *buffer, unsigned int *nbytes, int buffersize);
Packit Service 0e769b
Packit Service 0e769b
#undef YY_INPUT
Packit Service 0e769b
#define YY_INPUT(buffer, bytes_read, bytes_requested)			\
Packit Service 0e769b
({									\
Packit Service 0e769b
	int __ret;							\
Packit Service 0e769b
	unsigned int __bread = bytes_read;				\
Packit Service 0e769b
	__ret = lexer_input((buffer), &__bread, (bytes_requested));	\
Packit Service 0e769b
	bytes_read = __bread;						\
Packit Service 0e769b
	__ret;								\
Packit Service 0e769b
})
Packit Service 0e769b
Packit Service 0e769b
extern int yyerror(long long *result, double *dresult,
Packit Service 0e769b
		int *has_error, int *units_specified, const char *msg);
Packit Service 0e769b
Packit Service 0e769b
static void __attribute__((unused)) yyunput(int c, char *buf_ptr);
Packit Service 0e769b
static int __attribute__((unused)) input(void);
Packit Service 0e769b
Packit Service 0e769b
/* set by parser -- this is another thing which makes the parser thread-unsafe :(. */
Packit Service 0e769b
int lexer_value_is_time = 0; /* for determining if "m" suffix means mega- or minutes */
Packit Service 0e769b
Packit Service 0e769b
#define set_suffix_value(yylval, i_val, d_val, has_d_val) \
Packit Service 0e769b
	(yylval).v.dval = (d_val); \
Packit Service 0e769b
	(yylval).v.ival = (i_val); \
Packit Service 0e769b
	(yylval).v.has_dval = (has_d_val); \
Packit Service 0e769b
	(yylval).v.has_error = 0;
Packit Service 0e769b
Packit Service 0e769b
%}
Packit Service 0e769b
Packit Service 0e769b
%%
Packit Service 0e769b
Packit Service 0e769b
Packit Service 0e769b
[kK]|[kK][bB] 	{
Packit Service 0e769b
			set_suffix_value(yylval, 1024, 1024.0, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[Mm][bB]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1024 * 1024, 1024.0 * 1024.0, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[mM][sS]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1000, 1000.0, 1);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[uU][sS]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1, 1.0, 1);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[gG]|[Gg][Bb]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1024LL * 1024 * 1024, 1024.0 * 1024.0 * 1024, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[tT]|[tT][bB]	{	
Packit Service 0e769b
			set_suffix_value(yylval, 1024LL * 1024 * 1024 * 1024,
Packit Service 0e769b
						1024.0 * 1024.0 * 1024.0 * 1024.0 * 1024, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[pP]|[pP][bB]	{	
Packit Service 0e769b
			set_suffix_value(yylval, 1024LL * 1024 * 1024 * 1024 * 1024,
Packit Service 0e769b
					1024.0 * 1024.0 * 1024.0 * 1024.0 * 1024.0, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[kK][iI][Bb]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1000LL, 1000.0, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[mM][Ii][bB]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1000000LL, 1000000.0 , 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[gG][iI][Bb]	{
Packit Service 0e769b
			set_suffix_value(yylval, 1000000000LL, 1000000000.0 , 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[pP][iI][Bb]	{	
Packit Service 0e769b
			set_suffix_value(yylval, 1000000000000LL, 1000000000000.0 , 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[sS]		{
Packit Service 0e769b
			set_suffix_value(yylval, 1000000LL, 1000000.0 , 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[mM]		{
Packit Service 0e769b
			if (!lexer_value_is_time) {
Packit Service 0e769b
				set_suffix_value(yylval, 1024 * 1024, 1024.0 * 1024.0, 0);
Packit Service 0e769b
			} else {
Packit Service 0e769b
				set_suffix_value(yylval, 60LL * 1000000LL, 60.0 * 1000000.0, 0);
Packit Service 0e769b
			}
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[dD]		{
Packit Service 0e769b
			set_suffix_value(yylval, 60LL * 60LL * 24LL * 1000000LL,
Packit Service 0e769b
						60.0 * 60.0 * 24.0 * 1000000.0, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[hH]		{	
Packit Service 0e769b
			set_suffix_value(yylval, 60LL * 60LL * 1000000LL,
Packit Service 0e769b
					60.0 * 60.0 * 1000000.0, 0);
Packit Service 0e769b
			return SUFFIX;
Packit Service 0e769b
		}
Packit Service 0e769b
[ \t] ; /* ignore whitespace */
Packit Service 0e769b
[#:,].* ; /* ignore comments, and everything after colons and commas */
Packit Service 0e769b
[0-9]*[.][0-9]+|[0-9]*[.]?[0-9]+[eE][-+]*[0-9]+ {
Packit Service 0e769b
			int rc;
Packit Service 0e769b
			double dval;
Packit Service 0e769b
Packit Service 0e769b
			rc = sscanf(yytext, "%lf", &dval);
Packit Service 0e769b
			if (rc == 1) {
Packit Service 0e769b
				yylval.v.dval = dval;
Packit Service 0e769b
				yylval.v.ival = (long long) dval;
Packit Service 0e769b
				yylval.v.has_dval = 1;
Packit Service 0e769b
				yylval.v.has_error = 0;
Packit Service 0e769b
				return NUMBER;
Packit Service 0e769b
			} else {
Packit Service 0e769b
				yyerror(0, 0, 0, 0, "bad number\n");
Packit Service 0e769b
				yylval.v.has_error = 1;
Packit Service 0e769b
				return NUMBER;
Packit Service 0e769b
			}
Packit Service 0e769b
		}
Packit Service 0e769b
0x[0-9a-fA-F]+ {
Packit Service 0e769b
		int rc, intval;
Packit Service 0e769b
		rc = sscanf(yytext, "%x", &intval);
Packit Service 0e769b
		if (rc == 1) {
Packit Service 0e769b
			yylval.v.ival = intval;
Packit Service 0e769b
			yylval.v.dval = (double) intval;
Packit Service 0e769b
			yylval.v.has_dval = 0;
Packit Service 0e769b
			yylval.v.has_error = 0;
Packit Service 0e769b
			return NUMBER;
Packit Service 0e769b
		} else {
Packit Service 0e769b
			yyerror(0, 0, 0, 0, "bad number\n");
Packit Service 0e769b
			yylval.v.has_error = 1;
Packit Service 0e769b
			return NUMBER;
Packit Service 0e769b
		}
Packit Service 0e769b
	}
Packit Service 0e769b
[0-9]+	{
Packit Service 0e769b
		int rc, intval;
Packit Service 0e769b
		rc = sscanf(yytext, "%d", &intval);
Packit Service 0e769b
		if (rc == 1) {
Packit Service 0e769b
			yylval.v.ival = intval;
Packit Service 0e769b
			yylval.v.dval = (double) intval;
Packit Service 0e769b
			yylval.v.has_dval = 0;
Packit Service 0e769b
			yylval.v.has_error = 0;
Packit Service 0e769b
			return NUMBER;
Packit Service 0e769b
		} else {
Packit Service 0e769b
			yyerror(0, 0, 0, 0, "bad number\n");
Packit Service 0e769b
			yylval.v.has_error = 1;
Packit Service 0e769b
			return NUMBER;
Packit Service 0e769b
		}
Packit Service 0e769b
	}
Packit Service 0e769b
\n	return 0;
Packit Service 0e769b
[+-/*()^%]	return yytext[0];
Packit Service 0e769b
Packit Service 0e769b
.	{
Packit Service 0e769b
		yylval.v.has_error = 1;
Packit Service 0e769b
		return NUMBER;	
Packit Service 0e769b
	}
Packit Service 0e769b
%%
Packit Service 0e769b