* Fiddle with declarations, for small efficiency boost

This commit is contained in:
Matthew Honnibal 2014-09-13 00:31:53 +02:00
parent a8e7cce30f
commit 7d239df4c8

View File

@ -119,6 +119,7 @@ cdef class Language:
cdef uint64_t hashed = string.key cdef uint64_t hashed = string.key
cdef size_t first_token = tokens.length cdef size_t first_token = tokens.length
cdef int split
cdef int remaining = string.n cdef int remaining = string.n
cdef String prefix cdef String prefix
while remaining >= 1: while remaining >= 1:
@ -232,14 +233,13 @@ cdef void string_from_unicode(String* s, unicode uni):
string_from_slice(s, <Py_UNICODE*>uni, 0, len(uni)) string_from_slice(s, <Py_UNICODE*>uni, 0, len(uni))
cdef void string_from_slice(String* s, Py_UNICODE* chars, size_t start, size_t end): cdef inline void string_from_slice(String* s, Py_UNICODE* chars, size_t start, size_t end) nogil:
s.chars = &chars[start] s.chars = &chars[start]
s.n = end - start s.n = end - start
s.key = hash64(s.chars, s.n * sizeof(Py_UNICODE), 0) s.key = hash64(s.chars, s.n * sizeof(Py_UNICODE), 0)
cdef void string_slice_prefix(String* s, String* prefix, size_t n): cdef inline void string_slice_prefix(String* s, String* prefix, size_t n) nogil:
assert s.n >= n
string_from_slice(prefix, s.chars, 0, n) string_from_slice(prefix, s.chars, 0, n)
s.chars += n s.chars += n
s.n -= n s.n -= n