mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-24 13:13:17 -05:00
Updates from Paul Kim
This commit is contained in:
parent
516fe79380
commit
099bcf911b
@ -145,7 +145,7 @@ static query_field_t song_fields[] = {
|
|||||||
{ qft_string, "daap.songartist", OFFSET_OF(MP3FILE, artist) },
|
{ qft_string, "daap.songartist", OFFSET_OF(MP3FILE, artist) },
|
||||||
{ qft_i32, "daap.songbitrate", OFFSET_OF(MP3FILE, bitrate) },
|
{ qft_i32, "daap.songbitrate", OFFSET_OF(MP3FILE, bitrate) },
|
||||||
{ qft_string, "daap.songcomment", OFFSET_OF(MP3FILE, comment) },
|
{ qft_string, "daap.songcomment", OFFSET_OF(MP3FILE, comment) },
|
||||||
// { qft_i32_const, "daap.songcompilation", 0 },
|
{ qft_i32, "daap.songcompilation", OFFSET_OF(MP3FILE, compilation) },
|
||||||
{ qft_string, "daap.songcomposer", OFFSET_OF(MP3FILE, composer) },
|
{ qft_string, "daap.songcomposer", OFFSET_OF(MP3FILE, composer) },
|
||||||
// { qft_i32_const, "daap.songdatakind", 0 },
|
// { qft_i32_const, "daap.songdatakind", 0 },
|
||||||
// { qft_string, "daap.songdataurl", OFFSET_OF(MP3FILE, url) },
|
// { qft_string, "daap.songdataurl", OFFSET_OF(MP3FILE, url) },
|
||||||
|
@ -276,7 +276,7 @@ off_t da_aac_insert_covr_atom(off_t extra_size, int out_fd, FILE *aac_fp,
|
|||||||
int atom_length;
|
int atom_length;
|
||||||
off_t cur_pos;
|
off_t cur_pos;
|
||||||
char *cp;
|
char *cp;
|
||||||
unsigned char img_type_flag;
|
unsigned char img_type_flag = 0;
|
||||||
|
|
||||||
/* Figure out image file type since this needs to be encoded in the atom. */
|
/* Figure out image file type since this needs to be encoded in the atom. */
|
||||||
cp = strrchr(config.artfilename, '.');
|
cp = strrchr(config.artfilename, '.');
|
||||||
@ -286,10 +286,12 @@ off_t da_aac_insert_covr_atom(off_t extra_size, int out_fd, FILE *aac_fp,
|
|||||||
}
|
}
|
||||||
else if (!strcasecmp(cp, ".png")) {
|
else if (!strcasecmp(cp, ".png")) {
|
||||||
img_type_flag = 0x0e;
|
img_type_flag = 0x0e;
|
||||||
|
} else {
|
||||||
|
DPRINTF(ERR_LOG, "Image type '%s' not supported.\n", cp);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
DPRINTF(ERR_LOG, "Image type '%s' not supported.\n", cp);
|
DPRINTF(ERR_LOG, "No file extension for image file.\n");
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
aac_fd = fileno(aac_fp);
|
aac_fd = fileno(aac_fp);
|
||||||
|
@ -929,15 +929,21 @@ off_t aac_drilltoatom(FILE *aac_fp, char *atom_path, unsigned int *atom_length)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
DPRINTF(ERR_DEBUG, "Found %s atom at offset %ld.\n", atom_name, ftell(aac_fp) - 8);
|
DPRINTF(ERR_DEBUG, "Found %s atom at offset %ld.\n", atom_name, ftell(aac_fp) - 8);
|
||||||
/* Hack to deal with 'meta' atom which has 4 bytes of crud after it. */
|
|
||||||
if (!strcmp(atom_name, "meta"))
|
|
||||||
{
|
|
||||||
fseek(aac_fp, 4, SEEK_CUR);
|
|
||||||
}
|
|
||||||
cur_p = strchr(cur_p, ':');
|
cur_p = strchr(cur_p, ':');
|
||||||
if (cur_p != NULL)
|
if (cur_p != NULL)
|
||||||
{
|
{
|
||||||
cur_p++;
|
cur_p++;
|
||||||
|
|
||||||
|
/* PENDING: Hack to deal with atoms that have extra data in addition
|
||||||
|
to having child atoms. This should be dealt in a better fashion
|
||||||
|
than this (table with skip offsets or an actual real mp4 parser.) */
|
||||||
|
if (!strcmp(atom_name, "meta")) {
|
||||||
|
fseek(aac_fp, 4, SEEK_CUR);
|
||||||
|
} else if (!strcmp(atom_name, "stsd")) {
|
||||||
|
fseek(aac_fp, 8, SEEK_CUR);
|
||||||
|
} else if (!strcmp(atom_name, "mp4a")) {
|
||||||
|
fseek(aac_fp, 28, SEEK_CUR);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -955,9 +961,10 @@ int scan_get_aacfileinfo(char *file, MP3FILE *pmp3) {
|
|||||||
int atom_length;
|
int atom_length;
|
||||||
int sample_size;
|
int sample_size;
|
||||||
int samples;
|
int samples;
|
||||||
|
unsigned int bit_rate;
|
||||||
off_t file_size;
|
off_t file_size;
|
||||||
int ms;
|
int ms;
|
||||||
char buffer[10];
|
unsigned char buffer[2];
|
||||||
|
|
||||||
DPRINTF(ERR_DEBUG,"Getting AAC file info\n");
|
DPRINTF(ERR_DEBUG,"Getting AAC file info\n");
|
||||||
|
|
||||||
@ -995,10 +1002,53 @@ int scan_get_aacfileinfo(char *file, MP3FILE *pmp3) {
|
|||||||
DPRINTF(ERR_DEBUG,"Song length: %d seconds\n", pmp3->song_length / 1000);
|
DPRINTF(ERR_DEBUG,"Song length: %d seconds\n", pmp3->song_length / 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* calculate bitrate from song length... Kinda cheesy */
|
pmp3->bitrate = 0;
|
||||||
atom_offset=aac_drilltoatom(infile,"mdat",&atom_length);
|
|
||||||
if(atom_offset != -1) {
|
/* Get the sample rate from the 'mp4a' atom (timescale). This is also
|
||||||
pmp3->bitrate = atom_length / ((pmp3->song_length / 1000) * 128);
|
found in the 'mdhd' atom which is a bit closer but we need to
|
||||||
|
navigate to the 'mp4a' atom anyways to get to the 'esds' atom. */
|
||||||
|
atom_offset = aac_drilltoatom(infile, "moov:trak:mdia:minf:stbl:stsd:mp4a", &atom_length);
|
||||||
|
if (atom_offset != -1) {
|
||||||
|
fseek(infile, atom_offset + 32, SEEK_SET);
|
||||||
|
|
||||||
|
/* Timescale here seems to be 2 bytes here (the 2 bytes before it are
|
||||||
|
"reserved") though the timescale in the 'mdhd' atom is 4. Not sure how
|
||||||
|
this is dealt with when sample rate goes higher than 64K. */
|
||||||
|
fread(buffer, sizeof(unsigned char), 2, infile);
|
||||||
|
|
||||||
|
pmp3->samplerate = (buffer[0] << 8) | (buffer[1]);
|
||||||
|
|
||||||
|
/* Seek to end of atom. */
|
||||||
|
fseek(infile, 2, SEEK_CUR);
|
||||||
|
|
||||||
|
/* Get the bit rate from the 'esds' atom. We are already positioned
|
||||||
|
in the parent atom so just scan ahead. */
|
||||||
|
atom_offset = scan_aac_findatom(infile, atom_length - (ftell(infile) - atom_offset), "esds", &atom_length);
|
||||||
|
|
||||||
|
if (atom_offset != -1) {
|
||||||
|
fseek(infile, atom_offset + 22, SEEK_CUR);
|
||||||
|
|
||||||
|
fread((void *)&bit_rate, sizeof(unsigned int), 1, infile);
|
||||||
|
|
||||||
|
pmp3->bitrate = ntohl(bit_rate) / 1000;
|
||||||
|
} else {
|
||||||
|
DPRINTF(ERR_LOG, "Could not find 'esds' atom to determine bit rate.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
DPRINTF(ERR_LOG, "Could not find 'mp4a' atom to determine sample rate.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fallback if we can't find the info in the atoms. */
|
||||||
|
if (pmp3->bitrate == 0) {
|
||||||
|
/* calculate bitrate from song length... Kinda cheesy */
|
||||||
|
DPRINTF(ERR_LOG, "Could not find 'esds' atom. Calculating bit rate.\n");
|
||||||
|
|
||||||
|
atom_offset=aac_drilltoatom(infile,"mdat",&atom_length);
|
||||||
|
|
||||||
|
if (atom_offset != -1) {
|
||||||
|
pmp3->bitrate = atom_length / ((pmp3->song_length / 1000) * 128);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fclose(infile);
|
fclose(infile);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user