[renamed] cdtext_languages_available to cdtext_list_languages

[fixed] C++ CD-Text API
[fixed] C++ CD-Text example
This commit is contained in:
Leon Merten Lohse
2012-03-11 16:41:28 +01:00
parent 6571318912
commit 2a6f153952
9 changed files with 130 additions and 104 deletions

View File

@@ -21,83 +21,93 @@
*/ */
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
#define __CDIO_CONFIG_H__ 1
#endif #endif
#ifdef HAVE_STDIO_H #ifdef HAVE_STDIO_H
#include <stdio.h> #include <stdio.h>
#endif #endif
#ifdef HAVE_SYS_TYPES_H
#include <sys/types.h>
#endif
#include <cdio++/cdio.hpp> #include <cdio++/cdio.hpp>
/* Set up a CD-DA image to test on which is in the libcdio distribution. */ /* Set up a CD-DA image to test on which is in the libcdio distribution. */
#define CDDA_IMAGE_PATH "../../../test/" #define CDDA_IMAGE "../../../test/data/cdtext.cue"
#define CDDA_IMAGE CDDA_IMAGE_PATH "cdda.cue"
static void static void
print_cdtext_track_info(CdioDevice *device, track_t i_track, print_cdtext_track_info(CdioCDText *cdtext, track_t i_track) {
const char *psz_msg) { cdtext_field_t i;
cdtext_t *cdtext = device->getCdtext();
if (NULL != cdtext) { for (i=(cdtext_field_t) 0; i < MAX_CDTEXT_FIELDS; i++) {
cdtext_field_t i; if (cdtext->getConst(i, i_track)) {
printf("\t%s: %s\n", cdtext->field2str(i),
printf("%s\n", psz_msg); cdtext->getConst(i, i_track));
for (i= (cdtext_field_t) MIN_CDTEXT_FIELD; i < MAX_CDTEXT_FIELDS; i++) {
if (cdtext_get_const(i, i_track, cdtext)) {
printf("\t%s: %s\n", cdtext_field2str(i),
cdtext_get_const(i, i_track, cdtext));
}
} }
} }
} }
static void static void
print_disc_info(CdioDevice *device, track_t i_tracks, track_t i_first_track) { print_disc_info(CdioDevice *device)
{
track_t i_first_track = device->getFirstTrackNum();
track_t i_tracks = device->getNumTracks();
track_t i_last_track = i_first_track+i_tracks; track_t i_last_track = i_first_track+i_tracks;
discmode_t cd_discmode = device->getDiscmode(); discmode_t cd_discmode = device->getDiscmode();
CdioCDText *cdtext = device->getCdtext();
int i;
printf("%s\n", discmode2str[cd_discmode]); printf("Discmode: %s\n\n", discmode2str[cd_discmode]);
print_cdtext_track_info(device, 0, "\nCD-Text for Disc:"); if (NULL == cdtext)
for ( ; i_first_track < i_last_track; i_first_track++ ) { {
char psz_msg[50]; printf("No CD-Text found on Disc.\n");
sprintf(psz_msg, "CD-Text for Track %d:", i_first_track); return;
print_cdtext_track_info(device, i_first_track, psz_msg);
} }
/* print available languages */
{
cdtext_lang_t *languages;
printf("CD-Text available in: ");
languages = cdtext->listLanguages();
for(i=0; i<8; i++)
if ( CDTEXT_LANGUAGE_UNKNOWN != languages[i])
printf("%s ", cdtext->lang2str(languages[i]));
printf("\n");
}
printf("CD-Text for Disc:\n");
print_cdtext_track_info(cdtext, 0);
for (i = i_first_track ; i < i_last_track; i++ ) {
printf("CD-Text for Track %d:\n", i);
print_cdtext_track_info(cdtext, i);
}
delete cdtext;
} }
int int
main(int argc, const char *argv[]) main(int argc, const char *argv[])
{ {
track_t i_first_track;
track_t i_tracks;
CdioDevice *device = new CdioDevice; CdioDevice *device = new CdioDevice;
const char *psz_drive = NULL; const char *psz_drive = (const char *) NULL;
if (!device->open(CDDA_IMAGE, DRIVER_BINCUE)) { if (!device->open(CDDA_IMAGE, DRIVER_BINCUE)) {
printf("Couldn't open " CDDA_IMAGE " with BIN/CUE driver.\n"); printf("Couldn't open " CDDA_IMAGE " with BIN/CUE driver.\n");
} else { } else {
i_first_track = device->getFirstTrackNum(); print_disc_info(device);
i_tracks = device->getNumTracks();
print_disc_info(device, i_tracks, i_first_track);
} }
if (argc > 1) psz_drive = argv[1]; if (argc > 1) psz_drive = argv[1];
if (!device->open(psz_drive, DRIVER_DEVICE)) { if (!device->open(psz_drive, DRIVER_DEVICE)) {
printf("Couldn't find CD\n"); printf("Couldn't find CD\n");
delete(device);
return 1; return 1;
} else { } else {
i_first_track = device->getFirstTrackNum(); print_disc_info(device);
i_tracks = device->getNumTracks();
print_disc_info(device, i_tracks, i_first_track);
} }
delete(device); delete device;
return 0; return 0;
} }

View File

@@ -20,6 +20,7 @@
libcdio. See also corresponding C++ programs of similar names. */ libcdio. See also corresponding C++ programs of similar names. */
#define EXAMPLE_CUE_FILE "../test/data/cdtext.cue" #define EXAMPLE_CUE_FILE "../test/data/cdtext.cue"
#define EXAMPLE_PREF_LANG "German"
#ifdef HAVE_CONFIG_H #ifdef HAVE_CONFIG_H
#include "config.h" #include "config.h"
@@ -29,19 +30,13 @@
#ifdef HAVE_STDIO_H #ifdef HAVE_STDIO_H
#include <stdio.h> #include <stdio.h>
#endif #endif
#ifdef HAVE_SYS_TYPES_H
#include <sys/types.h>
#endif
#include <cdio/cdio.h> #include <cdio/cdio.h>
#include <cdio/cdtext.h>
static void static void
print_cdtext_track_info(cdtext_t *cdtext, track_t i_track, const char *psz_msg) { print_cdtext_track_info(cdtext_t *cdtext, track_t i_track) {
cdtext_field_t i; cdtext_field_t i;
printf("%s\n", psz_msg);
for (i=0; i < MAX_CDTEXT_FIELDS; i++) { for (i=0; i < MAX_CDTEXT_FIELDS; i++) {
if (cdtext_get_const(cdtext, i, i_track)) { if (cdtext_get_const(cdtext, i, i_track)) {
printf("\t%s: %s\n", cdtext_field2str(i), printf("\t%s: %s\n", cdtext_field2str(i),
@@ -52,55 +47,55 @@ print_cdtext_track_info(cdtext_t *cdtext, track_t i_track, const char *psz_msg)
} }
static void static void
print_disc_info(CdIo_t *p_cdio, track_t i_tracks, track_t i_first_track) { print_disc_info(CdIo_t *p_cdio) {
track_t i_last_track = i_first_track+i_tracks; track_t i_first_track = cdio_get_first_track_num (p_cdio);
discmode_t cd_discmode = cdio_get_discmode(p_cdio); track_t i_tracks = cdio_get_num_tracks (p_cdio);
cdtext_t *cdtext = cdio_get_cdtext(p_cdio); track_t i_last_track = i_first_track + i_tracks;
discmode_t cd_discmode = cdio_get_discmode (p_cdio);
cdtext_t *cdtext = cdio_get_cdtext (p_cdio);
int i; int i;
printf("Discmode: %s\n", discmode2str[cd_discmode]); printf("Discmode: %s\n\n", discmode2str[cd_discmode]);
if (NULL == cdtext) if (NULL == cdtext)
{ {
printf("\nNo CD-Text found on Disc."); printf("No CD-Text found on Disc.\n");
return; return;
} }
/* print available languages */
{
cdtext_lang_t *languages;
printf("\nCD-Text available in: "); /* print available languages */
{
cdtext_lang_t *languages;
languages = cdtext_languages_available(cdtext); printf("CD-Text available in: ");
for(i=0; i<8; i++)
if ( CDTEXT_LANGUAGE_UNKNOWN != languages[i])
printf("%s ", cdtext_lang2str(languages[i]));
printf("\n");
}
/* select language */ languages = cdtext_list_languages(cdtext);
if(cdtext_select_language(cdtext, "German")) { for(i=0; i<8; i++)
printf("%s selected.\n", "German"); if ( CDTEXT_LANGUAGE_UNKNOWN != languages[i])
} else { printf("%s ", cdtext_lang2str(languages[i]));
printf("'%s' is not available. Using '%s'\n", "German", printf("\n");
cdtext_lang2str (cdtext_get_language (cdtext))); }
}
/* select language */
/* print cd-text */ if(cdtext_select_language(cdtext, EXAMPLE_PREF_LANG)) {
print_cdtext_track_info(cdtext, 0, "CD-Text for Disc:"); printf("%s selected.\n", EXAMPLE_PREF_LANG);
for (i=i_first_track ; i < i_last_track; i++ ) { } else {
char psz_msg[50]; printf("'%s' is not available. Using '%s'\n", EXAMPLE_PREF_LANG,
snprintf(psz_msg, sizeof(psz_msg), "CD-Text for Track %d:", i); cdtext_lang2str (cdtext_get_language (cdtext)));
print_cdtext_track_info(cdtext, i, psz_msg); }
/* print cd-text */
printf("CD-Text for Disc:\n");
print_cdtext_track_info(cdtext, 0);
for (i=i_first_track ; i < i_last_track; i++ ) {
printf("CD-Text for Track %d\n:", i);
print_cdtext_track_info(cdtext, i);
} }
} }
int int
main(int argc, const char *argv[]) main(int argc, const char *argv[])
{ {
track_t i_first_track;
track_t i_tracks;
CdIo_t *p_cdio; CdIo_t *p_cdio;
/* read CD-Text from a bin/cue (CDRWIN) image */ /* read CD-Text from a bin/cue (CDRWIN) image */
@@ -109,9 +104,7 @@ main(int argc, const char *argv[])
printf("Couldn't open %s with BIN/CUE driver.\n", printf("Couldn't open %s with BIN/CUE driver.\n",
EXAMPLE_CUE_FILE); EXAMPLE_CUE_FILE);
} else { } else {
i_first_track = cdio_get_first_track_num(p_cdio); print_disc_info(p_cdio);
i_tracks = cdio_get_num_tracks(p_cdio);
print_disc_info(p_cdio, i_tracks, i_first_track);
cdio_destroy(p_cdio); cdio_destroy(p_cdio);
} }
@@ -121,12 +114,9 @@ main(int argc, const char *argv[])
printf("Couldn't find CD\n"); printf("Couldn't find CD\n");
return 77; return 77;
} else { } else {
i_first_track = cdio_get_first_track_num(p_cdio); print_disc_info(p_cdio);
i_tracks = cdio_get_num_tracks(p_cdio); cdio_destroy(p_cdio);
print_disc_info(p_cdio, i_tracks, i_first_track);
} }
cdio_destroy(p_cdio);
return 0; return 0;
} }

View File

@@ -101,9 +101,12 @@ void possible_throw_device_exception(driver_return_code_t drc);
class CdioCDText class CdioCDText
{ {
public: public:
CdioCDText() CdioCDText(cdtext_t *cdtext)
{ {
p_cdtext = cdtext_init(); // make sure we're initialized on the C side if (NULL == cdtext)
cdtext = cdtext_init();
p_cdtext = cdtext;
} }
~CdioCDText() ~CdioCDText()

View File

@@ -52,12 +52,6 @@ char *get (cdtext_field_t key, track_t i_track)
return cdtext_get (p_cdtext, key, i_track); return cdtext_get (p_cdtext, key, i_track);
} }
/*! returns the C cdtext_t pointer associated with this object. */
cdtext_t *get ()
{
return p_cdtext;
}
/*! returns a const string associated with the given field. NULL is /*! returns a const string associated with the given field. NULL is
returned if key is CDTEXT_INVALID or the field is not set. returned if key is CDTEXT_INVALID or the field is not set.
@@ -81,6 +75,30 @@ void set (cdtext_field_t key, track_t i_track, const uint8_t *value, const char
cdtext_set (p_cdtext, key, value, i_track, charset); cdtext_set (p_cdtext, key, value, i_track, charset);
} }
/*!
returns the selected language
*/
cdtext_lang_t getLanguage()
{
return cdtext_get_language(p_cdtext);
}
/*!
selects a language
*/
bool selectLanguage(const char *lang)
{
return cdtext_select_language(p_cdtext, lang);
}
/*!
returns a list of available languages
*/
cdtext_lang_t *listLanguages()
{
return cdtext_list_languages(p_cdtext);
}
/* /*
* Local variables: * Local variables:

View File

@@ -170,13 +170,18 @@ bool isDiscmodeDvd (discmode_t discmode)
} }
/*! /*!
* Get CD-Text information for a CdIo_t object. Get CD-Text information for a CdIo_t object.
*
* @return the CD-Text object or NULL if obj is NULL @return the CD-Text object or NULL if obj is NULL
* or CD-Text information does not exist. or CD-Text information does not exist.
* */ */
cdtext_t *getCdtext () CdioCDText *getCdtext ()
{ {
return cdio_get_cdtext (p_cdio); cdtext_t *cdtext = cdio_get_cdtext (p_cdio);
if (NULL == cdtext)
return (CdioCDText *) NULL;
else
return new CdioCDText(cdtext);
} }

View File

@@ -286,7 +286,7 @@ bool cdtext_select_language(cdtext_t *p_cdtext, const char *lang);
@param p_cdtext the CD-TEXT object @param p_cdtext the CD-TEXT object
*/ */
cdtext_lang_t *cdtext_languages_available (const cdtext_t *p_cdtext); cdtext_lang_t *cdtext_list_languages (const cdtext_t *p_cdtext);
/*! /*!
Sets the given field at the given track to the given value. Sets the given field at the given track to the given value.

View File

@@ -318,7 +318,7 @@ cdtext_get_language(const cdtext_t *p_cdtext)
@param p_cdtext the CD-TEXT object @param p_cdtext the CD-TEXT object
*/ */
cdtext_lang_t cdtext_lang_t
*cdtext_languages_available(const cdtext_t *p_cdtext) *cdtext_list_languages(const cdtext_t *p_cdtext)
{ {
static cdtext_lang_t avail[CDTEXT_NUM_BLOCKS_MAX]; static cdtext_lang_t avail[CDTEXT_NUM_BLOCKS_MAX];
int i, j=0; int i, j=0;

View File

@@ -188,7 +188,7 @@ cdtext_get
cdtext_get_const cdtext_get_const
cdtext_get_language cdtext_get_language
cdtext_init cdtext_init
cdtext_languages_available cdtext_list_languages
cdtext_set cdtext_set
cdtext_select_language cdtext_select_language
debug_cdio_mmc_feature debug_cdio_mmc_feature

View File

@@ -442,7 +442,7 @@ print_cdtext_info(CdIo_t *p_cdio, track_t i_tracks, track_t i_first_track) {
return; return;
} }
languages = cdtext_languages_available(p_cdtext); languages = cdtext_list_languages(p_cdtext);
for(i=0; i<8; i++) for(i=0; i<8; i++)
if ( CDTEXT_LANGUAGE_UNKNOWN != languages[i] if ( CDTEXT_LANGUAGE_UNKNOWN != languages[i]
&& cdtext_select_language(p_cdtext, cdtext_lang2str(languages[i]))) && cdtext_select_language(p_cdtext, cdtext_lang2str(languages[i])))