diff options
author | Adam <Adam@anope.org> | 2010-06-19 11:54:08 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-06-19 11:54:08 -0400 |
commit | 52058fe87b4b0475b1775198c725af14e540d355 (patch) | |
tree | c3597d6411a006ffbb670d2ce761101b9640e9b6 /src/compat.cpp | |
parent | 43e951aed54f838ba55a4c1552214773aee2fb2f (diff) | |
parent | df9d291bcba9788e51d11424ebaf6f05c26cc80f (diff) |
Merge remote branch 'origin/1.9.3' into 1.9
Diffstat (limited to 'src/compat.cpp')
-rw-r--r-- | src/compat.cpp | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/src/compat.cpp b/src/compat.cpp new file mode 100644 index 000000000..eb3088fe9 --- /dev/null +++ b/src/compat.cpp @@ -0,0 +1,58 @@ +/* Compatibility routines. + * + * (C) 2003-2010 Anope Team + * Contact us at team@anope.org + * + * Please read COPYING and README for further details. + * + * Based on the original code of Epona by Lara. + * Based on the original code of Services by Andy Church. + * + * + */ + +#include "services.h" + +/*************************************************************************/ + +#if !HAVE_STRICMP && !HAVE_STRCASECMP + +/* stricmp, strnicmp: Case-insensitive versions of strcmp() and + * strncmp(). + */ + +int stricmp(const char *s1, const char *s2) +{ + register int c; + + while ((c = tolower(*s1)) == tolower(*s2)) { + if (c == 0) + return 0; + s1++; + s2++; + } + if (c < tolower(*s2)) + return -1; + return 1; +} + +int strnicmp(const char *s1, const char *s2, size_t len) +{ + register int c; + + if (!len) + return 0; + while ((c = tolower(*s1)) == tolower(*s2) && len > 0) { + if (c == 0 || --len == 0) + return 0; + s1++; + s2++; + } + if (c < tolower(*s2)) + return -1; + return 1; +} +#endif + +/*************************************************************************/ + |