back to strncmp, is not clear if memcmp is faster
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@6272 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
82f2ee5db5
commit
f903ec5ac9
1 changed files with 11 additions and 10 deletions
|
|
@ -113,19 +113,20 @@ String_cmp(DOH *so1, DOH *so2)
|
||||||
{
|
{
|
||||||
String * s1 = (String *) ObjData(so1);
|
String * s1 = (String *) ObjData(so1);
|
||||||
String * s2 = (String *) ObjData(so2);
|
String * s2 = (String *) ObjData(so2);
|
||||||
register char *c1;
|
|
||||||
register char *c2;
|
|
||||||
register int len = s1->len;
|
register int len = s1->len;
|
||||||
if (len != s2->len) return (len < s2->len ) ? -1 : 1;
|
register char *c1 = s1->str;
|
||||||
c1 = s1->str;
|
register char *c2 = s2->str;
|
||||||
c2 = s2->str;
|
|
||||||
#if 1
|
#if 1
|
||||||
/* this is better, but it could be not present in all the
|
/* this is better, but strncmp could be not present in all the systems? */
|
||||||
systems ? */
|
if (len != s2->len) {
|
||||||
return memcmp(c1, c2, len);
|
return (len < s2->len) ? -1 : 1;
|
||||||
|
} else {
|
||||||
|
return strncmp(c1, c2, len);
|
||||||
|
}
|
||||||
#else
|
#else
|
||||||
/* faster loop with nonzero predicates */
|
register char *ce = c1 + len;
|
||||||
for (; len ; --len,++c1,++c2) {
|
if (len != s2->len) return (len < s2->len ) ? -1 : 1;
|
||||||
|
for (; c1 != ce ; ++c1, ++c2) {
|
||||||
if (*c1 != *c2) return ((*c1 < *c2) ? -1 : 1);
|
if (*c1 != *c2) return ((*c1 < *c2) ? -1 : 1);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue