1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
|
/*
* xbuffer code
*
* Includes a minimalistic replacement for xine_buffer functions used in
* Real streaming code. Only function needed by this code are implemented.
*
* Most code comes from xine_buffer.c Copyright (C) 2002 the xine project
*
* WARNING: do not mix original xine_buffer functions with this code!
* xbuffers behave like xine_buffers, but are not byte-compatible with them.
* You must take care of pointers returned by xbuffers functions (no macro to
* do it automatically)
*
* This file is part of MPlayer.
*
* MPlayer is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* MPlayer is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with MPlayer; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include <stdlib.h>
#include <string.h>
#include <inttypes.h>
#include "xbuffer.h"
typedef struct {
uint32_t size;
uint32_t chunk_size;
} xbuffer_header_t;
#define XBUFFER_HEADER_SIZE sizeof (xbuffer_header_t)
void *xbuffer_init(int chunk_size) {
uint8_t *data=calloc(1,chunk_size+XBUFFER_HEADER_SIZE);
xbuffer_header_t *header=(xbuffer_header_t*)data;
header->size=chunk_size;
header->chunk_size=chunk_size;
return data+XBUFFER_HEADER_SIZE;
}
void *xbuffer_free(void *buf) {
if (!buf) {
return NULL;
}
free(((uint8_t*)buf)-XBUFFER_HEADER_SIZE);
return NULL;
}
void *xbuffer_copyin(void *buf, int index, const void *data, int len) {
if (!buf || !data) {
return NULL;
}
buf = xbuffer_ensure_size(buf, index+len);
memcpy(((uint8_t*)buf)+index, data, len);
return buf;
}
void *xbuffer_ensure_size(void *buf, int size) {
xbuffer_header_t *xbuf;
int new_size;
if (!buf) {
return 0;
}
xbuf = ((xbuffer_header_t*)(((uint8_t*)buf)-XBUFFER_HEADER_SIZE));
if (xbuf->size < size) {
new_size = size + xbuf->chunk_size - (size % xbuf->chunk_size);
xbuf->size = new_size;
buf = ((uint8_t*)realloc(((uint8_t*)buf)-XBUFFER_HEADER_SIZE,
new_size+XBUFFER_HEADER_SIZE)) + XBUFFER_HEADER_SIZE;
}
return buf;
}
void *xbuffer_strcat(void *buf, char *data) {
if (!buf || !data) {
return NULL;
}
buf = xbuffer_ensure_size(buf, strlen(buf)+strlen(data)+1);
strcat(buf, data);
return buf;
}
|