summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2020-06-06 17:04:38 (GMT)
committerGitHub <noreply@github.com>2020-06-06 17:04:38 (GMT)
commit90ee51f1cd9e63cfe0f402392612f50fc1bea747 (patch)
treec01e9c055dc69900860659b8ab71528c81b6dc65 /Python
parent18f1226884e27d0cb89e7a2cc3d60a44df5da740 (diff)
downloadcpython-90ee51f1cd9e63cfe0f402392612f50fc1bea747.zip
cpython-90ee51f1cd9e63cfe0f402392612f50fc1bea747.tar.gz
cpython-90ee51f1cd9e63cfe0f402392612f50fc1bea747.tar.bz2
bpo-40870: Invalidate usage of some constants with ast.Name (GH-20649)
(cherry picked from commit 68874a8502da440a1dc4746cf73262648b870aee) Co-authored-by: Batuhan Taskaya <isidentical@gmail.com>
Diffstat (limited to 'Python')
-rw-r--r--Python/ast.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/Python/ast.c b/Python/ast.c
index c524b8e..408591f 100644
--- a/Python/ast.c
+++ b/Python/ast.c
@@ -22,6 +22,25 @@ static int validate_stmt(stmt_ty);
static int validate_expr(expr_ty, expr_context_ty);
static int
+validate_name(PyObject *name)
+{
+ assert(PyUnicode_Check(name));
+ static const char * const forbidden[] = {
+ "None",
+ "True",
+ "False",
+ NULL
+ };
+ for (int i = 0; forbidden[i] != NULL; i++) {
+ if (_PyUnicode_EqualToASCIIString(name, forbidden[i])) {
+ PyErr_Format(PyExc_ValueError, "Name node can't be used with '%s' constant", forbidden[i]);
+ return 0;
+ }
+ }
+ return 1;
+}
+
+static int
validate_comprehension(asdl_seq *gens)
{
Py_ssize_t i;
@@ -173,6 +192,9 @@ validate_expr(expr_ty exp, expr_context_ty ctx)
actual_ctx = exp->v.Starred.ctx;
break;
case Name_kind:
+ if (!validate_name(exp->v.Name.id)) {
+ return 0;
+ }
actual_ctx = exp->v.Name.ctx;
break;
case List_kind: