You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
175 lines
4.0 KiB
175 lines
4.0 KiB
17 years ago
|
%{
|
||
|
/*=========================================================================
|
||
|
|
||
|
Program: CMake - Cross-Platform Makefile Generator
|
||
|
Module: $RCSfile: cmExprParser.y,v $
|
||
|
Language: C++
|
||
|
Date: $Date: 2006-08-01 15:38:41 $
|
||
|
Version: $Revision: 1.3 $
|
||
|
|
||
|
Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
|
||
|
See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
|
||
|
|
||
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
||
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
||
|
PURPOSE. See the above copyright notices for more information.
|
||
|
|
||
|
=========================================================================*/
|
||
|
/*
|
||
|
|
||
|
This file must be translated to C and modified to build everywhere.
|
||
|
|
||
|
Run bison like this:
|
||
|
|
||
|
bison --yacc --name-prefix=cmExpr_yy --defines=cmExprParserTokens.h -ocmExprParser.cxx cmExprParser.y
|
||
|
|
||
|
Modify cmExprParser.cxx:
|
||
|
- remove TABs
|
||
|
- add __HP_aCC to the #if test for yyerrorlab warning suppression
|
||
|
|
||
|
*/
|
||
|
|
||
|
/* Configure the parser to use a lexer object. */
|
||
|
#define YYPARSE_PARAM yyscanner
|
||
|
#define YYLEX_PARAM yyscanner
|
||
|
#define YYERROR_VERBOSE 1
|
||
|
#define cmExpr_yyerror(x) \
|
||
|
cmExprError(yyscanner, x)
|
||
|
#define yyGetParser (cmExpr_yyget_extra(yyscanner))
|
||
|
|
||
|
/*-------------------------------------------------------------------------*/
|
||
|
#include "cmExprParserHelper.h" /* Interface to parser object. */
|
||
|
#include "cmExprLexer.h" /* Interface to lexer object. */
|
||
|
#include "cmExprParserTokens.h" /* Need YYSTYPE for YY_DECL. */
|
||
|
|
||
|
#include <math.h>
|
||
|
|
||
|
/* Forward declare the lexer entry point. */
|
||
|
YY_DECL;
|
||
|
|
||
|
/* Internal utility functions. */
|
||
|
static void cmExprError(yyscan_t yyscanner, const char* message);
|
||
|
|
||
|
#define YYDEBUG 1
|
||
|
//#define YYMAXDEPTH 100000
|
||
|
//#define YYINITDEPTH 10000
|
||
|
|
||
|
|
||
|
/* Disable some warnings in the generated code. */
|
||
|
#ifdef __BORLANDC__
|
||
|
# pragma warn -8004 /* Variable assigned a value that is not used. */
|
||
|
# pragma warn -8008 /* condition always returns true */
|
||
|
# pragma warn -8060 /* possibly incorrect assignment */
|
||
|
# pragma warn -8066 /* unreachable code */
|
||
|
#endif
|
||
|
#ifdef _MSC_VER
|
||
|
# pragma warning (disable: 4102) /* Unused goto label. */
|
||
|
# pragma warning (disable: 4065) /* Switch statement contains default but no case. */
|
||
|
#endif
|
||
|
%}
|
||
|
|
||
|
/* Generate a reentrant parser object. */
|
||
|
%pure_parser
|
||
|
|
||
|
/*-------------------------------------------------------------------------*/
|
||
|
/* Tokens */
|
||
|
%token exp_PLUS
|
||
|
%token exp_MINUS
|
||
|
%token exp_TIMES
|
||
|
%token exp_DIVIDE
|
||
|
%token exp_MOD
|
||
|
%token exp_SHIFTLEFT
|
||
|
%token exp_SHIFTRIGHT
|
||
|
%token exp_OPENPARENT
|
||
|
%token exp_CLOSEPARENT
|
||
|
%token exp_OR;
|
||
|
%token exp_AND;
|
||
|
%token exp_XOR;
|
||
|
%token exp_NOT;
|
||
|
%token exp_NUMBER;
|
||
|
|
||
|
/*-------------------------------------------------------------------------*/
|
||
|
/* grammar */
|
||
|
%%
|
||
|
|
||
|
|
||
|
Start:
|
||
|
exp
|
||
|
{
|
||
|
yyGetParser->SetResult($<Number>1);
|
||
|
}
|
||
|
|
||
|
exp:
|
||
|
bitwiseor
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
exp exp_OR bitwiseor
|
||
|
{$<Number>$ = $<Number>1 | $<Number>3;}
|
||
|
|
||
|
bitwiseor:
|
||
|
bitwisexor
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
bitwiseor exp_XOR bitwisexor
|
||
|
{$<Number>$ = $<Number>1 ^ $<Number>3;}
|
||
|
|
||
|
bitwisexor:
|
||
|
bitwiseand
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
bitwisexor exp_AND bitwiseand
|
||
|
{$<Number>$ = $<Number>1 & $<Number>3;}
|
||
|
|
||
|
bitwiseand:
|
||
|
shift
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
bitwiseand exp_SHIFTLEFT shift
|
||
|
{$<Number>$ = $<Number>1 << $<Number>3;}
|
||
|
|
|
||
|
bitwiseand exp_SHIFTRIGHT shift
|
||
|
{$<Number>$ = $<Number>1 >> $<Number>3;}
|
||
|
|
||
|
|
||
|
shift:
|
||
|
term
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
shift exp_PLUS term
|
||
|
{$<Number>$ = $<Number>1 + $<Number>3;}
|
||
|
|
|
||
|
shift exp_MINUS term
|
||
|
{$<Number>$ = $<Number>1 - $<Number>3;}
|
||
|
|
||
|
term:
|
||
|
factor
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
term exp_TIMES factor
|
||
|
{$<Number>$ = $<Number>1 * $<Number>3;}
|
||
|
|
|
||
|
term exp_DIVIDE factor
|
||
|
{$<Number>$ = $<Number>1 / $<Number>3;}
|
||
|
|
|
||
|
term exp_MOD factor
|
||
|
{$<Number>$ = $<Number>1 % $<Number>3;}
|
||
|
|
||
|
factor:
|
||
|
exp_NUMBER
|
||
|
{$<Number>$ = $<Number>1;}
|
||
|
|
|
||
|
exp_OPENPARENT exp exp_CLOSEPARENT
|
||
|
{$<Number>$ = $<Number>2;}
|
||
|
;
|
||
|
|
||
|
|
||
|
%%
|
||
|
/* End of grammar */
|
||
|
|
||
|
/*--------------------------------------------------------------------------*/
|
||
|
void cmExprError(yyscan_t yyscanner, const char* message)
|
||
|
{
|
||
|
yyGetParser->Error(message);
|
||
|
}
|
||
|
|