summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/LexerParser/cmExprParser.cxx125
-rw-r--r--Source/LexerParser/cmExprParser.y3
-rw-r--r--Tests/MathTest/CMakeLists.txt2
-rw-r--r--Tests/RunCMake/math/MATH-InvalidExpression-stderr.txt4
4 files changed, 75 insertions, 59 deletions
diff --git a/Source/LexerParser/cmExprParser.cxx b/Source/LexerParser/cmExprParser.cxx
index d2c65dc..8416e72 100644
--- a/Source/LexerParser/cmExprParser.cxx
+++ b/Source/LexerParser/cmExprParser.cxx
@@ -425,18 +425,18 @@ union yyalloc
#endif /* !YYCOPY_NEEDED */
/* YYFINAL -- State number of the termination state. */
-#define YYFINAL 17
+#define YYFINAL 19
/* YYLAST -- Last index in YYTABLE. */
-#define YYLAST 30
+#define YYLAST 34
/* YYNTOKENS -- Number of terminals. */
#define YYNTOKENS 17
/* YYNNTS -- Number of nonterminals. */
#define YYNNTS 10
/* YYNRULES -- Number of rules. */
-#define YYNRULES 23
+#define YYNRULES 24
/* YYNSTATES -- Number of states. */
-#define YYNSTATES 39
+#define YYNSTATES 41
#define YYUNDEFTOK 2
#define YYMAXUTOK 271
@@ -486,7 +486,7 @@ static const yytype_uint8 yyrline[] =
{
0, 77, 77, 82, 85, 90, 93, 98, 101, 106,
109, 112, 117, 120, 123, 128, 131, 134, 140, 145,
- 148, 151, 156, 159
+ 148, 151, 154, 159, 162
};
#endif
@@ -513,10 +513,10 @@ static const yytype_uint16 yytoknum[] =
};
# endif
-#define YYPACT_NINF -8
+#define YYPACT_NINF -11
#define yypact_value_is_default(Yystate) \
- (!!((Yystate) == (-8)))
+ (!!((Yystate) == (-11)))
#define YYTABLE_NINF -1
@@ -527,10 +527,11 @@ static const yytype_uint16 yytoknum[] =
STATE-NUM. */
static const yytype_int8 yypact[] =
{
- 0, 0, 0, 0, -8, 2, -7, -5, 8, 3,
- 10, 1, -8, -8, -8, -8, 6, -8, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, -8, -5,
- 8, 3, 10, 10, 1, 1, -8, -8, -8
+ 1, 1, 1, 1, 1, -11, 6, -10, -4, 9,
+ 4, 11, 2, -11, -11, -11, -11, 7, -11, -11,
+ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
+ -11, -4, 9, 4, 11, 11, 2, 2, -11, -11,
+ -11
};
/* YYDEFACT[STATE-NUM] -- Default reduction number in state STATE-NUM.
@@ -538,22 +539,23 @@ static const yytype_int8 yypact[] =
means the default is an error. */
static const yytype_uint8 yydefact[] =
{
- 0, 0, 0, 0, 22, 0, 2, 3, 5, 7,
- 9, 12, 15, 19, 20, 21, 0, 1, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 23, 4,
- 6, 8, 10, 11, 13, 14, 16, 17, 18
+ 0, 0, 0, 0, 0, 23, 0, 2, 3, 5,
+ 7, 9, 12, 15, 19, 20, 21, 0, 22, 1,
+ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+ 24, 4, 6, 8, 10, 11, 13, 14, 16, 17,
+ 18
};
/* YYPGOTO[NTERM-NUM]. */
static const yytype_int8 yypgoto[] =
{
- -8, -8, 12, 5, 11, 9, -2, 4, -1, -8
+ -11, -11, 22, 10, 8, 12, -3, -2, -1, -11
};
/* YYDEFGOTO[NTERM-NUM]. */
static const yytype_int8 yydefgoto[] =
{
- -1, 5, 6, 7, 8, 9, 10, 11, 12, 13
+ -1, 6, 7, 8, 9, 10, 11, 12, 13, 14
};
/* YYTABLE[YYPACT[STATE-NUM]] -- What to do in state STATE-NUM. If
@@ -561,28 +563,29 @@ static const yytype_int8 yydefgoto[] =
number is the opposite. If YYTABLE_NINF, syntax error. */
static const yytype_uint8 yytable[] =
{
- 14, 15, 17, 1, 2, 18, 25, 26, 27, 19,
- 3, 21, 22, 23, 24, 16, 4, 28, 18, 32,
- 33, 20, 0, 29, 36, 37, 38, 34, 35, 31,
- 30
+ 15, 16, 20, 18, 1, 2, 19, 27, 28, 29,
+ 21, 3, 23, 24, 25, 26, 4, 5, 30, 20,
+ 34, 35, 22, 36, 37, 17, 38, 39, 40, 32,
+ 31, 0, 0, 0, 33
};
static const yytype_int8 yycheck[] =
{
- 1, 2, 0, 3, 4, 12, 5, 6, 7, 14,
- 10, 8, 9, 3, 4, 3, 16, 11, 12, 21,
- 22, 13, -1, 18, 25, 26, 27, 23, 24, 20,
- 19
+ 1, 2, 12, 4, 3, 4, 0, 5, 6, 7,
+ 14, 10, 8, 9, 3, 4, 15, 16, 11, 12,
+ 23, 24, 13, 25, 26, 3, 27, 28, 29, 21,
+ 20, -1, -1, -1, 22
};
/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing
symbol of state STATE-NUM. */
static const yytype_uint8 yystos[] =
{
- 0, 3, 4, 10, 16, 18, 19, 20, 21, 22,
- 23, 24, 25, 26, 25, 25, 19, 0, 12, 14,
- 13, 8, 9, 3, 4, 5, 6, 7, 11, 20,
- 21, 22, 23, 23, 24, 24, 25, 25, 25
+ 0, 3, 4, 10, 15, 16, 18, 19, 20, 21,
+ 22, 23, 24, 25, 26, 25, 25, 19, 25, 0,
+ 12, 14, 13, 8, 9, 3, 4, 5, 6, 7,
+ 11, 20, 21, 22, 23, 23, 24, 24, 25, 25,
+ 25
};
/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */
@@ -590,7 +593,7 @@ static const yytype_uint8 yyr1[] =
{
0, 17, 18, 19, 19, 20, 20, 21, 21, 22,
22, 22, 23, 23, 23, 24, 24, 24, 24, 25,
- 25, 25, 26, 26
+ 25, 25, 25, 26, 26
};
/* YYR2[YYN] -- Number of symbols on the right hand side of rule YYN. */
@@ -598,7 +601,7 @@ static const yytype_uint8 yyr2[] =
{
0, 2, 1, 1, 3, 1, 3, 1, 3, 1,
3, 3, 1, 3, 3, 1, 3, 3, 3, 1,
- 2, 2, 1, 3
+ 2, 2, 2, 1, 3
};
@@ -1294,7 +1297,7 @@ yyreduce:
{
cmExpr_yyget_extra(yyscanner)->SetResult((yyvsp[0].Number));
}
-#line 1298 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1301 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 3:
@@ -1302,7 +1305,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1306 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1309 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 4:
@@ -1310,7 +1313,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) | (yyvsp[0].Number);
}
-#line 1314 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1317 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 5:
@@ -1318,7 +1321,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1322 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1325 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 6:
@@ -1326,7 +1329,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) ^ (yyvsp[0].Number);
}
-#line 1330 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1333 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 7:
@@ -1334,7 +1337,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1338 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1341 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 8:
@@ -1342,7 +1345,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) & (yyvsp[0].Number);
}
-#line 1346 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1349 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 9:
@@ -1350,7 +1353,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1354 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1357 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 10:
@@ -1358,7 +1361,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) << (yyvsp[0].Number);
}
-#line 1362 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1365 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 11:
@@ -1366,7 +1369,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) >> (yyvsp[0].Number);
}
-#line 1370 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1373 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 12:
@@ -1374,7 +1377,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1378 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1381 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 13:
@@ -1382,7 +1385,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) + (yyvsp[0].Number);
}
-#line 1386 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1389 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 14:
@@ -1390,7 +1393,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) - (yyvsp[0].Number);
}
-#line 1394 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1397 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 15:
@@ -1398,7 +1401,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1402 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1405 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 16:
@@ -1406,7 +1409,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) * (yyvsp[0].Number);
}
-#line 1410 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1413 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 17:
@@ -1417,7 +1420,7 @@ yyreduce:
}
(yyval.Number) = (yyvsp[-2].Number) / (yyvsp[0].Number);
}
-#line 1421 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1424 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 18:
@@ -1425,7 +1428,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[-2].Number) % (yyvsp[0].Number);
}
-#line 1429 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1432 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 19:
@@ -1433,7 +1436,7 @@ yyreduce:
{
(yyval.Number) = (yyvsp[0].Number);
}
-#line 1437 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1440 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 20:
@@ -1441,7 +1444,7 @@ yyreduce:
{
(yyval.Number) = + (yyvsp[0].Number);
}
-#line 1445 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1448 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 21:
@@ -1449,27 +1452,35 @@ yyreduce:
{
(yyval.Number) = - (yyvsp[0].Number);
}
-#line 1453 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1456 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 22:
-#line 156 "cmExprParser.y" /* yacc.c:1652 */
+#line 154 "cmExprParser.y" /* yacc.c:1652 */
{
- (yyval.Number) = (yyvsp[0].Number);
+ (yyval.Number) = ~ (yyvsp[0].Number);
}
-#line 1461 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1464 "cmExprParser.cxx" /* yacc.c:1652 */
break;
case 23:
#line 159 "cmExprParser.y" /* yacc.c:1652 */
{
+ (yyval.Number) = (yyvsp[0].Number);
+ }
+#line 1472 "cmExprParser.cxx" /* yacc.c:1652 */
+ break;
+
+ case 24:
+#line 162 "cmExprParser.y" /* yacc.c:1652 */
+ {
(yyval.Number) = (yyvsp[-1].Number);
}
-#line 1469 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1480 "cmExprParser.cxx" /* yacc.c:1652 */
break;
-#line 1473 "cmExprParser.cxx" /* yacc.c:1652 */
+#line 1484 "cmExprParser.cxx" /* yacc.c:1652 */
default: break;
}
/* User semantic actions sometimes alter yychar, and that requires
@@ -1702,7 +1713,7 @@ yyreturn:
#endif
return yyresult;
}
-#line 164 "cmExprParser.y" /* yacc.c:1918 */
+#line 167 "cmExprParser.y" /* yacc.c:1918 */
/* End of grammar */
diff --git a/Source/LexerParser/cmExprParser.y b/Source/LexerParser/cmExprParser.y
index 2137473..7ae2118 100644
--- a/Source/LexerParser/cmExprParser.y
+++ b/Source/LexerParser/cmExprParser.y
@@ -151,6 +151,9 @@ unary:
| exp_MINUS unary {
$<Number>$ = - $<Number>2;
}
+| exp_NOT unary {
+ $<Number>$ = ~ $<Number>2;
+ }
factor:
exp_NUMBER {
diff --git a/Tests/MathTest/CMakeLists.txt b/Tests/MathTest/CMakeLists.txt
index 5403d29..396f633 100644
--- a/Tests/MathTest/CMakeLists.txt
+++ b/Tests/MathTest/CMakeLists.txt
@@ -16,6 +16,8 @@ set(expressions
"1000 -12*5"
"1000 +12*-5"
"1000 -12*-5"
+ "~~1"
+ "1000 & ~0"
)
set(FILE_EXPRESSIONS "extern void test_expression(int x, int y, const char * text);\n")
diff --git a/Tests/RunCMake/math/MATH-InvalidExpression-stderr.txt b/Tests/RunCMake/math/MATH-InvalidExpression-stderr.txt
index 9e73ed5..22226f2 100644
--- a/Tests/RunCMake/math/MATH-InvalidExpression-stderr.txt
+++ b/Tests/RunCMake/math/MATH-InvalidExpression-stderr.txt
@@ -1,5 +1,5 @@
^CMake Error at MATH-InvalidExpression.cmake:1 \(math\):
- math cannot parse the expression: "INVALID": syntax error, unexpected \$end,
- expecting exp_PLUS or exp_MINUS or exp_OPENPARENT or exp_NUMBER \(7\).
+ math cannot parse the expression: "INVALID": syntax error, unexpected \$end
+ \(7\).
Call Stack \(most recent call first\):
CMakeLists.txt:3 \(include\)$