]> git.sesse.net Git - vlc/blob - src/extras/libc.c
* include/vlc_help.h src/libvlc.h: thou shalt not hardcode newlines in the middle...
[vlc] / src / extras / libc.c
1 /*****************************************************************************
2  * libc.c: Extra libc function for some systems.
3  *****************************************************************************
4  * Copyright (C) 2002 VideoLAN
5  * $Id: libc.c,v 1.10 2003/10/08 19:40:42 gbazin Exp $
6  *
7  * Authors: Jon Lech Johansen <jon-vl@nanocrew.net>
8  *          Samuel Hocevar <sam@zoy.org>
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program; if not, write to the Free Software
22  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
23  *****************************************************************************/
24 #include <string.h>                                              /* strdup() */
25 #include <stdlib.h>
26
27 #include <vlc/vlc.h>
28
29 /*****************************************************************************
30  * getenv: just in case, but it should never be called
31  *****************************************************************************/
32 #if !defined( HAVE_GETENV )
33 char *vlc_getenv( const char *name )
34 {
35     return NULL;
36 }
37 #endif
38
39 /*****************************************************************************
40  * strdup: returns a malloc'd copy of a string
41  *****************************************************************************/
42 #if !defined( HAVE_STRDUP )
43 char *vlc_strdup( const char *string )
44 {
45     return strndup( string, strlen( string ) );
46 }
47 #endif
48
49 /*****************************************************************************
50  * strndup: returns a malloc'd copy of at most n bytes of string
51  * Does anyone know whether or not it will be present in Jaguar?
52  *****************************************************************************/
53 #if !defined( HAVE_STRNDUP )
54 char *vlc_strndup( const char *string, size_t n )
55 {
56     char *psz;
57     size_t len = strlen( string );
58
59     len = __MIN( len, n );
60     psz = (char*)malloc( len + 1 );
61
62     if( psz != NULL )
63     {
64         memcpy( (void*)psz, (const void*)string, len );
65         psz[ len ] = 0;
66     }
67
68     return psz;
69 }
70 #endif
71
72 /*****************************************************************************
73  * strcasecmp: compare two strings ignoring case
74  *****************************************************************************/
75 #if !defined( HAVE_STRCASECMP ) && !defined( HAVE_STRICMP )
76 int vlc_strcasecmp( const char *s1, const char *s2 )
77 {
78     int i_delta = 0;
79
80     while( !i_delta && *s1 && *s2 )
81     {
82         i_delta = *s1 - *s2;
83
84         if( *s1 >= 'A' && *s1 <= 'Z' )
85         {
86             i_delta -= 'A' - 'a';
87         }
88
89         if( *s2 >= 'A' && *s2 <= 'Z' )
90         {
91             i_delta += 'A' - 'a';
92         }
93
94         s1++; s2++;
95     }
96
97     return i_delta;
98 }
99 #endif
100
101 /*****************************************************************************
102  * strncasecmp: compare n chars from two strings ignoring case
103  *****************************************************************************/
104 #if !defined( HAVE_STRNCASECMP ) && !defined( HAVE_STRNICMP )
105 int vlc_strncasecmp( const char *s1, const char *s2, size_t n )
106 {
107     int i_delta = 0;
108
109     while( n-- && !i_delta && *s1 )
110     {
111         i_delta = *s1 - *s2;
112
113         if( *s1 >= 'A' && *s1 <= 'Z' )
114         {
115             i_delta -= 'A' - 'a';
116         }
117
118         if( *s2 >= 'A' && *s2 <= 'Z' )
119         {
120             i_delta += 'A' - 'a';
121         }
122
123         s1++; s2++;
124     }
125
126     return i_delta;
127 }
128 #endif
129
130 /*****************************************************************************
131  * atof: convert a string to a double.
132  *****************************************************************************/
133 #if !defined( HAVE_ATOF )
134 double vlc_atof( const char *nptr )
135 {
136     double f_result;
137     wchar_t *psz_tmp;
138     int i_len = strlen( nptr ) + 1;
139
140     psz_tmp = malloc( i_len * sizeof(wchar_t) );
141     MultiByteToWideChar( CP_ACP, 0, nptr, -1, psz_tmp, i_len );
142     f_result = wcstod( psz_tmp, NULL );
143     free( psz_tmp );
144
145     return f_result;
146 }
147 #endif
148
149 /*****************************************************************************
150  * atoll: convert a string to a 64 bits int.
151  *****************************************************************************/
152 #if !defined( HAVE_ATOLL )
153 int64_t vlc_atoll( const char *str )
154 {
155     int64_t i_value = 0;
156     int sign = 1;
157
158     if( *str == '-' )
159     {
160         sign = -1;
161     }
162
163     while( *str >= '0' && *str <= '9' )
164     {
165         i_value = i_value * 10 + ( *str - '0' );
166     }
167
168     return i_value * sign;
169 }
170 #endif
171
172 /*****************************************************************************
173  * lseek: reposition read/write file offset.
174  *****************************************************************************
175  * FIXME: this cast sucks!
176  *****************************************************************************/
177 #if !defined( HAVE_LSEEK )
178 off_t vlc_lseek( int fildes, off_t offset, int whence )
179 {
180     return SetFilePointer( (HANDLE)fildes, (long)offset, NULL, whence );
181 }
182 #endif
183
184 /*****************************************************************************
185  * dgettext: gettext for plugins.
186  *****************************************************************************/
187 char *vlc_dgettext( const char *package, const char *msgid )
188 {
189 #if defined( ENABLE_NLS ) \
190      && ( defined(HAVE_GETTEXT) || defined(HAVE_INCLUDED_GETTEXT) )
191     return dgettext( package, msgid );
192 #else
193     return (char *)msgid;
194 #endif
195 }
196
197 /*****************************************************************************
198  * count_utf8_string: returns the number of characters in the string.
199  *****************************************************************************/
200 static int count_utf8_string( const char *psz_string )
201 {
202     int i = 0, i_count = 0;
203     while( psz_string[ i ] != 0 )
204     {
205         if( ((unsigned char *)psz_string)[ i ] <  0x80UL ) i_count++;
206         i++;
207     }
208     return i_count;
209 }
210
211 /*****************************************************************************
212  * wraptext: inserts \n at convenient places to wrap the text.
213  *           Returns the modified string in a new buffer.
214  *****************************************************************************/
215 char *vlc_wraptext( const char *psz_text, int i_line, vlc_bool_t b_utf8 )
216 {
217     int i_len;
218     char *psz_line, *psz_new_text;
219
220     psz_line = psz_new_text = strdup( psz_text );
221
222     if( b_utf8 )
223         i_len = count_utf8_string( psz_text );
224     else
225         i_len = strlen( psz_text );
226
227     while( i_len > i_line )
228     {
229         /* Look if there is a newline somewhere. */
230         char *psz_parser = psz_line;
231         int i_count = 0;
232         while( i_count <= i_line && *psz_parser != '\n' )
233         {
234             if( b_utf8 )
235             {
236                 while( *((unsigned char *)psz_parser) >= 0x80UL ) psz_parser++;
237             }
238             psz_parser++;
239             i_count++;
240         }
241         if( *psz_parser == '\n' )
242         {
243             i_len -= (i_count + 1);
244             psz_line = psz_parser + 1;
245             continue;
246         }
247
248         /* Find the furthest space. */
249         while( psz_parser > psz_line && *psz_parser != ' ' )
250         {
251             if( b_utf8 )
252             {
253                 while( *((unsigned char *)psz_parser) >= 0x80UL ) psz_parser--;
254             }
255             psz_parser--;
256             i_count--;
257         }
258         if( *psz_parser == ' ' )
259         {
260             *psz_parser = '\n';
261             i_len -= (i_count + 1);
262             psz_line = psz_parser + 1;
263             continue;
264         }
265
266         /* Wrapping has failed. Find the first space or newline */
267         while( i_count < i_len && *psz_parser != ' ' && *psz_parser != '\n' )
268         {
269             if( b_utf8 )
270             {
271                 while( *((unsigned char *)psz_parser) >= 0x80UL ) psz_parser++;
272             }
273             psz_parser++;
274             i_count++;
275         }
276         if( i_count < i_len ) *psz_parser = '\n';
277         i_len -= (i_count + 1);
278         psz_line = psz_parser + 1;
279     }
280
281     return psz_new_text;
282 }