enable downloading of the manual. It will get saved to the players root folder for...
[Rockbox.git] / apps / tagcache.h
blob118b4c411964c32b141fdbb413d7b8327fc786cb
1 /***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
10 * Copyright (C) 2005 by Miika Pekkarinen
12 * All files in this archive are subject to the GNU General Public License.
13 * See the file COPYING in the source tree root for full license agreement.
15 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
16 * KIND, either express or implied.
18 ****************************************************************************/
19 #ifdef HAVE_TAGCACHE
20 #ifndef _TAGCACHE_H
21 #define _TAGCACHE_H
23 #include "id3.h"
25 enum tag_type { tag_artist = 0, tag_album, tag_genre, tag_title,
26 tag_filename, tag_composer, tag_comment, tag_albumartist, tag_grouping, tag_year,
27 tag_discnumber, tag_tracknumber, tag_bitrate, tag_length, tag_playcount, tag_rating,
28 tag_playtime, tag_lastplayed, tag_commitid,
29 /* Virtual tags */
30 tag_virt_length_min, tag_virt_length_sec,
31 tag_virt_playtime_min, tag_virt_playtime_sec,
32 tag_virt_entryage, tag_virt_autoscore };
34 #define TAG_COUNT 19
36 /* Maximum length of a single tag. */
37 #define TAG_MAXLEN (MAX_PATH*2)
39 /* Allow a little drift to the filename ordering (should not be too high/low). */
40 #define POS_HISTORY_COUNT 4
42 /* How much to pre-load entries while committing to prevent seeking. */
43 #define IDX_BUF_DEPTH 64
45 /* Tag Cache Header version 'TCHxx'. Increment when changing internal structures. */
46 #define TAGCACHE_MAGIC 0x5443480b
48 /* How much to allocate extra space for ramcache. */
49 #define TAGCACHE_RESERVE 32768
51 /**
52 * Define how long one entry must be at least (longer -> less memory at commit).
53 * Must be at least 4 bytes in length for correct alignment.
55 #define TAGFILE_ENTRY_CHUNK_LENGTH 8
57 /* Used to guess the necessary buffer size at commit. */
58 #define TAGFILE_ENTRY_AVG_LENGTH 16
60 /* How many entries to fetch to the seek table at once while searching. */
61 #define SEEK_LIST_SIZE 32
63 /* Always strict align entries for best performance and binary compatability. */
64 #define TAGCACHE_STRICT_ALIGN 1
66 /* Max events in the internal tagcache command queue. */
67 #define TAGCACHE_COMMAND_QUEUE_LENGTH 32
68 /* Idle time before committing events in the command queue. */
69 #define TAGCACHE_COMMAND_QUEUE_COMMIT_DELAY HZ*2
71 #define TAGCACHE_MAX_FILTERS 4
72 #define TAGCACHE_MAX_CLAUSES 32
74 /* Tag database files. */
75 #define TAGCACHE_FILE_TEMP ROCKBOX_DIR "/database_tmp.tcd"
76 #define TAGCACHE_FILE_MASTER ROCKBOX_DIR "/database_idx.tcd"
77 #define TAGCACHE_FILE_INDEX ROCKBOX_DIR "/database_%d.tcd"
78 #define TAGCACHE_FILE_CHANGELOG ROCKBOX_DIR "/database_changelog.txt"
79 #define TAGCACHE_STATEFILE ROCKBOX_DIR "/database_state.tcd"
81 /* Flags */
82 #define FLAG_DELETED 0x0001 /* Entry has been removed from db */
83 #define FLAG_DIRCACHE 0x0002 /* Filename is a dircache pointer */
84 #define FLAG_DIRTYNUM 0x0004 /* Numeric data has been modified */
85 #define FLAG_TRKNUMGEN 0x0008 /* Track number has been generated */
86 #define FLAG_GET_ATTR(flag) ((flag >> 16) & 0x0000ffff)
87 #define FLAG_SET_ATTR(flag,attr) flag = (flag & 0x0000ffff) | (attr << 16)
89 enum clause { clause_none, clause_is, clause_is_not, clause_gt, clause_gteq,
90 clause_lt, clause_lteq, clause_contains, clause_not_contains,
91 clause_begins_with, clause_not_begins_with, clause_ends_with,
92 clause_not_ends_with, clause_oneof };
94 struct tagcache_stat {
95 bool initialized; /* Is tagcache currently busy? */
96 bool readyvalid; /* Has tagcache ready status been ascertained */
97 bool ready; /* Is tagcache ready to be used? */
98 bool ramcache; /* Is tagcache loaded in ram? */
99 bool commit_delayed; /* Has commit been delayed until next reboot? */
100 bool econ; /* Is endianess correction enabled? */
101 int commit_step; /* Commit progress */
102 int ramcache_allocated; /* Has ram been allocated for ramcache? */
103 int ramcache_used; /* How much ram has been really used */
104 int progress; /* Current progress of disk scan */
105 int processed_entries; /* Scanned disk entries so far */
108 struct tagcache_search_clause
110 int tag;
111 int type;
112 bool numeric;
113 bool input;
114 long numeric_data;
115 char *str;
118 struct tagcache_search {
119 /* For internal use only. */
120 int fd, masterfd;
121 int idxfd[TAG_COUNT];
122 long seek_list[SEEK_LIST_SIZE];
123 long seek_flags[SEEK_LIST_SIZE];
124 long filter_tag[TAGCACHE_MAX_FILTERS];
125 long filter_seek[TAGCACHE_MAX_FILTERS];
126 int filter_count;
127 struct tagcache_search_clause *clause[TAGCACHE_MAX_CLAUSES];
128 int clause_count;
129 int seek_list_count;
130 int seek_pos;
131 long position;
132 int entry_count;
133 bool valid;
134 bool initialized;
135 unsigned long *unique_list;
136 int unique_list_capacity;
137 int unique_list_count;
139 /* Exported variables. */
140 bool ramsearch;
141 bool ramresult;
142 int type;
143 char *result;
144 int result_len;
145 long result_seek;
146 int idx_id;
149 #ifdef __PCTOOL__
150 void build_tagcache(const char *path);
151 void tagcache_reverse_scan(void);
152 #endif
154 const char* tagcache_tag_to_str(int tag);
156 bool tagcache_is_numeric_tag(int type);
157 bool tagcache_is_unique_tag(int type);
158 bool tagcache_is_sorted_tag(int type);
159 bool tagcache_find_index(struct tagcache_search *tcs, const char *filename);
160 bool tagcache_check_clauses(struct tagcache_search *tcs,
161 struct tagcache_search_clause **clause, int count);
162 bool tagcache_search(struct tagcache_search *tcs, int tag);
163 void tagcache_search_set_uniqbuf(struct tagcache_search *tcs,
164 void *buffer, long length);
165 bool tagcache_search_add_filter(struct tagcache_search *tcs,
166 int tag, int seek);
167 bool tagcache_search_add_clause(struct tagcache_search *tcs,
168 struct tagcache_search_clause *clause);
169 bool tagcache_get_next(struct tagcache_search *tcs);
170 bool tagcache_retrieve(struct tagcache_search *tcs, int idxid,
171 int tag, char *buf, long size);
172 void tagcache_search_finish(struct tagcache_search *tcs);
173 long tagcache_get_numeric(const struct tagcache_search *tcs, int tag);
174 long tagcache_increase_serial(void);
175 long tagcache_get_serial(void);
176 bool tagcache_import_changelog(void);
177 bool tagcache_create_changelog(struct tagcache_search *tcs);
178 void tagcache_update_numeric(int idx_id, int tag, long data);
179 bool tagcache_modify_numeric_entry(struct tagcache_search *tcs,
180 int tag, long data);
182 struct tagcache_stat* tagcache_get_stat(void);
183 int tagcache_get_commit_step(void);
184 bool tagcache_prepare_shutdown(void);
185 void tagcache_shutdown(void);
187 #ifdef HAVE_TC_RAMCACHE
188 bool tagcache_is_ramcache(void);
189 bool tagcache_fill_tags(struct mp3entry *id3, const char *filename);
190 void tagcache_unload_ramcache(void);
191 #endif
192 void tagcache_init(void);
193 bool tagcache_is_initialized(void);
194 bool tagcache_is_usable(void);
195 void tagcache_start_scan(void);
196 void tagcache_stop_scan(void);
197 bool tagcache_update(void);
198 bool tagcache_rebuild(void);
199 int tagcache_get_max_commit_step(void);
200 #endif
201 #endif