song.h 2.2 KB
Newer Older
Warren Dukes's avatar
Warren Dukes committed
1
/* the Music Player Daemon (MPD)
2
 * Copyright (C) 2003-2007 by Warren Dukes (warren.dukes@gmail.com)
Warren Dukes's avatar
Warren Dukes committed
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
 * 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
 */

19 20
#ifndef MPD_SONG_H
#define MPD_SONG_H
Warren Dukes's avatar
Warren Dukes committed
21

22 23
#include <stddef.h>
#include <stdbool.h>
24
#include <sys/time.h>
Warren Dukes's avatar
Warren Dukes committed
25

Warren Dukes's avatar
Warren Dukes committed
26 27 28
#define SONG_BEGIN	"songList begin"
#define SONG_END	"songList end"

29 30 31
#define SONG_FILE	"file: "
#define SONG_TIME	"Time: "

32
struct song {
33
	struct tag *tag;
Max Kellermann's avatar
Max Kellermann committed
34
	struct directory *parent;
Warren Dukes's avatar
Warren Dukes committed
35
	time_t mtime;
36
	char url[sizeof(int)];
37
};
38

39
/** allocate a new song with a remote URL */
40
struct song *
41
song_remote_new(const char *url);
Warren Dukes's avatar
Warren Dukes committed
42

43
/** allocate a new song with a local file name */
44
struct song *
45 46 47 48 49 50 51 52 53
song_file_new(const char *path, struct directory *parent);

/**
 * allocate a new song structure with a local file name and attempt to
 * load its metadata.  If all decoder plugin fail to read its meta
 * data, NULL is returned.
 */
struct song *
song_file_load(const char *path, struct directory *parent);
Warren Dukes's avatar
Warren Dukes committed
54

55
void
Max Kellermann's avatar
Max Kellermann committed
56
song_free(struct song *song);
57

58
bool
Max Kellermann's avatar
Max Kellermann committed
59
song_file_update(struct song *song);
Warren Dukes's avatar
Warren Dukes committed
60

61
/*
Max Kellermann's avatar
Max Kellermann committed
62
 * song_get_url - Returns a path of a song in UTF8-encoded form
63 64 65 66
 * path_max_tmp is the argument that the URL is written to, this
 * buffer is assumed to be MPD_PATH_MAX or greater (including
 * terminating '\0').
 */
67
char *
68
song_get_url(const struct song *song, char *path_max_tmp);
69

70
static inline bool
71
song_in_database(const struct song *song)
Eric Wong's avatar
Eric Wong committed
72
{
Max Kellermann's avatar
Max Kellermann committed
73
	return song->parent != NULL;
Eric Wong's avatar
Eric Wong committed
74 75
}

76 77 78
static inline bool
song_is_file(const struct song *song)
{
79
	return song_in_database(song) || song->url[0] == '/';
80 81
}

Warren Dukes's avatar
Warren Dukes committed
82
#endif