merge 3.4 (#21642)
This commit is contained in:
commit
3e439797ba
|
@ -80,6 +80,12 @@ class TokenTests(unittest.TestCase):
|
||||||
x = .3e14
|
x = .3e14
|
||||||
x = 3.1e4
|
x = 3.1e4
|
||||||
|
|
||||||
|
def test_float_exponent_tokenization(self):
|
||||||
|
# See issue 21642.
|
||||||
|
self.assertEqual(1 if 1else 0, 1)
|
||||||
|
self.assertEqual(1 if 0else 0, 0)
|
||||||
|
self.assertRaises(SyntaxError, eval, "0 if 1Else 0")
|
||||||
|
|
||||||
def test_string_literals(self):
|
def test_string_literals(self):
|
||||||
x = ''; y = ""; self.assertTrue(len(x) == 0 and x == y)
|
x = ''; y = ""; self.assertTrue(len(x) == 0 and x == y)
|
||||||
x = '\''; y = "'"; self.assertTrue(len(x) == 1 and x == y and ord(x) == 39)
|
x = '\''; y = "'"; self.assertTrue(len(x) == 1 and x == y and ord(x) == 39)
|
||||||
|
|
|
@ -10,6 +10,10 @@ Release date: TBA
|
||||||
Core and Builtins
|
Core and Builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- Issue #21642: If the conditional if-else expression, allow an integer written
|
||||||
|
with no space between itself and the ``else`` keyword (e.g. ``True if 42else
|
||||||
|
False``) to be valid syntax.
|
||||||
|
|
||||||
- Issue #21523: Fix over-pessimistic computation of the stack effect of
|
- Issue #21523: Fix over-pessimistic computation of the stack effect of
|
||||||
some opcodes in the compiler. This also fixes a quadratic compilation
|
some opcodes in the compiler. This also fixes a quadratic compilation
|
||||||
time issue noticeable when compiling code with a large number of "and"
|
time issue noticeable when compiling code with a large number of "and"
|
||||||
|
|
|
@ -1603,15 +1603,24 @@ tok_get(struct tok_state *tok, char **p_start, char **p_end)
|
||||||
} while (isdigit(c));
|
} while (isdigit(c));
|
||||||
}
|
}
|
||||||
if (c == 'e' || c == 'E') {
|
if (c == 'e' || c == 'E') {
|
||||||
exponent:
|
int e;
|
||||||
|
exponent:
|
||||||
|
e = c;
|
||||||
/* Exponent part */
|
/* Exponent part */
|
||||||
c = tok_nextc(tok);
|
c = tok_nextc(tok);
|
||||||
if (c == '+' || c == '-')
|
if (c == '+' || c == '-') {
|
||||||
c = tok_nextc(tok);
|
c = tok_nextc(tok);
|
||||||
if (!isdigit(c)) {
|
if (!isdigit(c)) {
|
||||||
tok->done = E_TOKEN;
|
tok->done = E_TOKEN;
|
||||||
|
tok_backup(tok, c);
|
||||||
|
return ERRORTOKEN;
|
||||||
|
}
|
||||||
|
} else if (!isdigit(c)) {
|
||||||
tok_backup(tok, c);
|
tok_backup(tok, c);
|
||||||
return ERRORTOKEN;
|
tok_backup(tok, e);
|
||||||
|
*p_start = tok->start;
|
||||||
|
*p_end = tok->cur;
|
||||||
|
return NUMBER;
|
||||||
}
|
}
|
||||||
do {
|
do {
|
||||||
c = tok_nextc(tok);
|
c = tok_nextc(tok);
|
||||||
|
|
Loading…
Reference in New Issue