From 4338a0e55e9c62eb7469f7b99dcafeeb97eb53cd Mon Sep 17 00:00:00 2001 From: Daniel Date: Mon, 5 Dec 2016 21:03:05 +0000 Subject: [PATCH] Fix the check for a percent character It was matching everything less than 0x26, so could cause a minor performance loss. Also made the second if statement superfluous. --- stb_sprintf.h | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/stb_sprintf.h b/stb_sprintf.h index 4e3b3c0..e4ca291 100644 --- a/stb_sprintf.h +++ b/stb_sprintf.h @@ -247,9 +247,12 @@ STBSP__PUBLICDEF int STB_SPRINTF_DECORATE( vsprintfcb )( STBSP_SPRINTFCB * callb } for(;;) { + // Check if the next 4 bytes contain %(0x25) or end of string. + // Using the 'hasless' trick: + // https://graphics.stanford.edu/~seander/bithacks.html#HasLessInWord stbsp__uint32 v,c; v=*(stbsp__uint32*)f; c=(~v)&0x80808080; - if ((v-0x26262626)&c) goto schk1; + if (((v^0x25252525)-0x01010101)&c) goto schk1; if ((v-0x01010101)&c) goto schk2; if (callback) if ((STB_SPRINTF_MIN-(int)(bf-buf))<4) goto schk1; *(stbsp__uint32*)bf=v; bf+=4; f+=4;