summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVinay Sajip <vinay_sajip@yahoo.co.uk>2019-11-07 10:08:58 (GMT)
committerGitHub <noreply@github.com>2019-11-07 10:08:58 (GMT)
commit9def81aa52adc3cc89554156e40742cf17312825 (patch)
tree13b87d65449de478cef1183faa37c8508e9b4f5e
parent7f460494d2309ace004a400bae8fc59134dc325c (diff)
downloadcpython-9def81aa52adc3cc89554156e40742cf17312825.zip
cpython-9def81aa52adc3cc89554156e40742cf17312825.tar.gz
cpython-9def81aa52adc3cc89554156e40742cf17312825.tar.bz2
bpo-36876: Moved Parser/listnode.c statics to interpreter state. (GH-16328)
-rw-r--r--Include/internal/pycore_pystate.h9
-rw-r--r--Parser/listnode.c24
2 files changed, 23 insertions, 10 deletions
diff --git a/Include/internal/pycore_pystate.h b/Include/internal/pycore_pystate.h
index 91003db..eb44ae9 100644
--- a/Include/internal/pycore_pystate.h
+++ b/Include/internal/pycore_pystate.h
@@ -125,6 +125,15 @@ struct _is {
struct _warnings_runtime_state warnings;
PyObject *audit_hooks;
+/*
+ * See bpo-36876: miscellaneous ad hoc statics have been moved here.
+ */
+ struct {
+ struct {
+ int level;
+ int atbol;
+ } listnode;
+ } parser;
};
PyAPI_FUNC(struct _is*) _PyInterpreterState_LookUpID(PY_INT64_T);
diff --git a/Parser/listnode.c b/Parser/listnode.c
index 8f1a116..d431ae5 100644
--- a/Parser/listnode.c
+++ b/Parser/listnode.c
@@ -2,6 +2,7 @@
/* List a node on a file */
#include "Python.h"
+#include "pycore_pystate.h"
#include "token.h"
#include "node.h"
@@ -15,19 +16,21 @@ PyNode_ListTree(node *n)
listnode(stdout, n);
}
-static int level, atbol;
-
static void
listnode(FILE *fp, node *n)
{
- level = 0;
- atbol = 1;
+ PyInterpreterState *interp = _PyInterpreterState_GET_UNSAFE();
+
+ interp->parser.listnode.level = 0;
+ interp->parser.listnode.atbol = 1;
list1node(fp, n);
}
static void
list1node(FILE *fp, node *n)
{
+ PyInterpreterState *interp;
+
if (n == NULL)
return;
if (ISNONTERMINAL(TYPE(n))) {
@@ -36,25 +39,26 @@ list1node(FILE *fp, node *n)
list1node(fp, CHILD(n, i));
}
else if (ISTERMINAL(TYPE(n))) {
+ interp = _PyInterpreterState_GET_UNSAFE();
switch (TYPE(n)) {
case INDENT:
- ++level;
+ interp->parser.listnode.level++;
break;
case DEDENT:
- --level;
+ interp->parser.listnode.level--;
break;
default:
- if (atbol) {
+ if (interp->parser.listnode.atbol) {
int i;
- for (i = 0; i < level; ++i)
+ for (i = 0; i < interp->parser.listnode.level; ++i)
fprintf(fp, "\t");
- atbol = 0;
+ interp->parser.listnode.atbol = 0;
}
if (TYPE(n) == NEWLINE) {
if (STR(n) != NULL)
fprintf(fp, "%s", STR(n));
fprintf(fp, "\n");
- atbol = 1;
+ interp->parser.listnode.atbol = 1;
}
else
fprintf(fp, "%s ", STR(n));