2005-03-11 06:39:40 +00:00
|
|
|
/*
|
|
|
|
* $Id$
|
|
|
|
* Header info for generic database
|
|
|
|
*
|
|
|
|
* Copyright (C) 2005 Ron Pedde (ron@pedde.com)
|
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _DB_GENERIC_H_
|
|
|
|
#define _DB_GENERIC_H_
|
|
|
|
|
|
|
|
#include "mp3-scanner.h" /** for MP3FILE */
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
// generic meta data
|
|
|
|
metaItemId,
|
|
|
|
metaItemName,
|
|
|
|
metaItemKind,
|
|
|
|
metaPersistentId,
|
|
|
|
metaContainerItemId,
|
|
|
|
metaParentContainerId,
|
|
|
|
|
|
|
|
firstTypeSpecificMetaId,
|
|
|
|
|
|
|
|
// song meta data
|
|
|
|
metaSongAlbum = firstTypeSpecificMetaId,
|
|
|
|
metaSongArtist,
|
2005-03-14 06:17:28 +00:00
|
|
|
metaSongBPM,
|
2005-03-11 06:39:40 +00:00
|
|
|
metaSongBitRate,
|
|
|
|
metaSongComment,
|
|
|
|
metaSongCompilation,
|
|
|
|
metaSongComposer,
|
|
|
|
metaSongDataKind,
|
|
|
|
metaSongDataURL,
|
|
|
|
metaSongDateAdded,
|
|
|
|
metaSongDateModified,
|
|
|
|
metaSongDescription,
|
|
|
|
metaSongDisabled,
|
|
|
|
metaSongDiscCount,
|
|
|
|
metaSongDiscNumber,
|
|
|
|
metaSongEqPreset,
|
|
|
|
metaSongFormat,
|
|
|
|
metaSongGenre,
|
|
|
|
metaSongGrouping,
|
|
|
|
metaSongRelativeVolume,
|
|
|
|
metaSongSampleRate,
|
|
|
|
metaSongSize,
|
|
|
|
metaSongStartTime,
|
|
|
|
metaSongStopTime,
|
|
|
|
metaSongTime,
|
|
|
|
metaSongTrackCount,
|
|
|
|
metaSongTrackNumber,
|
|
|
|
metaSongUserRating,
|
2005-04-02 04:33:04 +00:00
|
|
|
metaSongYear,
|
|
|
|
|
2005-04-02 05:31:20 +00:00
|
|
|
/* iTunes 4.5 + */
|
|
|
|
metaSongCodecType,
|
|
|
|
metaSongCodecSubType,
|
|
|
|
metaItunesNormVolume,
|
|
|
|
metaItmsSongId,
|
|
|
|
metaItmsArtistId,
|
|
|
|
metaItmsPlaylistId,
|
|
|
|
metaItmsComposerId,
|
|
|
|
metaItmsGenreId,
|
|
|
|
metaItmsStorefrontId,
|
|
|
|
metaItunesSmartPlaylist,
|
|
|
|
|
2005-04-02 04:33:04 +00:00
|
|
|
/* mt-daapd specific */
|
2005-04-02 05:31:20 +00:00
|
|
|
metaMPlaylistSpec,
|
|
|
|
metaMPlaylistType
|
2005-03-11 06:39:40 +00:00
|
|
|
} MetaFieldName_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
queryTypeItems,
|
|
|
|
queryTypePlaylists,
|
|
|
|
queryTypePlaylistItems,
|
|
|
|
queryTypeBrowseArtists,
|
|
|
|
queryTypeBrowseAlbums,
|
|
|
|
queryTypeBrowseGenres,
|
|
|
|
queryTypeBrowseComposers
|
|
|
|
} QueryType_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
indexTypeNone,
|
|
|
|
indexTypeFirst,
|
|
|
|
indexTypeLast,
|
|
|
|
indexTypeSub
|
|
|
|
} IndexType_t;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
countSongs,
|
|
|
|
countPlaylists
|
|
|
|
} CountType_t;
|
|
|
|
|
|
|
|
typedef unsigned long long MetaField_t;
|
|
|
|
|
|
|
|
typedef struct tag_dbqueryinfo {
|
|
|
|
QueryType_t query_type;
|
|
|
|
IndexType_t index_type;
|
|
|
|
MetaField_t meta;
|
|
|
|
int index_low;
|
|
|
|
int index_high;
|
|
|
|
int playlist_id;
|
|
|
|
int db_id;
|
|
|
|
int session_id;
|
|
|
|
int uri_count;
|
|
|
|
char *uri_sections[10];
|
|
|
|
char *whereclause;
|
2005-03-16 11:38:14 +00:00
|
|
|
void *output_info;
|
2005-03-11 06:39:40 +00:00
|
|
|
} DBQUERYINFO;
|
|
|
|
|
2005-03-14 06:17:28 +00:00
|
|
|
typedef struct {
|
|
|
|
const char* tag;
|
|
|
|
MetaFieldName_t bit;
|
2005-03-11 06:39:40 +00:00
|
|
|
} METAMAP;
|
|
|
|
|
|
|
|
typedef struct tag_daap_items {
|
|
|
|
int type;
|
|
|
|
char *tag;
|
|
|
|
char *description;
|
|
|
|
} DAAP_ITEMS;
|
|
|
|
|
|
|
|
extern DAAP_ITEMS taglist[];
|
|
|
|
|
|
|
|
extern int db_set_backend(char *type);
|
|
|
|
|
|
|
|
extern int db_open(char *parameters);
|
|
|
|
extern int db_init(int reload);
|
|
|
|
extern int db_deinit(void);
|
|
|
|
|
|
|
|
extern int db_revision(void);
|
|
|
|
|
|
|
|
extern int db_add(MP3FILE *pmp3);
|
|
|
|
|
|
|
|
extern int db_enum_start(DBQUERYINFO *pinfo);
|
|
|
|
extern int db_enum_size(DBQUERYINFO *pinfo, int *count);
|
|
|
|
extern int db_enum_fetch(DBQUERYINFO *pinfo, unsigned char **pdmap);
|
|
|
|
extern int db_enum_reset(DBQUERYINFO *pinfo);
|
|
|
|
extern int db_enum_end(void);
|
|
|
|
extern int db_start_scan(void);
|
|
|
|
extern int db_end_scan(void);
|
|
|
|
extern int db_exists(char *path);
|
|
|
|
extern int db_scanning(void);
|
|
|
|
|
2005-04-17 23:57:10 +00:00
|
|
|
extern int db_add_playlist(char *name, int type, char *clause, char *path,int *playlistid);
|
2005-04-02 10:52:28 +00:00
|
|
|
extern int db_add_playlist_item(int playlistid, int songid);
|
2005-04-21 03:16:19 +00:00
|
|
|
extern int db_delete_playlist(int playlistid);
|
|
|
|
extern int db_delete_playlist_item(int playlistid, int songid);
|
2005-04-02 09:27:53 +00:00
|
|
|
|
2005-03-19 10:02:19 +00:00
|
|
|
extern MP3FILE *db_fetch_item(int id);
|
|
|
|
extern MP3FILE *db_fetch_path(char *path);
|
2005-04-21 03:16:19 +00:00
|
|
|
extern M3UFILE *db_fetch_playlist(char *path, int index);
|
2005-03-19 10:02:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* metatag parsing */
|
2005-03-11 06:39:40 +00:00
|
|
|
extern MetaField_t db_encode_meta(char *meta);
|
|
|
|
extern int db_wantsmeta(MetaField_t meta, MetaFieldName_t fieldNo);
|
|
|
|
|
|
|
|
/* dmap helper functions */
|
|
|
|
extern int db_dmap_add_char(char *where, char *tag, char value);
|
|
|
|
extern int db_dmap_add_short(char *where, char *tag, short value);
|
|
|
|
extern int db_dmap_add_int(char *where, char *tag, int value);
|
|
|
|
extern int db_dmap_add_string(char *where, char *tag, char *value);
|
2005-04-04 02:21:26 +00:00
|
|
|
extern int db_dmap_add_literal(char *where, char *tag, char *value, int size);
|
2005-03-11 06:39:40 +00:00
|
|
|
extern int db_dmap_add_container(char *where, char *tag, int size);
|
|
|
|
|
|
|
|
/* Holdover functions from old db interface...
|
|
|
|
* should these be removed? Refactored?
|
|
|
|
*/
|
|
|
|
extern int db_get_song_count(void);
|
|
|
|
extern int db_get_playlist_count(void);
|
|
|
|
extern void db_dispose_item(MP3FILE *pmp3);
|
2005-04-21 03:16:19 +00:00
|
|
|
extern void db_dispose_playlist(M3UFILE *pm3u);
|
2005-03-11 06:39:40 +00:00
|
|
|
|
2005-04-02 09:27:53 +00:00
|
|
|
|
|
|
|
#define DB_E_SUCCESS 0
|
|
|
|
#define DB_E_SQL_ERROR 1 /**< some kind of sql error - typically bad syntax */
|
|
|
|
#define DB_E_DUPLICATE_PLAYLIST 2 /**< playlist already exists when adding */
|
|
|
|
#define DB_E_NOCLAUSE 3 /**< adding smart playlist with no clause */
|
2005-04-02 10:52:28 +00:00
|
|
|
#define DB_E_INVALIDTYPE 4 /**< trying to add playlist items to invalid type */
|
|
|
|
#define DB_E_NOROWS 5 /**< sql query returned no rows */
|
|
|
|
#define DB_E_INVALID_PLAYLIST 6 /**< bad playlist id */
|
|
|
|
#define DB_E_INVALID_SONGID 7 /**< bad song id */
|
2005-04-02 09:27:53 +00:00
|
|
|
|
2005-03-11 06:39:40 +00:00
|
|
|
#endif /* _DB_GENERIC_H_ */
|