mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-15 08:45:02 -05:00
Make int/string descriptors interchangeable on wma tags
This commit is contained in:
parent
a9349d5d8b
commit
a159058bf7
@ -347,6 +347,7 @@ int wma_parse_extended_content_description(int fd,int size, MP3FILE *pmp3) {
|
|||||||
unsigned short int descriptor_short_value;
|
unsigned short int descriptor_short_value;
|
||||||
int fail=0;
|
int fail=0;
|
||||||
int track, tracknumber;
|
int track, tracknumber;
|
||||||
|
char numbuff[40];
|
||||||
|
|
||||||
track = tracknumber = 0;
|
track = tracknumber = 0;
|
||||||
|
|
||||||
@ -376,6 +377,7 @@ int wma_parse_extended_content_description(int fd,int size, MP3FILE *pmp3) {
|
|||||||
&descriptor_byte_value)) {
|
&descriptor_byte_value)) {
|
||||||
fail=1;
|
fail=1;
|
||||||
}
|
}
|
||||||
|
descriptor_int_value=atoi(descriptor_byte_value);
|
||||||
DPRINTF(E_DBG,L_SCAN,"Type: string, value: %s\n",descriptor_byte_value);
|
DPRINTF(E_DBG,L_SCAN,"Type: string, value: %s\n",descriptor_byte_value);
|
||||||
break;
|
break;
|
||||||
case 0x0001: /* byte array */
|
case 0x0001: /* byte array */
|
||||||
@ -389,14 +391,22 @@ int wma_parse_extended_content_description(int fd,int size, MP3FILE *pmp3) {
|
|||||||
case 0x0003: /* dword */
|
case 0x0003: /* dword */
|
||||||
if(!wma_file_read_int(fd,&descriptor_int_value)) fail=1;
|
if(!wma_file_read_int(fd,&descriptor_int_value)) fail=1;
|
||||||
DPRINTF(E_DBG,L_SCAN,"Type: int, value: %d\n",descriptor_int_value);
|
DPRINTF(E_DBG,L_SCAN,"Type: int, value: %d\n",descriptor_int_value);
|
||||||
|
snprintf(numbuff,sizeof(numbuff)-1,"%d",descriptor_int_value);
|
||||||
|
descriptor_byte_value = strdup(numbuff);
|
||||||
break;
|
break;
|
||||||
case 0x0004: /* qword */
|
case 0x0004: /* qword */
|
||||||
if(!wma_file_read_ll(fd,&descriptor_ll_value)) fail=1;
|
if(!wma_file_read_ll(fd,&descriptor_ll_value)) fail=1;
|
||||||
DPRINTF(E_DBG,L_SCAN,"Type: ll, value: %lld\n",descriptor_ll_value);
|
DPRINTF(E_DBG,L_SCAN,"Type: ll, value: %lld\n",descriptor_ll_value);
|
||||||
|
snprintf(numbuff,sizeof(numbuff)-1,"%lld",descriptor_ll_value);
|
||||||
|
descriptor_byte_value = strdup(numbuff);
|
||||||
break;
|
break;
|
||||||
case 0x0005: /* word */
|
case 0x0005: /* word */
|
||||||
if(!wma_file_read_short(fd,&descriptor_short_value)) fail=1;
|
if(!wma_file_read_short(fd,&descriptor_short_value)) fail=1;
|
||||||
DPRINTF(E_DBG,L_SCAN,"type: short, value %d\n",descriptor_short_value);
|
DPRINTF(E_DBG,L_SCAN,"type: short, value %d\n",descriptor_short_value);
|
||||||
|
snprintf(numbuff,sizeof(numbuff)-1,"%d",descriptor_short_value);
|
||||||
|
descriptor_byte_value = strdup(numbuff);
|
||||||
|
break;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -415,11 +425,7 @@ int wma_parse_extended_content_description(int fd,int size, MP3FILE *pmp3) {
|
|||||||
pmp3->album = descriptor_byte_value;
|
pmp3->album = descriptor_byte_value;
|
||||||
descriptor_byte_value = NULL;
|
descriptor_byte_value = NULL;
|
||||||
} else if(strcasecmp(descriptor_name,"wm/track")==0) {
|
} else if(strcasecmp(descriptor_name,"wm/track")==0) {
|
||||||
if(descriptor_value_type == 3) {
|
|
||||||
track = descriptor_int_value + 1;
|
track = descriptor_int_value + 1;
|
||||||
} else if(descriptor_value_type == 0) {
|
|
||||||
track = atoi(descriptor_byte_value) + 1;
|
|
||||||
}
|
|
||||||
} else if(strcasecmp(descriptor_name,"wm/shareduserrating")==0) {
|
} else if(strcasecmp(descriptor_name,"wm/shareduserrating")==0) {
|
||||||
/* what a strange rating strategy */
|
/* what a strange rating strategy */
|
||||||
pmp3->rating = descriptor_int_value;
|
pmp3->rating = descriptor_int_value;
|
||||||
@ -431,11 +437,7 @@ int wma_parse_extended_content_description(int fd,int size, MP3FILE *pmp3) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if(strcasecmp(descriptor_name,"wm/tracknumber")==0) {
|
} else if(strcasecmp(descriptor_name,"wm/tracknumber")==0) {
|
||||||
if(descriptor_value_type == 3) {
|
|
||||||
tracknumber = descriptor_int_value;
|
tracknumber = descriptor_int_value;
|
||||||
} else if(descriptor_value_type == 0) {
|
|
||||||
tracknumber = atoi(descriptor_byte_value);
|
|
||||||
}
|
|
||||||
} else if(strcasecmp(descriptor_name,"wm/year")==0) {
|
} else if(strcasecmp(descriptor_name,"wm/year")==0) {
|
||||||
pmp3->year = atoi(descriptor_byte_value);
|
pmp3->year = atoi(descriptor_byte_value);
|
||||||
} else if(strcasecmp(descriptor_name,"wm/composer")==0) {
|
} else if(strcasecmp(descriptor_name,"wm/composer")==0) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user