From: Benjamin Peterson Date: Fri, 8 Sep 2017 01:06:23 +0000 (-0700) Subject: optimize all_name_chars (#3442) X-Git-Tag: v3.7.0a1~105 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=9020ac7cce97dddad51b285fffc31fe4ddf60898;p=python optimize all_name_chars (#3442) Remove redundant PyUnicode_Check call. Use a static table for checking chars. --- diff --git a/Objects/codeobject.c b/Objects/codeobject.c index de8d16ce08..be2d7b22db 100644 --- a/Objects/codeobject.c +++ b/Objects/codeobject.c @@ -4,9 +4,6 @@ #include "code.h" #include "structmember.h" -#define NAME_CHARS \ - "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz" - /* Holder for co_extra information */ typedef struct { Py_ssize_t ce_size; @@ -18,23 +15,26 @@ typedef struct { static int all_name_chars(PyObject *o) { - static char ok_name_char[256]; - static const unsigned char *name_chars = (unsigned char *)NAME_CHARS; + /* [a-zA-Z0-9_] */ + static const bool ok_name_char[128] = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, + 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, + 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 + }; const unsigned char *s, *e; - if (!PyUnicode_Check(o) || PyUnicode_READY(o) == -1 || - !PyUnicode_IS_ASCII(o)) + if (PyUnicode_READY(o) == -1 || !PyUnicode_IS_ASCII(o)) return 0; - if (ok_name_char[*name_chars] == 0) { - const unsigned char *p; - for (p = name_chars; *p; p++) - ok_name_char[*p] = 1; - } s = PyUnicode_1BYTE_DATA(o); e = s + PyUnicode_GET_LENGTH(o); - while (s != e) { - if (ok_name_char[*s++] == 0) + for (; s != e; s++) { + if (!ok_name_char[*s]) return 0; } return 1;