comparison src/libid3tag-0.15.1b/util.c @ 85:545efbb81310

Import initial set of sources
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 18 Mar 2013 14:12:14 +0000
parents
children
comparison
equal deleted inserted replaced
-1:000000000000 85:545efbb81310
1 /*
2 * libid3tag - ID3 tag manipulation library
3 * Copyright (C) 2000-2004 Underbit Technologies, Inc.
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 *
19 * $Id: util.c,v 1.9 2004/01/23 09:41:32 rob Exp $
20 */
21
22 # ifdef HAVE_CONFIG_H
23 # include "config.h"
24 # endif
25
26 # include "global.h"
27
28 # include <stdlib.h>
29 # include <zlib.h>
30
31 # include "id3tag.h"
32 # include "util.h"
33
34 /*
35 * NAME: util->unsynchronise()
36 * DESCRIPTION: perform (in-place) unsynchronisation
37 */
38 id3_length_t id3_util_unsynchronise(id3_byte_t *data, id3_length_t length)
39 {
40 id3_length_t bytes = 0, count;
41 id3_byte_t *end = data + length;
42 id3_byte_t const *ptr;
43
44 if (length == 0)
45 return 0;
46
47 for (ptr = data; ptr < end - 1; ++ptr) {
48 if (ptr[0] == 0xff && (ptr[1] == 0x00 || (ptr[1] & 0xe0) == 0xe0))
49 ++bytes;
50 }
51
52 if (bytes) {
53 ptr = end;
54 end += bytes;
55
56 *--end = *--ptr;
57
58 for (count = bytes; count; *--end = *--ptr) {
59 if (ptr[-1] == 0xff && (ptr[0] == 0x00 || (ptr[0] & 0xe0) == 0xe0)) {
60 *--end = 0x00;
61 --count;
62 }
63 }
64 }
65
66 return length + bytes;
67 }
68
69 /*
70 * NAME: util->deunsynchronise()
71 * DESCRIPTION: undo unsynchronisation (in-place)
72 */
73 id3_length_t id3_util_deunsynchronise(id3_byte_t *data, id3_length_t length)
74 {
75 id3_byte_t const *old, *end = data + length;
76 id3_byte_t *new;
77
78 if (length == 0)
79 return 0;
80
81 for (old = new = data; old < end - 1; ++old) {
82 *new++ = *old;
83 if (old[0] == 0xff && old[1] == 0x00)
84 ++old;
85 }
86
87 *new++ = *old;
88
89 return new - data;
90 }
91
92 /*
93 * NAME: util->compress()
94 * DESCRIPTION: perform zlib deflate method compression
95 */
96 id3_byte_t *id3_util_compress(id3_byte_t const *data, id3_length_t length,
97 id3_length_t *newlength)
98 {
99 id3_byte_t *compressed;
100
101 *newlength = length + 12;
102 *newlength += *newlength / 1000;
103
104 compressed = malloc(*newlength);
105 if (compressed) {
106 if (compress2(compressed, newlength, data, length,
107 Z_BEST_COMPRESSION) != Z_OK ||
108 *newlength >= length) {
109 free(compressed);
110 compressed = 0;
111 }
112 else {
113 id3_byte_t *resized;
114
115 resized = realloc(compressed, *newlength ? *newlength : 1);
116 if (resized)
117 compressed = resized;
118 }
119 }
120
121 return compressed;
122 }
123
124 /*
125 * NAME: util->decompress()
126 * DESCRIPTION: undo zlib deflate method compression
127 */
128 id3_byte_t *id3_util_decompress(id3_byte_t const *data, id3_length_t length,
129 id3_length_t newlength)
130 {
131 id3_byte_t *decompressed;
132
133 decompressed = malloc(newlength ? newlength : 1);
134 if (decompressed) {
135 id3_length_t size;
136
137 size = newlength;
138
139 if (uncompress(decompressed, &size, data, length) != Z_OK ||
140 size != newlength) {
141 free(decompressed);
142 decompressed = 0;
143 }
144 }
145
146 return decompressed;
147 }