Kaydet (Commit) 965ef1a2 authored tarafından Colomban Wendling's avatar Colomban Wendling

Cleanup utils_strpos()

Use strstr() to find the substring, which makes the code simpler and
is way faster (new version is nearly 2 times faster on my machine).

git-svn-id: https://geany.svn.sourceforge.net/svnroot/geany/trunk@5994 ea778897-0a13-0410-b9d1-a72fbfd435f5
üst 7ff6f6b7
...@@ -697,39 +697,16 @@ void utils_str_replace_all(gchar **haystack, const gchar *needle, const gchar *r ...@@ -697,39 +697,16 @@ void utils_str_replace_all(gchar **haystack, const gchar *needle, const gchar *r
gint utils_strpos(const gchar *haystack, const gchar *needle) gint utils_strpos(const gchar *haystack, const gchar *needle)
{ {
gint haystack_length = strlen(haystack); const gchar *sub;
gint needle_length = strlen(needle);
gint i, j, pos = -1;
if (needle_length > haystack_length) if (! *needle)
{
return -1; return -1;
}
else sub = strstr(haystack, needle);
{ if (! sub)
for (i = 0; (i < haystack_length) && pos == -1; i++) return -1;
{
if (haystack[i] == needle[0] && needle_length == 1) return sub - haystack;
return i;
else if (haystack[i] == needle[0])
{
for (j = 1; (j < needle_length); j++)
{
if (haystack[i + j] == needle[j])
{
if (pos == -1)
pos = i;
}
else
{
pos = -1;
break;
}
}
}
}
return pos;
}
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment