diff options
| author | Serhiy Storchaka <storchaka@gmail.com> | 2021-10-04 14:11:26 +0300 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-10-04 14:11:26 +0300 | 
| commit | 252b7bcb236dc261f3af1275bc90f9a303d9648f (patch) | |
| tree | e259c0287bf2b02f7998d5ec9ae00a1c80d79af1 /Objects/codeobject.c | |
| parent | 9be930f9b169fb3d92693670ae069df902709b83 (diff) | |
| download | cpython-git-252b7bcb236dc261f3af1275bc90f9a303d9648f.tar.gz | |
bpo-45355: More use of sizeof(_Py_CODEUNIT) (GH-28720)
Diffstat (limited to 'Objects/codeobject.c')
| -rw-r--r-- | Objects/codeobject.c | 16 | 
1 files changed, 6 insertions, 10 deletions
| diff --git a/Objects/codeobject.c b/Objects/codeobject.c index ad8f13a781..8de5c4d9c8 100644 --- a/Objects/codeobject.c +++ b/Objects/codeobject.c @@ -656,15 +656,13 @@ _PyCode_Addr2Offset(PyCodeObject* co, int addrq)      if (co->co_columntable == Py_None || addrq < 0) {          return -1;      } -    if (addrq % 2 == 1) { -        --addrq; -    } -    if (addrq >= PyBytes_GET_SIZE(co->co_columntable)) { +    addrq /= sizeof(_Py_CODEUNIT); +    if (addrq*2 >= PyBytes_GET_SIZE(co->co_columntable)) {          return -1;      }      unsigned char* bytes = (unsigned char*)PyBytes_AS_STRING(co->co_columntable); -    return bytes[addrq] - 1; +    return bytes[addrq*2] - 1;  }  int @@ -673,15 +671,13 @@ _PyCode_Addr2EndOffset(PyCodeObject* co, int addrq)      if (co->co_columntable == Py_None || addrq < 0) {          return -1;      } -    if (addrq % 2 == 0) { -        ++addrq; -    } -    if (addrq >= PyBytes_GET_SIZE(co->co_columntable)) { +    addrq /= sizeof(_Py_CODEUNIT); +    if (addrq*2+1 >= PyBytes_GET_SIZE(co->co_columntable)) {          return -1;      }      unsigned char* bytes = (unsigned char*)PyBytes_AS_STRING(co->co_columntable); -    return bytes[addrq] - 1; +    return bytes[addrq*2+1] - 1;  }  void | 
