aboutsummaryrefslogtreecommitdiffstats
path: root/src/metadataChunk.c
blob: d116698579df3e3f1d08f2b84a4a04698f488044 (plain) (blame)
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
/* the Music Player Daemon (MPD)
 * (c)2003-2006 by Warren Dukes (warren.dukes@gmail.com)
 * This project's homepage is: http://www.musicpd.org
 *
 * This program 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.
 *
 * This program 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 this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

#include "metadataChunk.h"
#include "gcc.h"

#include <string.h>

static void initMetadataChunk(MetadataChunk * chunk)
{
	chunk->name = -1;
	chunk->artist = -1;
	chunk->album = -1;
	chunk->title = -1;
}

#define dupElementToTag(item, element) { \
	if(element >= 0 && element < METADATA_BUFFER_LENGTH) { \
		addItemToMpdTag(ret, item, chunk->buffer+element); \
	} \
}

MpdTag *metadataChunkToMpdTagDup(MetadataChunk * chunk)
{
	MpdTag *ret = newMpdTag();

	chunk->buffer[METADATA_BUFFER_LENGTH - 1] = '\0';

	dupElementToTag(TAG_ITEM_NAME, chunk->name);
	dupElementToTag(TAG_ITEM_TITLE, chunk->title);
	dupElementToTag(TAG_ITEM_ARTIST, chunk->artist);
	dupElementToTag(TAG_ITEM_ALBUM, chunk->album);

	return ret;
}

#define copyStringToChunk(string, element) { \
	if(element < 0 && string && (slen = strlen(string)) && \
                        pos < METADATA_BUFFER_LENGTH-1) \
        { \
		size_t len = slen; \
		size_t max = METADATA_BUFFER_LENGTH - 1 - pos; \
		if (mpd_unlikely(len > max)) \
			len = max; \
		memcpy(chunk->buffer+pos, string, len); \
		*(chunk->buffer+pos+len) = '\0'; \
		element = pos; \
		pos += slen+1; \
	} \
}

void copyMpdTagToMetadataChunk(MpdTag * tag, MetadataChunk * chunk)
{
	int pos = 0;
	int slen;
	int i;

	initMetadataChunk(chunk);

	if (!tag)
		return;

	for (i = 0; i < tag->numOfItems; i++) {
		switch (tag->items[i].type) {
		case TAG_ITEM_NAME:
			copyStringToChunk(tag->items[i].value, chunk->name);
			break;
		case TAG_ITEM_TITLE:
			copyStringToChunk(tag->items[i].value, chunk->title);
			break;
		case TAG_ITEM_ARTIST:
			copyStringToChunk(tag->items[i].value, chunk->artist);
			break;
		case TAG_ITEM_ALBUM:
			copyStringToChunk(tag->items[i].value, chunk->album);
			break;
		}
	}
}