]> git.sesse.net Git - vlc/blobdiff - modules/access/cdda/cdda.h
Why are this variable unused ? (commented out for the moment as it memleak)
[vlc] / modules / access / cdda / cdda.h
index e0eeffd5151c341da09943f1ef51cb63e4352dbf..19b26721128692d23d5153242bd2763f5eaf8e6b 100644 (file)
@@ -1,9 +1,8 @@
 /*****************************************************************************
- * cdda.h : CD-DA input module header for vlc
- *          using libcdio, libvcd and libvcdinfo
+ * cdda.h : CD-DA input module header for vlc using libcdio.
  *****************************************************************************
- * Copyright (C) 2003 VideoLAN
- * $Id: cdda.h,v 1.6 2004/02/14 17:25:39 gbazin Exp $
+ * Copyright (C) 2003 the VideoLAN team
+ * $Id$
  *
  * Author: Rocky Bernstein <rocky@panix.com>
  *
  *
  * 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, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
  *****************************************************************************/
 
-#include "../vcdx/cdrom.h"
+#include <vlc_input.h>
+#include <vlc_access.h>
+#include <cdio/cdio.h>
+#include <cdio/cdtext.h>
+#if LIBCDIO_VERSION_NUM >= 73
+#include <cdio/audio.h>
+#include <cdio/mmc.h>
+#endif
+
+#include <vlc_meta.h>
+#include <vlc_codecs.h>
 
 #ifdef HAVE_LIBCDDB
 #include <cddb/cddb.h>
 #endif
 
+
+#define CDDA_MRL_PREFIX "cddax://"
+
+/* Frequency of sample in bits per second. */
+#define CDDA_FREQUENCY_SAMPLE 44100
+
 /*****************************************************************************
  * Debugging
  *****************************************************************************/
 #if INPUT_DEBUG
 #define dbg_print(mask, s, args...) \
    if (p_cdda->i_debug & mask) \
-     msg_Dbg(p_input, "%s: "s, __func__ , ##args)
+     msg_Dbg(p_access, "%s: "s, __func__ , ##args)
 #else
 #define dbg_print(mask, s, args...)
 #endif
 
+#if LIBCDIO_VERSION_NUM >= 72
+#include <cdio/cdda.h>
+#include <cdio/paranoia.h>
+#else
+#define CdIo_t CdIo
+#endif
 /*****************************************************************************
  * cdda_data_t: CD audio information
  *****************************************************************************/
 typedef struct cdda_data_s
 {
-    cddev_t     *p_cddev;                           /* CD device descriptor */
-    int         i_nb_tracks;                        /* Nb of tracks (titles) */
-    int         i_track;                                    /* Current track */
-    lsn_t       i_sector;                                  /* Current Sector */
-    lsn_t *     p_sectors;                                  /* Track sectors */
-    vlc_bool_t  b_end_of_track;           /* If the end of track was reached */
-    int         i_debug;                  /* Debugging mask */
-    char *      mcn;                      /* Media Catalog Number            */
-    intf_thread_t *p_intf;
+  CdIo_t         *p_cdio;             /* libcdio CD device */
+  track_t        i_tracks;            /* # of tracks */
+  track_t        i_first_track;       /* # of first track */
+  track_t        i_titles;            /* # of titles in playlist */
+  /* Current position */
+  track_t        i_track;             /* Current track */
+  lsn_t          i_lsn;               /* Current Logical Sector Number */
+  lsn_t          first_frame;         /* LSN of first frame of this track   */
+  lsn_t          last_frame;          /* LSN of last frame of this track    */
+  lsn_t          last_disc_frame;     /* LSN of last frame on CD            */
+  int            i_blocks_per_read;   /* # blocks to get in a read */
+  int            i_debug;             /* Debugging mask */
 
+  /* Information about CD */
+  vlc_meta_t    *p_meta;
+  char *         psz_mcn;             /* Media Catalog Number */
+  char *         psz_source;          /* CD drive or CD image filename */
+  input_title_t *p_title[CDIO_CD_MAX_TRACKS]; /* This *is* 0 origin, not
+                             track number origin */
+
+#if LIBCDIO_VERSION_NUM >= 72
+  /* Paranoia support */
+  paranoia_mode_t e_paranoia;         /* Use cd paranoia for reads? */
+  cdrom_drive_t *paranoia_cd;         /* Place to store drive
+                     handle given by paranoia. */
+  cdrom_paranoia_t *paranoia;
+
+#endif
 #ifdef HAVE_LIBCDDB
-    int         i_cddb_enabled;
+  bool     b_cddb_enabled;      /* Use CDDB at all? */
   struct  {
-    bool             have_info;      /* True if we have any info */
-    cddb_disc_t     *disc;           /* libcdio uses this to get disc info */
-    int              disc_length;    /* Length in frames of cd. Used in
-                                        CDDB lookups */
+    bool   have_info;           /* True if we have any info */
+    cddb_disc_t *disc;                /* libcdio uses this to get disc
+                     info */
+    int          disc_length;         /* Length in frames of cd. Used
+                     in CDDB lookups */
   } cddb;
 #endif
 
-    WAVEHEADER  waveheader;               /* Wave header for the output data */
-    int         i_header_pos;
+  bool   b_audio_ctl;           /* Use CD-Text audio controls and
+                     audio output? */
+
+  bool   b_cdtext;              /* Use CD-Text at all? If not,
+                     cdtext_preferred is meaningless. */
+  bool   b_cdtext_prefer;       /* Prefer CD-Text info over
+                     CDDB? If no CDDB, the issue
+                     is moot. */
 
+  const cdtext_t *p_cdtext[CDIO_CD_MAX_TRACKS]; /* CD-Text info. Origin is NOT
+                           0 origin but origin of track
+                           number (usually 1).
+                         */
+
+  WAVEHEADER   waveheader;            /* Wave header for the output data  */
+  bool   b_header;
+  bool   b_nav_mode;           /* If false we view the entire CD as
+                    as a unit rather than each track
+                    as a unit. If b_nav_mode then the
+                    slider area represents the Disc rather
+                    than a track
+                      */
+  input_thread_t *p_input;
 } cdda_data_t;
 
-/*****************************************************************************
- * CDDAPlay: Arrange things so we play the specified track.
- * VLC_TRUE is returned if there was no error.
- *****************************************************************************/
-vlc_bool_t  CDDAPlay         ( input_thread_t *, int );
+/* FIXME: This variable is a hack. Would be nice to eliminate. */
+extern access_t *p_cdda_input;