gvfs-02-enable-cdda-without-cdio.diff revision 16350
16350N/A--- gvfs-1.2.0/daemon/gvfsbackendcdda.c.old 2009-04-10 17:18:57.735377000 +0800
16350N/A+++ gvfs-1.2.0/daemon/gvfsbackendcdda.c 2009-04-10 17:19:03.543878000 +0800
15558N/A@@ -47,9 +47,11 @@
13796N/A #include "gvfsjobqueryinfo.h"
13796N/A #include "gvfsjobenumerate.h"
12961N/A
13796N/A+#ifdef HAVE_CDIO
12961N/A #define DO_NOT_WANT_PARANOIA_COMPATIBILITY
12961N/A #include <cdio/paranoia.h>
15558N/A #include <cdio/cdio.h>
12961N/A+#endif
12961N/A
12961N/A /* TODO:
12961N/A *
15558N/A@@ -98,7 +100,9 @@
12961N/A guint64 size;
12961N/A
12961N/A char *device_path;
12961N/A+#ifdef HAVE_CDIO
12961N/A cdrom_drive_t *drive;
12961N/A+#endif
12961N/A int num_open_files;
12961N/A
15558N/A /* Metadata from CD-Text */
15558N/A@@ -116,11 +120,13 @@
12961N/A g_free (cdda_backend->device_path);
12961N/A cdda_backend->device_path = NULL;
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A if (cdda_backend->drive != NULL)
12961N/A {
12961N/A cdio_cddap_close (cdda_backend->drive);
12961N/A cdda_backend->drive = NULL;
12961N/A }
12961N/A+#endif
12961N/A }
12961N/A
15558N/A /* Metadata related functions */
16059N/A@@ -150,6 +156,7 @@
16059N/A static void
16059N/A fetch_metadata (GVfsBackendCdda *cdda_backend)
16059N/A {
16059N/A+#ifdef HAVE_CDIO
16059N/A CdIo *cdio;
16059N/A track_t cdtrack, last_cdtrack;
16059N/A const cdtext_t *cdtext;
16059N/A@@ -182,6 +189,7 @@
16059N/A }
16059N/A
16059N/A cdio_destroy (cdio);
16059N/A+#endif
16059N/A }
16059N/A
16059N/A static void
16059N/A@@ -344,10 +352,15 @@
12961N/A return;
12961N/A }
12961N/A
12961N/A+#ifdef __sun
12961N/A+ cdda_backend->device_path = g_strdup_printf ("/dev/dsk/%s", host);
12961N/A+#else
12961N/A cdda_backend->device_path = g_strdup_printf ("/dev/%s", host);
12961N/A+#endif
12961N/A
12961N/A find_udi_for_device (cdda_backend);
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A cdda_backend->drive = cdio_cddap_identify (cdda_backend->device_path, 0, NULL);
12961N/A if (cdda_backend->drive == NULL)
12961N/A {
16350N/A@@ -373,6 +386,21 @@
12961N/A return;
12961N/A }
16350N/A
16350N/A+#else
16350N/A+ //to prevent gvfs-mount cdda://1 to create a disc icon here
16350N/A+ if (cdda_backend->hal_udi== NULL)
16350N/A+ {
16350N/A+ g_set_error (&error, G_IO_ERROR, G_IO_ERROR_FAILED,
16350N/A+ _("Cannot find drive %s"), cdda_backend->device_path);
16350N/A+ g_vfs_job_failed_from_error (G_VFS_JOB (job), error);
16350N/A+ g_error_free (error);
16350N/A+ release_device (cdda_backend);
16350N/A+ release_metadata (cdda_backend);
16350N/A+ return;
16350N/A+ }
16350N/A+
12961N/A+#endif
16350N/A+
12961N/A /* Translator: %s is the device the disc is inserted into */
12961N/A fuse_name = g_strdup_printf (_("cdda mount on %s"), host);
16350N/A display_name = g_strdup_printf (_("Audio Disc"));
16350N/A@@ -470,7 +498,9 @@
12961N/A }
12961N/A
12961N/A typedef struct {
12961N/A+#ifdef HAVE_CDIO
12961N/A cdrom_paranoia_t *paranoia;
12961N/A+#endif
12961N/A
12961N/A long size; /* size of file being read */
12961N/A long header_size; /* size of the header */
16350N/A@@ -488,15 +518,19 @@
12961N/A * is to avoid seeking back if fewer bytes than whole sector is requested.
12961N/A */
12961N/A long buf_at_sector_num; /* the sector that is cached */
12961N/A+#ifdef HAVE_CDIO
12961N/A char buf_at_sector[CDIO_CD_FRAMESIZE_RAW]; /* the data of the sector */
12961N/A+#endif
12961N/A
12961N/A } ReadHandle;
12961N/A
12961N/A static void
12961N/A free_read_handle (ReadHandle *read_handle)
12961N/A {
12961N/A+#ifdef HAVE_CDIO
12961N/A if (read_handle->paranoia != NULL)
12961N/A cdio_paranoia_free (read_handle->paranoia);
12961N/A+#endif
12961N/A g_free (read_handle->header);
12961N/A g_free (read_handle);
12961N/A }
16350N/A@@ -530,7 +564,11 @@
12961N/A /* TODO: fill in from metadata */
12961N/A artist = NULL;
12961N/A title = NULL;
12961N/A+#ifdef HAVE_CDIO
12961N/A software = "gvfs-cdda using libcdio " CDIO_VERSION;
12961N/A+#else
12961N/A+ software = "gvfs-cdda not using libcdio ";
12961N/A+#endif
12961N/A
12961N/A artist_len = 0;
12961N/A title_len = 0;
16350N/A@@ -633,20 +671,25 @@
12961N/A return;
12961N/A }
12961N/A
12961N/A-
12961N/A+#ifdef HAVE_CDIO
12961N/A read_handle->first_sector = cdio_cddap_track_firstsector (cdda_backend->drive, track_num);
12961N/A read_handle->last_sector = cdio_cddap_track_lastsector (cdda_backend->drive, track_num);
12961N/A+#endif
12961N/A read_handle->sector_cursor = -1;
12961N/A
12961N/A read_handle->cursor = 0;
12961N/A read_handle->buf_at_sector_num = -1;
12961N/A+#ifdef HAVE_CDIO
12961N/A read_handle->content_size = ((read_handle->last_sector - read_handle->first_sector) + 1) * CDIO_CD_FRAMESIZE_RAW;
12961N/A+#endif
12961N/A
12961N/A read_handle->header = create_header (cdda_backend, &(read_handle->header_size), read_handle->content_size);
12961N/A read_handle->size = read_handle->header_size + read_handle->content_size;
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A read_handle->paranoia = cdio_paranoia_init (cdda_backend->drive);
12961N/A cdio_paranoia_modeset (read_handle->paranoia, PARANOIA_MODE_DISABLE);
12961N/A+#endif
12961N/A
12961N/A cdda_backend->num_open_files++;
12961N/A
16350N/A@@ -656,10 +699,12 @@
12961N/A }
12961N/A
12961N/A /* We have to pass in a callback to paranoia_read, even though we don't use it */
12961N/A+#ifdef HAVE_CDIO
12961N/A static void
12961N/A paranoia_callback (long int inpos, paranoia_cb_mode_t function)
12961N/A {
12961N/A }
12961N/A+#endif
12961N/A
12961N/A
12961N/A static void
16350N/A@@ -700,16 +745,20 @@
12961N/A
12961N/A cursor_in_stream = read_handle->cursor - read_handle->header_size;
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A desired_sector = cursor_in_stream / CDIO_CD_FRAMESIZE_RAW + read_handle->first_sector;
12961N/A+#endif
12961N/A
12961N/A if (desired_sector == read_handle->buf_at_sector_num)
12961N/A {
12961N/A /* got it cached */
12961N/A
12961N/A /* skip some bytes */
12961N/A+#ifdef HAVE_CDIO
12961N/A skip_bytes = cursor_in_stream - (desired_sector - read_handle->first_sector) * CDIO_CD_FRAMESIZE_RAW;
12961N/A readbuf = read_handle->buf_at_sector + skip_bytes;
12961N/A bytes_read = CDIO_CD_FRAMESIZE_RAW - skip_bytes;
12961N/A+#endif
12961N/A
12961N/A //g_warning ("read from cache for cursor @ %ld", read_handle->buf_at_sector_num);
12961N/A }
16350N/A@@ -718,16 +767,20 @@
12961N/A /* first check that we're at the right sector */
12961N/A if (desired_sector != read_handle->sector_cursor)
12961N/A {
12961N/A+#ifdef HAVE_CDIO
12961N/A cdio_paranoia_seek (read_handle->paranoia, desired_sector, SEEK_SET);
12961N/A+#endif
12961N/A read_handle->sector_cursor = desired_sector;
12961N/A //g_warning ("seeking cursor to %ld", read_handle->sector_cursor);
12961N/A }
12961N/A
12961N/A /* skip some bytes */
12961N/A+#ifdef HAVE_CDIO
12961N/A skip_bytes = cursor_in_stream - (read_handle->sector_cursor - read_handle->first_sector) * CDIO_CD_FRAMESIZE_RAW;
12961N/A //g_warning ("advanced cursor to %ld", read_handle->sector_cursor);
12961N/A
12961N/A readbuf = (char *) cdio_paranoia_read (read_handle->paranoia, paranoia_callback);
12961N/A+#endif
12961N/A
12961N/A if (readbuf == NULL)
12961N/A {
16350N/A@@ -741,12 +794,14 @@
12961N/A }
12961N/A
12961N/A read_handle->buf_at_sector_num = read_handle->sector_cursor;
12961N/A+#ifdef HAVE_CDIO
12961N/A memcpy (read_handle->buf_at_sector, readbuf, CDIO_CD_FRAMESIZE_RAW);
12961N/A
12961N/A read_handle->sector_cursor++;
12961N/A
12961N/A readbuf += skip_bytes;
12961N/A bytes_read = CDIO_CD_FRAMESIZE_RAW - skip_bytes;
12961N/A+#endif
12961N/A
12961N/A
12961N/A }
16350N/A@@ -839,9 +894,11 @@
12961N/A GIcon *icon;
15558N/A GVfsBackendCddaTrack *track;
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A first = cdio_cddap_track_firstsector (cdda_backend->drive, track_num);
12961N/A last = cdio_cddap_track_lastsector (cdda_backend->drive, track_num);
12961N/A content_size = (last - first + 1) * CDIO_CD_FRAMESIZE_RAW;
12961N/A+#endif
12961N/A
12961N/A header = create_header (cdda_backend, &header_size, content_size);
12961N/A g_free (header);
16350N/A@@ -916,19 +973,23 @@
12961N/A return;
12961N/A }
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A if (track_num > cdda_backend->drive->tracks)
12961N/A {
12961N/A error = g_error_new (G_IO_ERROR, G_IO_ERROR_NOT_FOUND, _("File doesn't exist"));
12961N/A g_vfs_job_failed_from_error (G_VFS_JOB (job), error);
12961N/A return;
12961N/A }
12961N/A+#endif
12961N/A
12961N/A+#ifdef HAVE_CDIO
12961N/A if (! cdio_cddap_track_audiop (cdda_backend->drive, track_num))
12961N/A {
12961N/A error = g_error_new (G_IO_ERROR, G_IO_ERROR_NOT_FOUND, _("The file does not exist or isn't an audio track"));
12961N/A g_vfs_job_failed_from_error (G_VFS_JOB (job), error);
12961N/A return;
12961N/A }
12961N/A+#endif
12961N/A
12961N/A set_info_for_track (cdda_backend, info, track_num);
12961N/A }
16350N/A@@ -952,6 +1013,7 @@
12961N/A //g_warning ("enumerate (%s)", filename);
12961N/A
12961N/A l = NULL;
12961N/A+#ifdef HAVE_CDIO
12961N/A for (n = 1; n <= cdda_backend->drive->tracks; n++)
12961N/A {
12961N/A char *name;
16350N/A@@ -971,6 +1033,7 @@
12961N/A
12961N/A l = g_list_append (l, info);
12961N/A }
12961N/A+#endif
12961N/A
12961N/A g_vfs_job_succeeded (G_VFS_JOB (job));
16350N/A
16350N/A--- gvfs-1.1.6/configure.ac.old 2009-02-17 12:51:28.708111000 +0800
16350N/A+++ gvfs-1.1.6/configure.ac 2009-02-17 12:51:51.196942000 +0800
16350N/A@@ -238,10 +238,10 @@
16350N/A CDDA_CFLAGS=
16350N/A
16350N/A if test "x$enable_cdda" != "xno"; then
16350N/A- PKG_CHECK_EXISTS(libcdio_paranoia >= 0.78.2 hal >= $HAL_REQUIRED, msg_cdda=yes)
16350N/A+ PKG_CHECK_EXISTS(hal >= $HAL_REQUIRED, msg_cdda=yes)
16350N/A
16350N/A if test "x$msg_cdda" = "xyes"; then
16350N/A- PKG_CHECK_MODULES(CDDA, libcdio_paranoia hal >= $HAL_REQUIRED)
16350N/A+ PKG_CHECK_MODULES(CDDA, hal >= $HAL_REQUIRED)
16350N/A AC_DEFINE(HAVE_CDDA, 1, [Define to 1 if CDDA is going to be built])
16350N/A fi
16350N/A fi
16350N/A
16059N/A--- /usr/tmp/clean/gvfs-0.2.3/daemon/cdda.mount.in 2008-04-08 02:27:43.000000000 +0100
16059N/A+++ gvfs-0.2.3/daemon/cdda.mount.in 2008-04-28 08:56:52.278895000 +0100
12961N/A@@ -1,4 +1,4 @@
12961N/A [Mount]
12961N/A Type=cdda
12961N/A Exec=@libexecdir@/gvfsd-cdda
12961N/A-AutoMount=false
12961N/A+AutoMount=true
16350N/A