From efdfee065aa3d2273727dd4bddd137cf3b60a5fc Mon Sep 17 00:00:00 2001 From: Nikolai Kondrashov Date: Wed, 9 Sep 2020 17:31:08 +0300 Subject: [PATCH] Use PyBytes_AsStringAndSize() Let Python give us the length of the "bytes" it already knows, instead of doing an strlen(). This improves performance a bit. --- jq.pyx | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/jq.pyx b/jq.pyx index 3ea6b02..11af984 100644 --- a/jq.pyx +++ b/jq.pyx @@ -1,7 +1,7 @@ import json import threading -from cpython.bytes cimport PyBytes_AsString +from cpython.bytes cimport PyBytes_AsStringAndSize cdef extern from "jv.h": @@ -161,10 +161,11 @@ cdef class _Parser(object): cdef bint _ready_next_bytes(self) except 1: cdef char* cbytes + cdef ssize_t clen try: self._bytes = next(self._text_iter).encode("utf8") - cbytes = PyBytes_AsString(self._bytes) - jv_parser_set_buf(self._parser, cbytes, len(cbytes), 1) + PyBytes_AsStringAndSize(self._bytes, &cbytes, &clen) + jv_parser_set_buf(self._parser, cbytes, clen, 1) except StopIteration: self._bytes = None jv_parser_set_buf(self._parser, "", 0, 0) @@ -349,8 +350,10 @@ cdef class _ResultIterator(object): self._bytes_input = bytes_input self._ready = False cdef jv_parser* parser = jv_parser_new(0) - cdef char* cbytes_input = PyBytes_AsString(bytes_input) - jv_parser_set_buf(parser, cbytes_input, len(cbytes_input), 0) + cdef char* cbytes_input + cdef ssize_t clen_input + PyBytes_AsStringAndSize(bytes_input, &cbytes_input, &clen_input) + jv_parser_set_buf(parser, cbytes_input, clen_input, 0) self._parser = parser def __iter__(self):