include/cdio++ Add pre- and post- increment/decrement operators for
libcdio enums that it makes sense to iterate over. example/C++/OO/*: use these example/*: match up C and C++ programs better.
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: cdtext.cpp,v 1.1 2005/11/10 11:11:15 rocky Exp $
|
$Id: cdtext.cpp,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -18,9 +18,22 @@
|
|||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Simple program to list CD-Text info of a Compact Disc using libcdio. */
|
/* Simple program to list CD-Text info of a Compact Disc using
|
||||||
|
libcdio. See also corresponding C program of a similar name.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STDIO_H
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SYS_TYPES_H
|
||||||
#include <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. */
|
||||||
@@ -33,12 +46,10 @@ print_cdtext_track_info(CdioDevice *device, track_t i_track,
|
|||||||
cdtext_t *cdtext = device->getCdtext(0);
|
cdtext_t *cdtext = device->getCdtext(0);
|
||||||
if (NULL != cdtext) {
|
if (NULL != cdtext) {
|
||||||
cdtext_field_t i;
|
cdtext_field_t i;
|
||||||
int j=0;
|
|
||||||
|
|
||||||
printf("%s\n", psz_msg);
|
printf("%s\n", psz_msg);
|
||||||
|
|
||||||
for (j=0; j < MAX_CDTEXT_FIELDS; j++) {
|
for (i= (cdtext_field_t) MIN_CDTEXT_FIELD; i < MAX_CDTEXT_FIELDS; i++) {
|
||||||
i = (cdtext_field_t) j;
|
|
||||||
if (cdtext->field[i]) {
|
if (cdtext->field[i]) {
|
||||||
printf("\t%s: %s\n", cdtext_field2str(i), cdtext->field[i]);
|
printf("\t%s: %s\n", cdtext_field2str(i), cdtext->field[i]);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: device.cpp,v 1.1 2005/11/10 11:11:15 rocky Exp $
|
$Id: device.cpp,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -18,8 +18,9 @@
|
|||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Simple program to show drivers installed and what the default
|
/* Simple program to show drivers installed and what the default
|
||||||
CD-ROM drive is. */
|
CD-ROM drive is. See also corresponding C program of a similar
|
||||||
|
name. */
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
@@ -123,5 +124,16 @@ main(int argc, const char *argv[])
|
|||||||
} else {
|
} else {
|
||||||
printf("Problem in trying to find a driver.\n\n");
|
printf("Problem in trying to find a driver.\n\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
driver_id_t driver_id;
|
||||||
|
for (driver_id=CDIO_MIN_DRIVER; driver_id<=CDIO_MAX_DRIVER; driver_id++)
|
||||||
|
if (cdio_have_driver(driver_id))
|
||||||
|
printf("We have: %s\n", cdio_driver_describe(driver_id));
|
||||||
|
else
|
||||||
|
printf("We don't have: %s\n", cdio_driver_describe(driver_id));
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: eject.cpp,v 1.1 2005/11/10 11:11:15 rocky Exp $
|
$Id: eject.cpp,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -22,6 +22,8 @@
|
|||||||
|
|
||||||
If a single argument is given, it is used as the CD-ROM device to
|
If a single argument is given, it is used as the CD-ROM device to
|
||||||
eject/close. Otherwise a CD-ROM drive will be scanned for.
|
eject/close. Otherwise a CD-ROM drive will be scanned for.
|
||||||
|
|
||||||
|
See also corresponding C program of a similar name.
|
||||||
*/
|
*/
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: cdtext.c,v 1.2 2005/01/04 04:40:22 rocky Exp $
|
$Id: cdtext.c,v 1.3 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2004, 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2004, 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -18,12 +18,20 @@
|
|||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Simple program to list CD-Text info of a Compact Disc using libcdio. */
|
/* Simple program to list CD-Text info of a Compact Disc using
|
||||||
|
libcdio. See also corresponding C++ programs of similar names. */
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STDIO_H
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SYS_TYPES_H
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#endif
|
||||||
#include <cdio/cdio.h>
|
#include <cdio/cdio.h>
|
||||||
#include <cdio/cdtext.h>
|
#include <cdio/cdtext.h>
|
||||||
|
|
||||||
@@ -77,7 +85,7 @@ main(int argc, const char *argv[])
|
|||||||
cdio_destroy(p_cdio);
|
cdio_destroy(p_cdio);
|
||||||
}
|
}
|
||||||
|
|
||||||
p_cdio = cdio_open (NULL, DRIVER_UNKNOWN);
|
p_cdio = cdio_open (NULL, DRIVER_DEVICE);
|
||||||
i_first_track = cdio_get_first_track_num(p_cdio);
|
i_first_track = cdio_get_first_track_num(p_cdio);
|
||||||
i_tracks = cdio_get_num_tracks(p_cdio);
|
i_tracks = cdio_get_num_tracks(p_cdio);
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: device.c,v 1.1 2005/02/06 15:09:10 rocky Exp $
|
$Id: device.c,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2003, 2004, 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2003, 2004, 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -18,8 +18,9 @@
|
|||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Simple program to show drivers installed and what the default
|
/* Simple program to show drivers installed and what the default
|
||||||
CD-ROM drive is. */
|
CD-ROM drive is. See also corresponding C++ programs of similar
|
||||||
|
names .*/
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
#endif
|
#endif
|
||||||
@@ -100,7 +101,6 @@ int
|
|||||||
main(int argc, const char *argv[])
|
main(int argc, const char *argv[])
|
||||||
{
|
{
|
||||||
CdIo_t *p_cdio = cdio_open (NULL, DRIVER_UNKNOWN);
|
CdIo_t *p_cdio = cdio_open (NULL, DRIVER_UNKNOWN);
|
||||||
driver_id_t driver_id;
|
|
||||||
|
|
||||||
if (NULL != p_cdio) {
|
if (NULL != p_cdio) {
|
||||||
char *default_device = cdio_get_default_device(p_cdio);
|
char *default_device = cdio_get_default_device(p_cdio);
|
||||||
@@ -123,11 +123,14 @@ main(int argc, const char *argv[])
|
|||||||
} else {
|
} else {
|
||||||
printf("Problem in trying to find a driver.\n\n");
|
printf("Problem in trying to find a driver.\n\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (driver_id=CDIO_MIN_DRIVER; driver_id<=CDIO_MAX_DRIVER; driver_id++)
|
{
|
||||||
if (cdio_have_driver(driver_id))
|
driver_id_t driver_id;
|
||||||
printf("We have: %s\n", cdio_driver_describe(driver_id));
|
for (driver_id=CDIO_MIN_DRIVER; driver_id<=CDIO_MAX_DRIVER; driver_id++)
|
||||||
else
|
if (cdio_have_driver(driver_id))
|
||||||
printf("We don't have: %s\n", cdio_driver_describe(driver_id));
|
printf("We have: %s\n", cdio_driver_describe(driver_id));
|
||||||
|
else
|
||||||
|
printf("We don't have: %s\n", cdio_driver_describe(driver_id));
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: eject.c,v 1.1 2005/11/07 07:44:00 rocky Exp $
|
$Id: eject.c,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -22,6 +22,8 @@
|
|||||||
|
|
||||||
If a single argument is given, it is used as the CD-ROM device to
|
If a single argument is given, it is used as the CD-ROM device to
|
||||||
eject/close. Otherwise a CD-ROM drive will be scanned for.
|
eject/close. Otherwise a CD-ROM drive will be scanned for.
|
||||||
|
|
||||||
|
See also corresponding C++ program of a similar name.
|
||||||
*/
|
*/
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
# include "config.h"
|
# include "config.h"
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# $Id: Makefile.am,v 1.1 2005/11/10 11:11:16 rocky Exp $
|
# $Id: Makefile.am,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
#
|
#
|
||||||
# Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
# Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
#
|
#
|
||||||
@@ -28,5 +28,6 @@ libcdioinclude_HEADERS = \
|
|||||||
device.hpp \
|
device.hpp \
|
||||||
devices.hpp \
|
devices.hpp \
|
||||||
disc.hpp \
|
disc.hpp \
|
||||||
|
enum.hpp \
|
||||||
read.hpp \
|
read.hpp \
|
||||||
track.hpp
|
track.hpp
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* -*- C++ -*-
|
/* -*- C++ -*-
|
||||||
$Id: cdio.hpp,v 1.1 2005/11/10 11:11:16 rocky Exp $
|
$Id: cdio.hpp,v 1.2 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -29,6 +29,10 @@
|
|||||||
|
|
||||||
#include <cdio/cdio.h>
|
#include <cdio/cdio.h>
|
||||||
|
|
||||||
|
// Make pre- and post-increment operators for enums in libcdio where it
|
||||||
|
// makes sense.
|
||||||
|
#include <cdio++/enum.hpp>
|
||||||
|
|
||||||
class Cdio {
|
class Cdio {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|||||||
50
include/cdio++/enum.hpp
Normal file
50
include/cdio++/enum.hpp
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
/* -*- C++ -*-
|
||||||
|
$Id: enum.hpp,v 1.1 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program; if not, write to the Free Software
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** \file enum.hpp
|
||||||
|
*
|
||||||
|
* \brief C++ header for pre- and post-increment operators for
|
||||||
|
* enumerations defined in libcdio that it makes sense to iterate over.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define ENUM_ITERATE_FNS(type) \
|
||||||
|
inline \
|
||||||
|
type &operator++(type &t) \
|
||||||
|
{ \
|
||||||
|
return t = type(t + 1); \
|
||||||
|
} \
|
||||||
|
inline \
|
||||||
|
type &operator++(type &t, int) \
|
||||||
|
{ \
|
||||||
|
return t = type(t + 1); \
|
||||||
|
} \
|
||||||
|
inline \
|
||||||
|
type &operator--(type &t) \
|
||||||
|
{ \
|
||||||
|
return t = type(t - 1); \
|
||||||
|
} \
|
||||||
|
inline \
|
||||||
|
type &operator--(type &t, int) \
|
||||||
|
{ \
|
||||||
|
return t = type(t - 1); \
|
||||||
|
}
|
||||||
|
|
||||||
|
ENUM_ITERATE_FNS(cdtext_field_t)
|
||||||
|
ENUM_ITERATE_FNS(driver_id_t)
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
$Id: cdtext.h,v 1.12 2005/11/10 00:44:40 rocky Exp $
|
$Id: cdtext.h,v 1.13 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2004, 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2004, 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
adapted from cuetools
|
adapted from cuetools
|
||||||
@@ -37,6 +37,7 @@ extern "C" {
|
|||||||
#endif /* __cplusplus */
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
#define MAX_CDTEXT_FIELDS 13
|
#define MAX_CDTEXT_FIELDS 13
|
||||||
|
#define MIN_CDTEXT_FIELD 0
|
||||||
|
|
||||||
/*! \brief structure for holding CD-Text information
|
/*! \brief structure for holding CD-Text information
|
||||||
|
|
||||||
@@ -46,7 +47,9 @@ extern "C" {
|
|||||||
char *field[MAX_CDTEXT_FIELDS];
|
char *field[MAX_CDTEXT_FIELDS];
|
||||||
};
|
};
|
||||||
|
|
||||||
/*! \brief A list of all of the CD-Text fields */
|
/*! \brief A list of all of the CD-Text fields. Because
|
||||||
|
the interval has no gaps, we can use ++ to iterate over fields.
|
||||||
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
CDTEXT_ARRANGER = 0, /**< name(s) of the arranger(s) */
|
CDTEXT_ARRANGER = 0, /**< name(s) of the arranger(s) */
|
||||||
CDTEXT_COMPOSER = 1, /**< name(s) of the composer(s) */
|
CDTEXT_COMPOSER = 1, /**< name(s) of the composer(s) */
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/* -*- c -*-
|
/* -*- c -*-
|
||||||
$Id: device.h,v 1.25 2005/11/07 07:44:00 rocky Exp $
|
$Id: device.h,v 1.26 2005/11/11 12:26:57 rocky Exp $
|
||||||
|
|
||||||
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
Copyright (C) 2005 Rocky Bernstein <rocky@panix.com>
|
||||||
|
|
||||||
@@ -136,6 +136,8 @@ extern "C" {
|
|||||||
* different than what is available on a given host.
|
* different than what is available on a given host.
|
||||||
*
|
*
|
||||||
* Order is a little significant since the order is used in scans.
|
* Order is a little significant since the order is used in scans.
|
||||||
|
* Also the enumeration values are assumed not to leave any holes so
|
||||||
|
* we can use ++ to iterate over values.
|
||||||
* We have to start with DRIVER_UNKNOWN and devices should come before
|
* We have to start with DRIVER_UNKNOWN and devices should come before
|
||||||
* disk-image readers. By putting something towards the top (a lower
|
* disk-image readers. By putting something towards the top (a lower
|
||||||
* enumeration number), in an iterative scan we prefer that to
|
* enumeration number), in an iterative scan we prefer that to
|
||||||
|
|||||||
Reference in New Issue
Block a user