* libc.c: Extra libc function for some systems.
*****************************************************************************
* Copyright (C) 2002 VideoLAN
- * $Id: libc.c,v 1.6 2002/12/30 13:34:03 sam Exp $
+ * $Id: libc.c,v 1.16 2004/02/09 16:12:25 sigmunau Exp $
*
* Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
* Samuel Hocevar <sam@zoy.org>
}
#endif
+/*****************************************************************************
+ * vasprintf:
+ *****************************************************************************/
+#if !defined(HAVE_VASPRINTF) || defined(SYS_DARWIN) || defined(SYS_BEOS)
+int vlc_vasprintf(char **strp, const char *fmt, va_list ap)
+{
+ /* Guess we need no more than 100 bytes. */
+ int i_size = 100;
+ char *p = malloc( i_size );
+ int n;
+
+ if( p == NULL )
+ {
+ *strp = NULL;
+ return -1;
+ }
+
+ for( ;; )
+ {
+ /* Try to print in the allocated space. */
+ n = vsnprintf( p, i_size, fmt, ap );
+
+ /* If that worked, return the string. */
+ if (n > -1 && n < i_size)
+ {
+ *strp = p;
+ return strlen( p );
+ }
+ /* Else try again with more space. */
+ if (n > -1) /* glibc 2.1 */
+ {
+ i_size = n+1; /* precisely what is needed */
+ }
+ else /* glibc 2.0 */
+ {
+ i_size *= 2; /* twice the old size */
+ }
+ if( (p = realloc( p, i_size ) ) == NULL)
+ {
+ *strp = NULL;
+ return -1;
+ }
+ }
+}
+#endif
+
+/*****************************************************************************
+ * asprintf:
+ *****************************************************************************/
+#if !defined(HAVE_ASPRINTF) || defined(SYS_DARWIN) || defined(SYS_BEOS)
+int vlc_asprintf( char **strp, const char *fmt, ... )
+{
+ va_list args;
+ int i_ret;
+
+ va_start( args, fmt );
+ i_ret = vasprintf( strp, fmt, args );
+ va_end( args );
+
+ return i_ret;
+}
+#endif
+
/*****************************************************************************
* atof: convert a string to a double.
*****************************************************************************/
}
#endif
+/*****************************************************************************
+ * atoll: convert a string to a 64 bits int.
+ *****************************************************************************/
+#if !defined( HAVE_ATOLL )
+int64_t vlc_atoll( const char *str )
+{
+ int64_t i_value = 0;
+ int sign = 1;
+
+ if( *str == '-' )
+ {
+ sign = -1;
+ }
+
+ while( *str >= '0' && *str <= '9' )
+ {
+ i_value = i_value * 10 + ( *str++ - '0' );
+ }
+
+ return i_value * sign;
+}
+#endif
+
/*****************************************************************************
* lseek: reposition read/write file offset.
*****************************************************************************
#endif
}
+/*****************************************************************************
+ * count_utf8_string: returns the number of characters in the string.
+ *****************************************************************************/
+static int count_utf8_string( const char *psz_string )
+{
+ int i = 0, i_count = 0;
+ while( psz_string[ i ] != 0 )
+ {
+ if( ((unsigned char *)psz_string)[ i ] < 0x80UL ) i_count++;
+ i++;
+ }
+ return i_count;
+}
+
+/*****************************************************************************
+ * wraptext: inserts \n at convenient places to wrap the text.
+ * Returns the modified string in a new buffer.
+ *****************************************************************************/
+char *vlc_wraptext( const char *psz_text, int i_line, vlc_bool_t b_utf8 )
+{
+ int i_len;
+ char *psz_line, *psz_new_text;
+
+ psz_line = psz_new_text = strdup( psz_text );
+
+ if( b_utf8 )
+ i_len = count_utf8_string( psz_text );
+ else
+ i_len = strlen( psz_text );
+
+ while( i_len > i_line )
+ {
+ /* Look if there is a newline somewhere. */
+ char *psz_parser = psz_line;
+ int i_count = 0;
+ while( i_count <= i_line && *psz_parser != '\n' )
+ {
+ if( b_utf8 )
+ {
+ while( *((unsigned char *)psz_parser) >= 0x80UL ) psz_parser++;
+ }
+ psz_parser++;
+ i_count++;
+ }
+ if( *psz_parser == '\n' )
+ {
+ i_len -= (i_count + 1);
+ psz_line = psz_parser + 1;
+ continue;
+ }
+
+ /* Find the furthest space. */
+ while( psz_parser > psz_line && *psz_parser != ' ' )
+ {
+ if( b_utf8 )
+ {
+ while( *((unsigned char *)psz_parser) >= 0x80UL ) psz_parser--;
+ }
+ psz_parser--;
+ i_count--;
+ }
+ if( *psz_parser == ' ' )
+ {
+ *psz_parser = '\n';
+ i_len -= (i_count + 1);
+ psz_line = psz_parser + 1;
+ continue;
+ }
+
+ /* Wrapping has failed. Find the first space or newline */
+ while( i_count < i_len && *psz_parser != ' ' && *psz_parser != '\n' )
+ {
+ if( b_utf8 )
+ {
+ while( *((unsigned char *)psz_parser) >= 0x80UL ) psz_parser++;
+ }
+ psz_parser++;
+ i_count++;
+ }
+ if( i_count < i_len ) *psz_parser = '\n';
+ i_len -= (i_count + 1);
+ psz_line = psz_parser + 1;
+ }
+
+ return psz_new_text;
+}