[vlc-devel] commit: Add us_asprintf function (Michael Hanselmann )

git version control git at videolan.org
Tue Dec 2 18:04:00 CET 2008


vlc | branch: master | Michael Hanselmann <public at hansmi.ch> | Tue Dec  2 01:06:00 2008 +0100| [3df9e79877f9131b8a7f9700317a6d86877fbae6] | committer: Rémi Denis-Courmont 

Add us_asprintf function

us_asprintf() has the same prototype as asprintf(), but doesn't use
the system locale.

Signed-off-by: Michael Hanselmann <public at hansmi.ch>
Signed-off-by: Rémi Denis-Courmont <rdenis at simphalempin.com>

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=3df9e79877f9131b8a7f9700317a6d86877fbae6
---

 include/vlc_charset.h |    1 +
 src/libvlccore.sym    |    1 +
 src/text/charset.c    |   24 ++++++++++++++++++++++++
 3 files changed, 26 insertions(+), 0 deletions(-)

diff --git a/include/vlc_charset.h b/include/vlc_charset.h
index 5d3a1b5..6e5c4d7 100644
--- a/include/vlc_charset.h
+++ b/include/vlc_charset.h
@@ -85,5 +85,6 @@ VLC_EXPORT( const char *, GetFallbackEncoding, ( void ) LIBVLC_USED );
 
 VLC_EXPORT( double, us_strtod, ( const char *, char ** ) LIBVLC_USED );
 VLC_EXPORT( double, us_atof, ( const char * ) LIBVLC_USED );
+VLC_EXPORT( int, us_asprintf, ( char **, const char *, ... ) LIBVLC_USED );
 
 #endif
diff --git a/src/libvlccore.sym b/src/libvlccore.sym
index c8d40ba..24e5fc5 100644
--- a/src/libvlccore.sym
+++ b/src/libvlccore.sym
@@ -396,6 +396,7 @@ update_GetRelease
 update_NeedUpgrade
 __update_New
 update_WaitDownload
+us_asprintf
 us_atof
 us_strtod
 utf8_fopen
diff --git a/src/text/charset.c b/src/text/charset.c
index eaed11b..6d4d2a7 100644
--- a/src/text/charset.c
+++ b/src/text/charset.c
@@ -100,3 +100,27 @@ double us_atof( const char *str )
     return us_strtod( str, NULL );
 }
 
+
+/**
+ * us_asprintf() has the same prototype as asprintf(), but doesn't use
+ * the system locale.
+ */
+int us_asprintf( char **ret, const char *format, ... )
+{
+    va_list ap;
+    locale_t loc = newlocale( LC_NUMERIC_MASK, "C", NULL );
+    locale_t oldloc = uselocale( loc );
+    int i_rc;
+
+    va_start( ap, format );
+    i_rc = vasprintf( ret, format, ap );
+    va_end( ap );
+
+    if ( loc != (locale_t)0 )
+    {
+        uselocale( oldloc );
+        freelocale( loc );
+    }
+
+    return i_rc;
+}




More information about the vlc-devel mailing list