1) cdtext objects are no longer associated with a track but with the disc.
2) - cdio_get_cdtext no longer takes track as an argument - cdtext_get, cdtext_get_const, cdtext_set require track argument 3) Language, Genre, Genre Code and Encoding Fields are now properly parsed and stored in the cdtext object 4) Added public function cdio_get_cdtext_raw to extract the binary CD-Text 5) Added CDTEXTFILE keyword logic in cue sheet parser. Parses binary/raw CD-Text files 6) Added cdtext_genre2str to convert genre code 7) altered the example programs, test drivers, cdda-player and cd-info to work with these changes 8) Added test case 9) A few smaller changes A disc either holds CD-Text for all the tracks or does not hold any. Therefore a CD-Text object for the whole disc seems more natural to me. It also enables us to store global fields, like genre, encoding, language. Patch was tested on GNU/Linux 32 bit running Gentoo.
This commit is contained in:
@@ -110,7 +110,6 @@ typedef struct {
|
||||
lsn_t start_lsn;
|
||||
uchar Control : 4;
|
||||
uchar Format;
|
||||
cdtext_t cdtext; /* CD-TEXT */
|
||||
} track_info_t;
|
||||
|
||||
typedef struct {
|
||||
@@ -172,8 +171,6 @@ init_aix (_img_private_t *p_env)
|
||||
|
||||
p_env->gen.init = true;
|
||||
p_env->gen.toc_init = false;
|
||||
p_env->gen.b_cdtext_init = false;
|
||||
p_env->gen.b_cdtext_error = false;
|
||||
p_env->gen.i_joliet_level = 0; /* Assume no Joliet extensions initally */
|
||||
p_env->access_mode = _AM_CTRL_SCSI;
|
||||
|
||||
@@ -946,6 +943,7 @@ cdio_open_am_aix (const char *psz_orig_source, const char *access_mode)
|
||||
_funcs.free = cdio_generic_free;
|
||||
_funcs.get_arg = get_arg_aix;
|
||||
_funcs.get_cdtext = get_cdtext_generic;
|
||||
_funcs.get_cdtext_raw = read_cdtext_generic;
|
||||
_funcs.get_default_device = cdio_get_default_device_aix;
|
||||
_funcs.get_devices = cdio_get_devices_aix;
|
||||
_funcs.get_disc_last_lsn = get_disc_last_lsn_aix;
|
||||
@@ -973,11 +971,10 @@ cdio_open_am_aix (const char *psz_orig_source, const char *access_mode)
|
||||
_data = calloc (1, sizeof (_img_private_t));
|
||||
|
||||
_data->access_mode = _AM_CTRL_SCSI;
|
||||
_data->gen.b_cdtext_error = false;
|
||||
_data->gen.init = false;
|
||||
_data->gen.fd = -1;
|
||||
_data->gen.toc_init = false;
|
||||
_data->gen.b_cdtext_init = false;
|
||||
_data->gen.b_cdtext_error = false;
|
||||
|
||||
if (NULL == psz_orig_source) {
|
||||
psz_source = cdio_get_default_device_aix();
|
||||
|
||||
Reference in New Issue
Block a user