annotate src/libid3tag-0.15.1b/genre.c @ 169:223a55898ab9 tip default

Add null config files
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 02 Mar 2020 14:03:47 +0000
parents 545efbb81310
children
rev   line source
cannam@85 1 /*
cannam@85 2 * libid3tag - ID3 tag manipulation library
cannam@85 3 * Copyright (C) 2000-2004 Underbit Technologies, Inc.
cannam@85 4 *
cannam@85 5 * This program is free software; you can redistribute it and/or modify
cannam@85 6 * it under the terms of the GNU General Public License as published by
cannam@85 7 * the Free Software Foundation; either version 2 of the License, or
cannam@85 8 * (at your option) any later version.
cannam@85 9 *
cannam@85 10 * This program is distributed in the hope that it will be useful,
cannam@85 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
cannam@85 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
cannam@85 13 * GNU General Public License for more details.
cannam@85 14 *
cannam@85 15 * You should have received a copy of the GNU General Public License
cannam@85 16 * along with this program; if not, write to the Free Software
cannam@85 17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
cannam@85 18 *
cannam@85 19 * $Id: genre.c,v 1.8 2004/01/23 09:41:32 rob Exp $
cannam@85 20 */
cannam@85 21
cannam@85 22 # ifdef HAVE_CONFIG_H
cannam@85 23 # include "config.h"
cannam@85 24 # endif
cannam@85 25
cannam@85 26 # include "global.h"
cannam@85 27
cannam@85 28 # include "id3tag.h"
cannam@85 29 # include "ucs4.h"
cannam@85 30
cannam@85 31 /* genres are stored in ucs4 format */
cannam@85 32 # include "genre.dat"
cannam@85 33
cannam@85 34 # define NGENRES (sizeof(genre_table) / sizeof(genre_table[0]))
cannam@85 35
cannam@85 36 /*
cannam@85 37 * NAME: genre->index()
cannam@85 38 * DESCRIPTION: return an ID3v1 genre string indexed by number
cannam@85 39 */
cannam@85 40 id3_ucs4_t const *id3_genre_index(unsigned int index)
cannam@85 41 {
cannam@85 42 return (index < NGENRES) ? genre_table[index] : 0;
cannam@85 43 }
cannam@85 44
cannam@85 45 /*
cannam@85 46 * NAME: genre->name()
cannam@85 47 * DESCRIPTION: translate an ID3v2 genre number/keyword to its full name
cannam@85 48 */
cannam@85 49 id3_ucs4_t const *id3_genre_name(id3_ucs4_t const *string)
cannam@85 50 {
cannam@85 51 id3_ucs4_t const *ptr;
cannam@85 52 static id3_ucs4_t const genre_remix[] = { 'R', 'e', 'm', 'i', 'x', 0 };
cannam@85 53 static id3_ucs4_t const genre_cover[] = { 'C', 'o', 'v', 'e', 'r', 0 };
cannam@85 54 unsigned long number;
cannam@85 55
cannam@85 56 if (string == 0 || *string == 0)
cannam@85 57 return id3_ucs4_empty;
cannam@85 58
cannam@85 59 if (string[0] == 'R' && string[1] == 'X' && string[2] == 0)
cannam@85 60 return genre_remix;
cannam@85 61 if (string[0] == 'C' && string[1] == 'R' && string[2] == 0)
cannam@85 62 return genre_cover;
cannam@85 63
cannam@85 64 for (ptr = string; *ptr; ++ptr) {
cannam@85 65 if (*ptr < '0' || *ptr > '9')
cannam@85 66 return string;
cannam@85 67 }
cannam@85 68
cannam@85 69 number = id3_ucs4_getnumber(string);
cannam@85 70
cannam@85 71 return (number < NGENRES) ? genre_table[number] : string;
cannam@85 72 }
cannam@85 73
cannam@85 74 /*
cannam@85 75 * NAME: translate()
cannam@85 76 * DESCRIPTION: return a canonicalized character for testing genre equivalence
cannam@85 77 */
cannam@85 78 static
cannam@85 79 id3_ucs4_t translate(id3_ucs4_t ch)
cannam@85 80 {
cannam@85 81 if (ch) {
cannam@85 82 if (ch >= 'A' && ch <= 'Z')
cannam@85 83 ch += 'a' - 'A';
cannam@85 84
cannam@85 85 if (ch < 'a' || ch > 'z')
cannam@85 86 ch = ID3_UCS4_REPLACEMENTCHAR;
cannam@85 87 }
cannam@85 88
cannam@85 89 return ch;
cannam@85 90 }
cannam@85 91
cannam@85 92 /*
cannam@85 93 * NAME: compare()
cannam@85 94 * DESCRIPTION: test two ucs4 genre strings for equivalence
cannam@85 95 */
cannam@85 96 static
cannam@85 97 int compare(id3_ucs4_t const *str1, id3_ucs4_t const *str2)
cannam@85 98 {
cannam@85 99 id3_ucs4_t c1, c2;
cannam@85 100
cannam@85 101 if (str1 == str2)
cannam@85 102 return 1;
cannam@85 103
cannam@85 104 do {
cannam@85 105 do
cannam@85 106 c1 = translate(*str1++);
cannam@85 107 while (c1 == ID3_UCS4_REPLACEMENTCHAR);
cannam@85 108
cannam@85 109 do
cannam@85 110 c2 = translate(*str2++);
cannam@85 111 while (c2 == ID3_UCS4_REPLACEMENTCHAR);
cannam@85 112 }
cannam@85 113 while (c1 && c1 == c2);
cannam@85 114
cannam@85 115 return c1 == c2;
cannam@85 116 }
cannam@85 117
cannam@85 118 /*
cannam@85 119 * NAME: genre->number()
cannam@85 120 * DESCRIPTION: translate an ID3v2 genre name/number to its ID3v1 index number
cannam@85 121 */
cannam@85 122 int id3_genre_number(id3_ucs4_t const *string)
cannam@85 123 {
cannam@85 124 id3_ucs4_t const *ptr;
cannam@85 125 int i;
cannam@85 126
cannam@85 127 if (string == 0 || *string == 0)
cannam@85 128 return -1;
cannam@85 129
cannam@85 130 for (ptr = string; *ptr; ++ptr) {
cannam@85 131 if (*ptr < '0' || *ptr > '9')
cannam@85 132 break;
cannam@85 133 }
cannam@85 134
cannam@85 135 if (*ptr == 0) {
cannam@85 136 unsigned long number;
cannam@85 137
cannam@85 138 number = id3_ucs4_getnumber(string);
cannam@85 139
cannam@85 140 return (number <= 0xff) ? number : -1;
cannam@85 141 }
cannam@85 142
cannam@85 143 for (i = 0; i < NGENRES; ++i) {
cannam@85 144 if (compare(string, genre_table[i]))
cannam@85 145 return i;
cannam@85 146 }
cannam@85 147
cannam@85 148 /* no equivalent */
cannam@85 149
cannam@85 150 return -1;
cannam@85 151 }