]> git.sesse.net Git - vlc/blob - modules/access/mms/var_buffer.h
* modules/demux/asf/.cvsignore : put the good one.
[vlc] / modules / access / mms / var_buffer.h
1 /*****************************************************************************
2  * var_buffer.h: MMS access plug-in
3  *****************************************************************************
4  * Copyright (C) 2001, 2002 VideoLAN
5  * $Id: var_buffer.h,v 1.1 2002/11/12 00:54:40 fenrir Exp $
6  *
7  * Authors: Laurent Aimar <fenrir@via.ecp.fr>
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  * 
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
22  *****************************************************************************/
23
24 typedef struct var_buffer_s
25 {
26     uint8_t *p_data;    // pointer on data
27     int     i_data;     // number of bytes set in p_data
28
29     // private
30     int    i_size;     // size of p_data memory allocated
31 } var_buffer_t;
32
33
34 /*****************************************************************************
35  * Macro/Function to create/manipulate buffer 
36  *****************************************************************************/
37 static inline int       var_buffer_initwrite( var_buffer_t *p_buf, 
38                                               int i_default_size );
39 static inline int       var_buffer_reinitwrite( var_buffer_t *p_buf, 
40                                                 int i_default_size );
41 static inline void var_buffer_add8 ( var_buffer_t *p_buf, uint8_t  i_byte );
42 static inline void var_buffer_add16( var_buffer_t *p_buf, uint16_t i_word );
43 static inline void var_buffer_add32( var_buffer_t *p_buf, uint32_t i_word );
44 static inline void var_buffer_add64( var_buffer_t *p_buf, uint64_t i_word );
45 static inline void var_buffer_addmemory( var_buffer_t *p_buf, 
46                                          void *p_mem, int i_mem );
47 static inline void var_buffer_addUTF16( var_buffer_t *p_buf, char *p_str );
48 static inline void var_buffer_free( var_buffer_t *p_buf );
49
50
51 static inline void      var_buffer_initread( var_buffer_t *p_buf,
52                                              void *p_data, int i_data );
53 static inline uint8_t   var_buffer_get8 ( var_buffer_t *p_buf );
54 static inline uint16_t  var_buffer_get16( var_buffer_t *p_buf );
55 static inline uint32_t  var_buffer_get32( var_buffer_t *p_buf );
56 static inline uint64_t  var_buffer_get64( var_buffer_t *p_buf );
57 static inline int       var_buffer_getmemory ( var_buffer_t *p_buf, 
58                                                void *p_mem, int i_mem );
59 static inline int       var_buffer_readempty( var_buffer_t *p_buf );
60 static inline void      var_buffer_getguid( var_buffer_t *p_buf, 
61                                             guid_t *p_guid );
62
63
64
65 /*****************************************************************************
66  *****************************************************************************/
67
68 static inline int var_buffer_initwrite( var_buffer_t *p_buf, 
69                                         int i_default_size )
70 {
71     p_buf->i_size =  ( i_default_size > 0 ) ? i_default_size : 2048;
72     p_buf->i_data = 0;
73     if( !( p_buf->p_data = malloc( p_buf->i_size ) ) )
74     {
75         return( -1 );
76     }
77     return( 0 );
78 }
79 static inline int var_buffer_reinitwrite( var_buffer_t *p_buf, 
80                                           int i_default_size )
81 {
82     p_buf->i_data = 0;
83     if( p_buf->i_size < i_default_size ) 
84     {
85         p_buf->i_size = i_default_size;
86         if( p_buf->p_data )
87         {
88             free( p_buf->p_data );
89         }
90         p_buf->p_data = malloc( p_buf->i_size );
91     }
92     if( !p_buf->p_data )
93     {
94         p_buf->i_size =  ( i_default_size > 0 ) ? i_default_size : 2048;
95         p_buf->p_data = malloc( p_buf->i_size );
96     }
97     if( !p_buf->p_data )
98     {
99         return( -1 );
100     }
101     return( 0 );
102 }
103
104 static inline void var_buffer_add8 ( var_buffer_t *p_buf, uint8_t  i_byte )
105 {
106     /* check if there is enough data */
107     if( p_buf->i_data >= p_buf->i_size )
108     {
109         p_buf->i_size += 1024;
110         p_buf->p_data = realloc( p_buf->p_data, p_buf->i_size );
111     }
112     p_buf->p_data[p_buf->i_data] = i_byte&0xff;
113     p_buf->i_data++;
114 }
115
116 static inline void var_buffer_add16( var_buffer_t *p_buf, uint16_t i_word )
117 {
118     var_buffer_add8( p_buf, i_word&0xff );
119     var_buffer_add8( p_buf, ( i_word >> 8 )&0xff );
120 }
121 static inline void var_buffer_add32( var_buffer_t *p_buf, uint32_t i_dword )
122 {
123     var_buffer_add16( p_buf, i_dword&0xffff );
124     var_buffer_add16( p_buf, ( i_dword >> 16 )&0xffff );
125 }
126 static inline void var_buffer_add64( var_buffer_t *p_buf, uint64_t i_long )
127 {
128     var_buffer_add32( p_buf, i_long&0xffffffff );
129     var_buffer_add32( p_buf, ( i_long >> 32 )&0xffffffff );
130 }
131
132
133 static inline void var_buffer_addmemory( var_buffer_t *p_buf, 
134                                          void *p_mem, int i_mem )
135 {    
136     /* check if there is enough data */
137     if( p_buf->i_data + i_mem >= p_buf->i_size )
138     {
139         p_buf->i_size += i_mem + 1024;
140         p_buf->p_data = realloc( p_buf->p_data, p_buf->i_size );
141     }
142     
143     memcpy( p_buf->p_data + p_buf->i_data,
144             p_mem,
145             i_mem );
146     p_buf->i_data += i_mem;
147 }
148
149 static inline void var_buffer_addUTF16( var_buffer_t *p_buf, char *p_str )
150 {
151     int i;
152     if( !p_str )
153     {
154         var_buffer_add16( p_buf, 0 );
155     }
156     else
157     {
158         for( i = 0; i < strlen( p_str ) + 1; i++ ) // and 0
159         {
160             var_buffer_add16( p_buf, p_str[i] );
161         }
162     }
163 }
164
165 static inline void     var_buffer_free( var_buffer_t *p_buf )
166 {
167     if( p_buf->p_data )
168     {
169         free( p_buf->p_data );
170     }
171     p_buf->i_data = 0;
172     p_buf->i_size = 0;
173 }
174
175 static inline void var_buffer_initread( var_buffer_t *p_buf,
176                                         void *p_data, int i_data )
177 {
178     p_buf->i_size = i_data;
179     p_buf->i_data = 0;
180     p_buf->p_data = p_data;
181 }
182
183 static inline uint8_t  var_buffer_get8 ( var_buffer_t *p_buf )
184 {
185     uint8_t  i_byte;
186     if( p_buf->i_data >= p_buf->i_size )
187     {
188         return( 0 );
189     }
190     i_byte = p_buf->p_data[p_buf->i_data];
191     p_buf->i_data++;
192     return( i_byte );
193 }
194
195
196 static inline uint16_t var_buffer_get16( var_buffer_t *p_buf )
197 {
198     uint16_t i_b1, i_b2;
199     
200     i_b1 = var_buffer_get8( p_buf );
201     i_b2 = var_buffer_get8( p_buf );
202
203     return( i_b1 + ( i_b2 << 8 ) );
204
205 }
206 static inline uint32_t var_buffer_get32( var_buffer_t *p_buf )
207 {
208     uint32_t i_w1, i_w2;
209     
210     i_w1 = var_buffer_get16( p_buf );
211     i_w2 = var_buffer_get16( p_buf );
212
213     return( i_w1 + ( i_w2 << 16 ) );
214 }
215 static inline uint64_t var_buffer_get64( var_buffer_t *p_buf )
216 {
217     uint64_t i_dw1, i_dw2;
218     
219     i_dw1 = var_buffer_get32( p_buf );
220     i_dw2 = var_buffer_get32( p_buf );
221
222     return( i_dw1 + ( i_dw2 << 32 ) );
223 }
224 static inline int var_buffer_getmemory ( var_buffer_t *p_buf, 
225                                          void *p_mem, int i_mem )
226 {
227     int i_copy;
228
229     i_copy = __MIN( i_mem, p_buf->i_size - p_buf->i_data );
230     if( i_copy > 0 && p_mem != NULL)
231     {
232         memcpy( p_mem, p_buf + p_buf->i_data, i_copy );
233     }
234     p_buf->i_data += i_copy;
235     return( i_copy );
236 }
237
238 static inline int var_buffer_readempty( var_buffer_t *p_buf )
239 {
240     return( ( p_buf->i_data >= p_buf->i_size ) ? 1 : 0 );
241 }
242
243 static inline void var_buffer_getguid( var_buffer_t *p_buf, guid_t *p_guid )
244 {
245     int i;
246     
247     p_guid->v1 = var_buffer_get32( p_buf );
248     p_guid->v2 = var_buffer_get16( p_buf );
249     p_guid->v3 = var_buffer_get16( p_buf );
250
251     for( i = 0; i < 8; i++ )
252     {
253         p_guid->v4[i] = var_buffer_get8( p_buf );
254     }
255 }
256