Fix bug with utils_string_replace_all().

Make utils_str_replace() call utils_string_replace_all() internally
(for better memory management and allowing replacements to match
search string).



git-svn-id: https://geany.svn.sourceforge.net/svnroot/geany/trunk@3226 ea778897-0a13-0410-b9d1-a72fbfd435f5
This commit is contained in:
Nick Treleaven 2008-11-14 14:15:32 +00:00
parent 44bff7b443
commit 0ef7d92782
3 changed files with 20 additions and 41 deletions

View File

@ -4,6 +4,11 @@
Prompt the user for whether to move the configuration directory or Prompt the user for whether to move the configuration directory or
just quit instead. This is useful if the user is already running an just quit instead. This is useful if the user is already running an
older binary of Geany and the second instance is newer. older binary of Geany and the second instance is newer.
* src/utils.c, src/editor.c:
Fix bug with utils_string_replace_all().
Make utils_str_replace() call utils_string_replace_all() internally
(for better memory management and allowing replacements to match
search string).
2008-11-13 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de> 2008-11-13 Enrico Tröger <enrico(dot)troeger(at)uvena(dot)de>

View File

@ -1813,9 +1813,8 @@ static gboolean snippets_complete_constructs(GeanyEditor *editor, gint pos, cons
pattern = snippets_global_pattern; pattern = snippets_global_pattern;
} }
/* replace line breaks and whitespaces */ /* add line indentation */
pattern = utils_str_replace(pattern, "\n", "%newline%"); /* to avoid endless replacing of \n */ pattern = utils_str_replace(pattern, "\n", lindent);
pattern = utils_str_replace(pattern, "%newline%", lindent);
/* replace any %template% wildcards */ /* replace any %template% wildcards */
pattern = snippets_replace_wildcards(editor, pattern); pattern = snippets_replace_wildcards(editor, pattern);

View File

@ -497,45 +497,19 @@ gint utils_is_file_writeable(const gchar *locale_filename)
/* Replaces all occurrences of needle in haystack with replacement. /* Replaces all occurrences of needle in haystack with replacement.
* New code should use utils_string_replace_all() instead. * Warning: haystack will be freed.
* All strings have to be NULL-terminated and needle and replacement have to be different, * New code should use utils_string_replace_all() instead (freeing arguments
* e.g. needle "%" and replacement "%%" causes an endless loop */ * is unusual behaviour).
* All strings have to be NULL-terminated.
* See utils_string_replace_all() for details. */
gchar *utils_str_replace(gchar *haystack, const gchar *needle, const gchar *replacement) gchar *utils_str_replace(gchar *haystack, const gchar *needle, const gchar *replacement)
{ {
gint i; GString *str = g_string_new(haystack);
gchar *start;
gint lt_pos;
gchar *result;
GString *str;
if (haystack == NULL)
return NULL;
if (needle == NULL || replacement == NULL)
return haystack;
if (utils_str_equal(needle, replacement))
return haystack;
start = strstr(haystack, needle);
lt_pos = utils_strpos(haystack, needle);
if (start == NULL || lt_pos == -1)
return haystack;
/* substitute by copying */
str = g_string_sized_new(strlen(haystack));
for (i = 0; i < lt_pos; i++)
{
g_string_append_c(str, haystack[i]);
}
g_string_append(str, replacement);
g_string_append(str, haystack + lt_pos + strlen(needle));
result = str->str;
g_free(haystack); g_free(haystack);
g_string_free(str, FALSE); utils_string_replace_all(str, needle, replacement);
return utils_str_replace(result, needle, replacement);
return g_string_free(str, FALSE);
} }
@ -1377,13 +1351,14 @@ gboolean utils_string_replace_all(GString *haystack, const gchar *needle, const
pos = match - haystack->str; pos = match - haystack->str;
g_string_erase(haystack, pos, strlen(needle)); g_string_erase(haystack, pos, strlen(needle));
/* next search is after removed matching text */ /* make next search after removed matching text.
stack = match; * (we have to be careful to only use haystack->str as its address may change) */
stack = haystack->str + pos;
if (replace) if (replace)
{ {
g_string_insert(haystack, pos, replace); g_string_insert(haystack, pos, replace);
stack += strlen(replace); /* don't replace replacements */ stack = haystack->str + pos + strlen(replace); /* skip past replacement */
} }
} }
} }