On Fri, 5 Apr 2019, 09:26 Benjamin Coutu, <ben.co...@zeyos.com> wrote:

> Hello,
>
> I was surprised to find out that equality checks on zend_string do not
> take advantage of the fact that in many cases we have a hash key available
> that can be utilized in a quick bailout path without having to resort to a
> costly `memcmp` on the value.
>
> I recommend to modify `zend_string_equal_content` like so:
>
> static zend_always_inline zend_bool zend_string_equal_content(zend_string
> *s1, zend_string *s2)
> {
>   if (ZSTR_LEN(s1) != ZSTR_LEN(s2)) {
>     return 0;
>   }
>
>   if (ZSTR_H(s1) && ZSTR_H(s1) != ZSTR_H(s2)) {
>     return 0;
>   }
>
>   return zend_string_equal_val(s1, s2);
> }
>
> Thoughts?
>
> --
>
> Benjamin Coutu
> ben.co...@zeyos.com
>

Best idea would be to do a PR on the GitHub repo.

Best regards

George Peter Banyard

Reply via email to