]> git.sesse.net Git - vlc/commitdiff
config_StringEscape: iterate through string twice rather than 3 times
authorRémi Denis-Courmont <remi@remlab.net>
Sun, 1 May 2011 14:37:16 +0000 (17:37 +0300)
committerRémi Denis-Courmont <remi@remlab.net>
Sun, 1 May 2011 14:37:16 +0000 (17:37 +0300)
src/config/chain.c

index d7f063307e5dfaf6b069444f129141ab79d642dd..4ef60be922aa19c80d5c64b0c4487930549b756c 100644 (file)
@@ -451,32 +451,23 @@ char *config_StringUnescape( char *psz_string )
     return psz_string;
 }
 
-char *config_StringEscape( const char *psz_string )
+char *config_StringEscape( const char *str )
 {
-    char *psz_return;
-    char *psz_dst;
-    int i_escape;
+    size_t length = 0;
 
-    if( !psz_string )
+    if( str == NULL )
         return NULL;
 
-    i_escape = 0;
-    for( const char *p = psz_string; *p; p++ )
-    {
-        if( IsEscapeNeeded( *p ) )
-            i_escape++;
-    }
+    for( const char *p = str; *p; p++ )
+        length += IsEscapeNeeded( *p ) ? 2 : 1;
 
-    psz_return = psz_dst = malloc( strlen( psz_string ) + i_escape + 1 );
-    for( const char *p = psz_string; *p; p++ )
+    char *ret = xmalloc( length + 1 ), *dst = ret;
+    for( const char *p = str; *p; p++ )
     {
         if( IsEscapeNeeded( *p ) )
-            *psz_dst++ = '\\';
-        *psz_dst++ = *p;
+            *dst++ = '\\';
+        *dst++ = *p;
     }
-    *psz_dst = '\0';
-
-    return psz_return;
+    *dst = '\0';;
+    return ret;
 }
-
-