aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--audio/gnome-media/Makefile36
-rw-r--r--audio/gnome-media/distinfo1
-rw-r--r--audio/gnome-media/files/patch-ac50
-rw-r--r--audio/gnome-media/files/patch-ad73
-rw-r--r--audio/gnome-media/files/patch-ae881
-rw-r--r--audio/gnome-media/pkg-comment1
-rw-r--r--audio/gnome-media/pkg-descr3
-rw-r--r--audio/gnome-media/pkg-plist32
-rw-r--r--audio/gnomemedia/Makefile36
-rw-r--r--audio/gnomemedia/distinfo1
-rw-r--r--audio/gnomemedia/files/patch-ac50
-rw-r--r--audio/gnomemedia/files/patch-ad73
-rw-r--r--audio/gnomemedia/files/patch-ae881
-rw-r--r--audio/gnomemedia/pkg-comment1
-rw-r--r--audio/gnomemedia/pkg-descr3
-rw-r--r--audio/gnomemedia/pkg-plist32
-rw-r--r--audio/gnomemedia2/Makefile36
-rw-r--r--audio/gnomemedia2/distinfo1
-rw-r--r--audio/gnomemedia2/files/patch-ac50
-rw-r--r--audio/gnomemedia2/files/patch-ad73
-rw-r--r--audio/gnomemedia2/files/patch-ae881
-rw-r--r--audio/gnomemedia2/pkg-comment1
-rw-r--r--audio/gnomemedia2/pkg-descr3
-rw-r--r--audio/gnomemedia2/pkg-plist32
24 files changed, 3231 insertions, 0 deletions
diff --git a/audio/gnome-media/Makefile b/audio/gnome-media/Makefile
new file mode 100644
index 000000000000..8a17ad7c6c90
--- /dev/null
+++ b/audio/gnome-media/Makefile
@@ -0,0 +1,36 @@
+# New ports collection makefile for: gnome-media
+# Version required: 1.0.1
+# Date created: 20 January 1999
+# Whom: Jeremy Lea <reg@shale.csir.co.za>
+#
+# $Id: $
+#
+
+DISTNAME= gnome-media-1.0.1
+PKGNAME= gnomemedia-1.0.1
+CATEGORIES= audio gnome
+MASTER_SITES= ${MASTER_SITE_GNOME}
+MASTER_SITE_SUBDIR= gnome-1.0/sources
+
+MAINTAINER= reg@shale.csir.co.za
+
+BUILD_DEPENDS= panel:${PORTSDIR}/x11/gnomecore
+RUN_DEPENDS= panel:${PORTSDIR}/x11/gnomecore
+
+# implicit dependencies:
+# gettext, esound, gnomelibs
+
+USE_X_PREFIX= yes
+USE_GMAKE= yes
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --without-ncurses \
+ --localstatedir=${PREFIX}/share/gnome \
+ --datadir=${PREFIX}/share/gnome \
+ --with-gnome=${X11BASE}
+CONFIGURE_ENV= CPPFLAGS="-I${LOCALBASE}/include" \
+ LIBS="-L${LOCALBASE}/lib"
+
+post-install:
+ @${SETENV} OBJFORMAT=${PORTOBJFORMAT} ${LDCONFIG} -m ${PREFIX}/lib
+
+.include <bsd.port.mk>
diff --git a/audio/gnome-media/distinfo b/audio/gnome-media/distinfo
new file mode 100644
index 000000000000..6beda9aad6f4
--- /dev/null
+++ b/audio/gnome-media/distinfo
@@ -0,0 +1 @@
+MD5 (gnome-media-1.0.1.tar.gz) = 34c5fa120431aa3ff07b087cbc7cdcdf
diff --git a/audio/gnome-media/files/patch-ac b/audio/gnome-media/files/patch-ac
new file mode 100644
index 000000000000..7c6e1965bf81
--- /dev/null
+++ b/audio/gnome-media/files/patch-ac
@@ -0,0 +1,50 @@
+--- vu-meter/Makefile.in.orig Wed Mar 3 12:35:57 1999
++++ vu-meter/Makefile.in Wed Mar 3 12:36:25 1999
+@@ -116,9 +116,9 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+-INCLUDES = -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(GNOME_INCLUDEDIR)
++INCLUDES = -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(GNOME_INCLUDEDIR)
+
+
+ bin_PROGRAMS = vumeter
+--- gmix/Makefile.in.orig Sat Feb 27 09:22:00 1999
++++ gmix/Makefile.in Wed Mar 3 12:37:46 1999
+@@ -116,11 +116,11 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+ EXTRA_DIST = README TODO NEWS gmix.desktop
+
+-INCLUDES = -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(GNOME_INCLUDEDIR)
++INCLUDES = -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(GNOME_INCLUDEDIR)
+
+
+ bin_PROGRAMS = gmix
+--- tcd/Makefile.in.orig Sat Feb 27 09:22:02 1999
++++ tcd/Makefile.in Wed Mar 3 12:38:28 1999
+@@ -116,7 +116,7 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+ EXTRA_DIST = README TODO NEWS gtcd.desktop
+
+@@ -141,7 +141,7 @@
+
+ CLEANFILES = *~
+
+-INCLUDES = -I$(includedir) $(GNOME_INCLUDEDIR) $(CURSES_INCLUDEDIR) -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(USE_CD_CHANGER) -g
++INCLUDES = -I$(includedir) $(GNOME_INCLUDEDIR) $(CURSES_INCLUDEDIR) -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(USE_CD_CHANGER) -g
+
+
+ Audio_DATA = gtcd.desktop
diff --git a/audio/gnome-media/files/patch-ad b/audio/gnome-media/files/patch-ad
new file mode 100644
index 000000000000..6a817788707f
--- /dev/null
+++ b/audio/gnome-media/files/patch-ad
@@ -0,0 +1,73 @@
+--- gmix/gmix.c.orig Fri Feb 19 18:30:49 1999
++++ gmix/gmix.c Wed Mar 3 10:49:51 1999
+@@ -94,6 +94,17 @@
+ /*
+ * All, that is known about a mixer-device
+ */
++
++#if !defined(OPEN_SOUND_SYSTEM)
++typedef struct mixer_info
++{
++ char id[16];
++ char name[32];
++ int modify_counter;
++ int fillers[10];
++} mixer_info;
++#endif
++
+ typedef struct device_info {
+ int fd;
+ mixer_info info;
+@@ -272,11 +283,7 @@
+ /*
+ * open the mixer-device
+ */
+- if (num==0) {
+- sprintf(device_name, "/dev/mixer");
+- } else {
+- sprintf(device_name, "/dev/mixer%i", num);
+- }
++ sprintf(device_name, "/dev/mixer%i", num);
+ new_device->fd=open(device_name, O_RDWR, 0);
+ if (new_device->fd<0) {
+ free(new_device);
+@@ -291,6 +298,8 @@
+ fprintf(stderr, "Warning: This version of gmix was compiled with a different version of\nsoundcard.h.\n");
+ }
+ #endif
++
++#if defined(OPEN_SOUND_SYSTEM)
+ /*
+ * mixer-name
+ */
+@@ -301,6 +310,11 @@
+ }
+ if(!isalpha(new_device->info.name[0]))
+ g_snprintf(new_device->info.name, 31, "Card %d", num+1);
++#else
++ g_snprintf(new_device->info.id, 15, "mixer%d", num);
++ g_snprintf(new_device->info.name, 31, "Sound Card %d", num+1);
++ new_device->info.modify_counter=0;
++#endif
+ /*
+ * several bitmasks describing the mixer
+ */
+@@ -386,15 +400,15 @@
+ {
+ int cnt;
+ device_info *new_device;
+- cnt=0; devices=NULL;
++ cnt=0; num_mixers=0; devices=NULL;
+ do {
+ new_device=open_device(cnt++);
+ if (new_device) {
+ new_device->channels=make_channels(new_device);
+ devices=g_list_append(devices, new_device);
++ num_mixers++;
+ }
+- } while (new_device);
+- num_mixers=cnt-1;
++ } while ((errno == EACCES) || (errno == EINVAL) || new_device);
+ }
+
+ void free_one_device(gpointer a, gpointer b)
diff --git a/audio/gnome-media/files/patch-ae b/audio/gnome-media/files/patch-ae
new file mode 100644
index 000000000000..6dd5f1c41e5f
--- /dev/null
+++ b/audio/gnome-media/files/patch-ae
@@ -0,0 +1,881 @@
+--- tcd/callbacks.c.orig Sun Feb 21 20:32:04 1999
++++ tcd/callbacks.c Wed Mar 3 10:57:00 1999
+@@ -10,7 +10,7 @@
+
+ void play_cb(GtkWidget *widget, gpointer data)
+ {
+- if(cd.sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED)
++ if(SC_AUDIOSTATUS(cd.sc)==CDROM_AUDIO_PAUSED)
+ tcd_pausecd(&cd);
+ else
+ tcd_playtracks(&cd, cd.first_t, cd.last_t, prefs.only_use_trkind);
+@@ -42,7 +42,7 @@
+ cd.play_method = NORMAL;
+ cd.repeat_track = -1;
+ /* SDH: Make sure play/pause state change is noticed */
+- cd.sc.cdsc_audiostatus = -1;
++ SC_AUDIOSTATUS(cd.sc) = -1;
+ if(cd.isplayable)
+ {
+ make_goto_menu();
+--- tcd/cddb.c.orig Sat Feb 20 23:08:10 1999
++++ tcd/cddb.c Wed Mar 3 10:57:00 1999
+@@ -120,16 +120,16 @@
+ {
+ int min, sec;
+
+- min = cd->trk[i].toc.cdte_addr.msf.minute;
+- sec = cd->trk[i].toc.cdte_addr.msf.second;
++ min = TOC_MINUTE(cd->trk[i]);
++ sec = TOC_MINUTE(cd->trk[i]);
+
+ n = (min*60)+sec;
+- fprintf( fp, "# %u\n", (n*75)+cd->trk[i].toc.cdte_addr.msf.frame );
++ fprintf( fp, "# %u\n", (n*75)+TOC_FRAME(cd->trk[i]) );
+ }
+ /* Print the number of seconds */
+ fprintf( fp, "#\n# Disc length: %i seconds\n",
+- (cd->trk[cd->last_t+1].toc.cdte_addr.msf.minute*60)
+- +(cd->trk[cd->last_t+1].toc.cdte_addr.msf.second) );
++ (TOC_MINUTE(cd->trk[cd->last_t+1])*60)
++ +(TOC_SECOND(cd->trk[cd->last_t+1])) );
+
+ /* FIXME increment revision. sigh, lousy cddb */
+ fprintf( fp, "#\n# Revision: 0\n" );
+@@ -160,10 +160,10 @@
+ {
+ int min, sec;
+
+- min = cd->trk[i].toc.cdte_addr.msf.minute;
+- sec = cd->trk[i].toc.cdte_addr.msf.second;
++ min = TOC_MINUTE(cd->trk[i]);
++ sec = TOC_SECOND(cd->trk[i]);
+
+- l=sprintf( tmp, "%u ", calc_offset(min,sec,cd->trk[i].toc.cdte_addr.msf.frame));
++ l=sprintf( tmp, "%u ", calc_offset(min,sec,TOC_FRAME(cd->trk[i])));
+
+ if(blen>l)
+ {
+@@ -172,8 +172,8 @@
+ }
+ }
+ l=sprintf( tmp, "%i\n",
+- (cd->trk[cd->last_t+1].toc.cdte_addr.msf.minute*60)
+- +(cd->trk[cd->last_t+1].toc.cdte_addr.msf.second) );
++ (TOC_MINUTE(cd->trk[cd->last_t+1])*60)
++ +(TOC_SECOND(cd->trk[cd->last_t+1])) );
+ if(blen>l)
+ strcat( buf,tmp );
+
+@@ -203,9 +203,9 @@
+
+ for( i=0; i <= cd->last_t+1; i++ )
+ {
+- cdtoc[i].frame = cd->trk[i+1].toc.cdte_addr.msf.frame;
+- cdtoc[i].min = cd->trk[i+1].toc.cdte_addr.msf.minute;
+- cdtoc[i].sec = cd->trk[i+1].toc.cdte_addr.msf.second;
++ cdtoc[i].frame = TOC_FRAME(cd->trk[i+1]);
++ cdtoc[i].min = TOC_MINUTE(cd->trk[i+1]);
++ cdtoc[i].sec = TOC_SECOND(cd->trk[i+1]);
+ }
+
+
+--- tcd/gtcd.c.orig Wed Feb 24 02:48:49 1999
++++ tcd/gtcd.c Wed Mar 3 10:57:00 1999
+@@ -408,8 +408,8 @@
+ break;
+ case DISC_R:
+ cur = cd.cur_pos_abs;
+- end = (cd.trk[cd.last_t+1].toc.cdte_addr.msf.minute
+- *60)+cd.trk[cd.last_t+1].toc.cdte_addr.msf.second;
++ end = (TOC_MINUTE(cd.trk[cd.last_t+1])*60
++ +TOC_SECOND(cd.trk[cd.last_t+1]));
+ pos = end-cur;
+ min = pos/60;
+ sec = pos-(pos/60)*60;
+@@ -490,7 +490,7 @@
+
+ if( !cd.err )
+ {
+- switch( cd.sc.cdsc_audiostatus )
++ switch( SC_AUDIOSTATUS(cd.sc) )
+ {
+ case CDROM_AUDIO_INVALID:
+ strcpy(tmp, _("No Disc"));
+@@ -577,8 +577,8 @@
+ }
+
+ /* see if we need to repeat */
+- if( cd.sc.cdsc_audiostatus != CDROM_AUDIO_PLAY &&
+- cd.sc.cdsc_audiostatus != CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd.sc) != CDROM_AUDIO_PLAY &&
++ SC_AUDIOSTATUS(cd.sc) != CDROM_AUDIO_PAUSED )
+ {
+ if( cd.play_method == REPEAT_CD )
+ tcd_playtracks( &cd, cd.first_t, cd.last_t, prefs.only_use_trkind);
+@@ -593,14 +593,14 @@
+
+ void status_changed(void)
+ {
+- if(old_status != cd.sc.cdsc_audiostatus)
++ if(old_status != SC_AUDIOSTATUS(cd.sc))
+ {
+ GtkWidget *pixmap;
+ GtkSignalFunc func;
+ char tmp[256];
+ char *name;
+
+- old_status = cd.sc.cdsc_audiostatus;
++ old_status = SC_AUDIOSTATUS(cd.sc);
+ g_snprintf(tmp, 255, "tcd/%s.xpm",
+ (old_status==CDROM_AUDIO_PLAY)?"pause":"play");
+
+--- tcd/gtracked.c.orig Thu Feb 11 18:48:56 1999
++++ tcd/gtracked.c Wed Mar 3 10:57:00 1999
+@@ -166,8 +166,8 @@
+ /* Disc area */
+ disc_table = gtk_table_new(2, 2, FALSE);
+ g_snprintf(tmp, 63, _("Disc Information (%02u:%02u minutes)"),
+- cd.trk[cd.last_t+1].toc.cdte_addr.msf.minute,
+- cd.trk[cd.last_t+1].toc.cdte_addr.msf.second);
++ TOC_MINUTE(cd.trk[cd.last_t+1]),
++ TOC_SECOND(cd.trk[cd.last_t+1]));
+
+ disc_frame = gtk_frame_new(tmp);
+ label = gtk_label_new(_("Artist / Title"));
+--- tcd/linux-cdrom.c.orig Tue Feb 23 06:52:46 1999
++++ tcd/linux-cdrom.c Wed Mar 3 10:57:00 1999
+@@ -77,7 +77,7 @@
+ if(!homedir)
+ homedir = "/";
+
+-#if defined(TCD_CHANGER_ENABLED)
++#if defined(TCD_CHANGER_ENABLED) && !defined(TCD_BSD)
+ cd->nslots = ioctl( cd->cd_dev, CDROM_CHANGER_NSLOTS );
+ #else
+ cd->nslots = 0;
+@@ -120,34 +120,58 @@
+
+ int tcd_readtoc( cd_struct *cd )
+ {
+- int tmp,i;
++ int i;
+ int delsecs;
++#ifdef TCD_BSD
++ struct ioc_read_toc_single_entry tocentry;
++#endif
+
+ debug("cdrom.c: tcd_readtoc(%p) top\n", cd );
+ cd->err = FALSE;
+ cd->isplayable=FALSE;
+
+ /* read the TOC header */
++#ifdef TCD_BSD
++ if(ioctl( cd->cd_dev, CDIOREADTOCHEADER, &cd->tochdr))
++#else
+ if(ioctl( cd->cd_dev, CDROMREADTOCHDR, &cd->tochdr))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCHDR ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+
+ /* grab first & last tracks */
++#ifdef TCD_BSD
++ cd->first_t = cd->tochdr.starting_track;
++ cd->last_t = cd->tochdr.ending_track;
++#else
+ cd->first_t = cd->tochdr.cdth_trk0;
+ cd->last_t = cd->tochdr.cdth_trk1;
++#endif
+
+ /* read the leadout track */
++#ifdef TCD_BSD
++ tocentry.track = cd->last_t+1; /* Magic last track */
++ tocentry.address_format = CD_MSF_FORMAT;
++#else
+ cd->trk[C(cd->last_t+1)].toc.cdte_track = CDROM_LEADOUT;
+ cd->trk[C(cd->last_t+1)].toc.cdte_format = CDROM_MSF;
++#endif
+
+ /* read the leadout toc */
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOREADTOCENTRY, &tocentry))
++#else
+ if(ioctl(cd->cd_dev, CDROMREADTOCENTRY, &cd->trk[C(cd->last_t+1)].toc))
++#endif
+ {
+ strcpy(cd->errmsg, "Can't read disc.");
+ cd->err = TRUE;
+@@ -155,40 +179,65 @@
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCENTRY ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ cd->trk[C(cd->last_t+1)].toc = tocentry.entry;
++#endif
++ cd->trk[C(cd->last_t+1)].length = TOC_MINUTE(cd->trk[C(cd->last_t+1)]) * 60 +
++ TOC_SECOND(cd->trk[C(cd->last_t+1)]);
++ cd->trk[C(cd->last_t+1)].start = cd->trk[C(cd->last_t+1)].length * 75 +
++ TOC_FRAME(cd->trk[C(cd->last_t+1)]);
+
+ /* read the rest of the tocs */
+ for( i = cd->first_t; i <= cd->last_t; i++ )
+ {
++#ifdef TCD_BSD
++ tocentry.track = i;
++ tocentry.address_format = CD_MSF_FORMAT;
++#else
+ cd->trk[C(i)].toc.cdte_track = i;
+ cd->trk[C(i)].toc.cdte_format = CDROM_MSF;
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOREADTOCENTRY, &tocentry))
++#else
+ if(ioctl(cd->cd_dev, CDROMREADTOCENTRY, &cd->trk[C(i)].toc))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCENTRY ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+
++#ifdef TCD_BSD
++ cd->trk[C(i)].toc = tocentry.entry;
++ cd->trk[C(i)].type = cd->trk[C(i)].toc.control;
++#else
+ cd->trk[C(i)].type = cd->trk[C(i)].toc.cdte_ctrl;
+- cd->trk[C(i)].length = cd->trk[C(i)].toc.cdte_addr.msf.minute * 60 +
+- cd->trk[C(i)].toc.cdte_addr.msf.second;
++#endif
++ cd->trk[C(i)].length = TOC_MINUTE(cd->trk[C(i)]) * 60 +
++ TOC_SECOND(cd->trk[C(i)]);
+ cd->trk[C(i)].start = cd->trk[C(i)].length * 75 +
+- cd->trk[C(i)].toc.cdte_addr.msf.frame;
++ TOC_FRAME(cd->trk[C(i)]);
+ }
+
+ /* calculate track times */
+ for(i = cd->first_t; i <= cd->last_t; i ++)
+ {
+ /* Taken from cdtool...Thanks Thomas I.! */
+- delsecs = cd->trk[C(i+1)].toc.cdte_addr.msf.minute * 60
+- + cd->trk[C(i+1)].toc.cdte_addr.msf.second
+- - cd->trk[C(i)].toc.cdte_addr.msf.minute * 60
+- - cd->trk[C(i)].toc.cdte_addr.msf.second;
++ delsecs = cd->trk[C(i+1)].length
++ - cd->trk[C(i)].length;
+
+ cd->trk[C(i)].tot_min = delsecs / 60;
+ cd->trk[C(i)].tot_sec = delsecs - (delsecs/60)*60;
+@@ -207,7 +256,7 @@
+
+ cd->isplayable=TRUE;
+ debug("cdrom.c: tcd_readtoc exiting normally\n" );
+- return tmp;
++ return 0;
+ }
+
+ void tcd_recalculate(cd_struct *cd)
+@@ -215,9 +264,8 @@
+ int result;
+
+ /* calculate various timing values */
+- cd->cur_pos_abs = cd->sc.cdsc_absaddr.msf.minute * 60 +
+- cd->sc.cdsc_absaddr.msf.second;
+- cd->cur_frame = cd->cur_pos_abs * 75 + cd->sc.cdsc_absaddr.msf.frame;
++ cd->cur_pos_abs = SC_MINUTE(cd->sc) * 60 + SC_SECOND(cd->sc);
++ cd->cur_frame = cd->cur_pos_abs * 75 + SC_FRAME(cd->sc);
+
+ cd->cur_pos_rel = (cd->cur_frame - cd->trk[C(cd->cur_t)].start) / 75;
+
+@@ -235,42 +283,83 @@
+ cd->cd_sec = cd->cur_pos_abs % 60;
+ cd->cd_min = cd->cur_pos_abs / 60;
+
+-#ifdef TCD_CHANGER_ENABLED
++#if defined(TCD_CHANGER_ENABLED) & !defined(TCD_BSD)
+ cd->cur_disc = ioctl( cd->cd_dev, CDROM_SELECT_DISC, CDSL_CURRENT );
+ #endif
+ }
+
+ void tcd_gettime( cd_struct *cd )
+ {
++#ifdef TCD_BSD
++ struct ioc_read_subchannel subch;
++#endif
++
+ cd->err = FALSE;
++#ifdef TCD_BSD
++ subch.address_format = CD_MSF_FORMAT;
++ subch.data_format = CD_CURRENT_POSITION;
++ subch.data_len = sizeof(cd->sc);
++ subch.data = &(cd->sc);
++#else
+ cd->sc.cdsc_format = CDROM_MSF;
++#endif
+
+ if(cd->isplayable)
+ {
++#ifdef TCD_BSD
++ if(ioctl( cd->cd_dev, CDIOCREADSUBCHANNEL, &subch))
++#else
+ if(ioctl( cd->cd_dev, CDROMSUBCHNL, &cd->sc))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_gettime exiting early. CDROMSUBCHNL ioctl error.\n" );
+ cd->cur_t = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return;
+ }
+- if(cd->sc.cdsc_audiostatus==CDROM_AUDIO_PLAY)
+- cd->cur_t = cd->sc.cdsc_trk;
++ if( SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PLAY )
++ {
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
++ cd->cur_t = SC_TRACK(cd->sc);
++ }
+ else
+- cd->cur_t = 0;
++ {
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++ cd->cur_t = 0;
++ }
+ tcd_recalculate(cd);
+ }
+ }
+
+ int tcd_set_volume(cd_struct *cd, int volume)
+ {
++#ifdef TCD_BSD
++ struct ioc_vol vol;
++#else
+ struct cdrom_volctrl vol;
++#endif
+
++#ifdef TCD_BSD
++ vol.vol[0] = volume;
++ vol.vol[1] = vol.vol[2] = vol.vol[3] = vol.vol[0];
++#else
+ vol.channel0 = volume;
+ vol.channel1 = vol.channel2 = vol.channel3 = vol.channel0;
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCSETVOL, &vol) < 0)
++#else
+ if(ioctl(cd->cd_dev, CDROMVOLCTRL, &vol) < 0)
++#endif
+ return FALSE;
+
+ return TRUE;
+@@ -278,6 +367,14 @@
+
+ int tcd_get_volume(cd_struct *cd)
+ {
++#ifdef TCD_BSD
++ struct ioc_vol vol;
++
++ if(ioctl(cd->cd_dev, CDIOCGETVOL, &vol) < 0)
++ return -1;
++
++ return vol.vol[0];
++#else
+ #ifdef CDROMVOLREAD
+ struct cdrom_volctrl vol;
+
+@@ -287,13 +384,40 @@
+ return vol.channel0;
+ #else
+ return 0;
++#endif
+ #endif
+ }
+
+ int tcd_playtracks(cd_struct *cd, int start_t, int end_t, int only_use_trkind)
+ {
++#ifdef TCD_BSD
++ struct ioc_play_msf msf;
++#define MSF_START_MIN (msf.start_m)
++#define MSF_START_SEC (msf.start_s)
++#define MSF_START_FRM (msf.start_f)
++#define MSF_END_MIN (msf.end_m)
++#define MSF_END_SEC (msf.end_s)
++#define MSF_END_FRM (msf.end_f)
++ struct ioc_play_track trkind;
++#define TI_START_TRK (trkind.start_track)
++#define TI_START_IND (trkind.start_index)
++#define TI_END_TRK (trkind.end_track)
++#define TI_END_IND (trkind.end_index)
++#else
+ struct cdrom_msf msf;
++#define MSF_START_MIN (msf.cdmsf_min0)
++#define MSF_START_SEC (msf.cdmsf_sec0)
++#define MSF_START_FRM (msf.cdmsf_frame0)
++#define MSF_END_MIN (msf.cdmsf_min1)
++#define MSF_END_SEC (msf.cdmsf_sec1)
++#define MSF_END_FRM (msf.cdmsf_frame0)
+ struct cdrom_ti trkind;
++#define TI_START_TRK (trkind.cdti_trk0)
++#define TI_START_IND (trkind.cdti_ind0)
++#define TI_END_TRK (trkind.cdti_trk1)
++#define TI_END_IND (trkind.cdti_ind1)
++#endif
++
+ int tmp;
+ debug("cdrom.c: tcd_playtracks( %p, %d, %d )\n", cd, start_t, end_t );
+ cd->err = FALSE;
+@@ -302,7 +426,7 @@
+ tcd_gettime(cd);
+ if(cd->err)
+ {
+- /* try and inject cd */
++ /* try and eject cd */
+ tcd_ejectcd(cd);
+
+ if(cd->err)
+@@ -312,64 +436,88 @@
+ }
+ }
+
++#ifdef TCD_BSD
++ ioctl(cd->cd_dev, CDIOCCLOSE);
++#else
+ #if defined(CDROMCLOSETRAY)
+ ioctl(cd->cd_dev, CDROMCLOSETRAY);
+-#endif
+-
+- if(cd->trk[start_t].toc.cdte_ctrl == CDROM_DATA_TRACK)
+- start_t++; /* bad hack. most data tracks are the first track... */
++#endif
++#endif
+
+- msf.cdmsf_min0 = cd->trk[start_t].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec0 = cd->trk[start_t].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame0 = cd->trk[start_t].toc.cdte_addr.msf.frame;
++ /* bad hack. most data tracks are the first track... */
++#ifdef TCD_BSD
++ if(cd->trk[start_t].toc.control == 0x04)
++#else
++ if(cd->trk[start_t].toc.cdte_ctrl == CDROM_DATA_TRACK)
++#endif
++ start_t++;
++
++ MSF_START_MIN = TOC_MINUTE(cd->trk[start_t]);
++ MSF_START_SEC = TOC_SECOND(cd->trk[start_t]);
++ MSF_START_FRM = TOC_FRAME(cd->trk[start_t]);
+
+ if( end_t < 0 )
+ {
+- msf.cdmsf_min1 = cd->trk[start_t].tot_min+msf.cdmsf_min0;
+- msf.cdmsf_sec1 = cd->trk[start_t].tot_sec+msf.cdmsf_sec0;
+- msf.cdmsf_frame1=0;
++ MSF_END_MIN = cd->trk[start_t].tot_min+MSF_START_MIN;
++ MSF_END_SEC = cd->trk[start_t].tot_sec+MSF_START_SEC;
++ MSF_END_FRM = 0;
+ }
+ else
+ {
+- msf.cdmsf_min1 = cd->trk[end_t+1].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec1 = cd->trk[end_t+1].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame1 = cd->trk[end_t+1].toc.cdte_addr.msf.frame - 1;
++ MSF_END_MIN = TOC_MINUTE(cd->trk[end_t+1]);
++ MSF_END_SEC = TOC_SECOND(cd->trk[end_t+1]);
++ MSF_END_FRM = TOC_FRAME(cd->trk[end_t+1]) - 1;
+
+ #ifdef UNSIGNED_NUMBERS_CAN_BE_NEGATIVE
+- if(msf.cdmsf_frame1 < 0)
++ if(MSF_END_FRM < 0)
+ {
+- msf.cdmsf_sec1 += msf.cdmsf_frame1;
+- msf.cdmsf_frame1 = 0;
++ MSF_END_SEC += MSF_END_FRM;
++ MSF_END_FRM = 0;
+ }
+- if(msf.cdmsf_sec1 < 0)
++ if(MSF_END_SEC < 0)
+ {
+- msf.cdmsf_min1 += msf.cdmsf_sec1;
+- msf.cdmsf_sec1 = 0;
++ MSF_END_MIN += MSF_END_SEC;
++ MSF_END_SEC = 0;
+ }
+- if(msf.cdmsf_min1 < 0)
++ if(MSF_END_MIN < 0)
+ {
+- msf.cdmsf_min1 = 0;
++ MSF_END_MIN = 0;
+ }
+ #endif
+ }
+- msf.cdmsf_min1 += (msf.cdmsf_sec1 / 60);
+- msf.cdmsf_sec1 %= 60;
++ MSF_END_MIN += (MSF_END_SEC / 60);
++ MSF_END_SEC %= 60;
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
++
++#ifdef TCD_BSD
++ if(only_use_trkind || ioctl( cd->cd_dev, CDIOCPLAYMSF, &msf))
++#else
+ if(ioctl( cd->cd_dev, CDROMPLAYMSF, &msf) || only_use_trkind)
++#endif
+ {
+ debug("cdrom.c: tcd_playtracks error. CDROMPLAYMSF ioctl error (or user override). Trying PLAYTRKIND\n" );
+
+ /* Try alternate method of playing */
+- trkind.cdti_trk0 = start_t; /* start track */
+- trkind.cdti_ind0 = 0; /* start index */
+- trkind.cdti_trk1 = end_t; /* end track */
+- trkind.cdti_ind1 = 0; /* end index */
++ TI_START_TRK = start_t; /* start track */
++ TI_START_IND = 0; /* start index */
++ TI_END_TRK = end_t; /* end track */
++ TI_END_IND = 0; /* end index */
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCPLAYTRACKS, &trkind))
++#else
+ if(ioctl(cd->cd_dev, CDROMPLAYTRKIND, &trkind))
++#endif
+ {
+ strcpy( cd->errmsg, "Error playing disc" );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_playtracks error. CDROMPLAYTRKIND ioctl error.\n");
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return -1;
+ }
+ }
+@@ -381,7 +529,11 @@
+
+ int tcd_play_seconds( cd_struct *cd, long int offset )
+ {
++#ifdef TCD_BSD
++ struct ioc_play_msf msf;
++#else
+ struct cdrom_msf msf;
++#endif
+ int tmp;
+
+ debug("cdrom.c: tcd_playseconds( %p, %ld )\n", cd, offset );
+@@ -390,42 +542,53 @@
+ cd->isplayable=FALSE;
+
+ /* got subchannel? */
+- msf.cdmsf_sec0 = cd->sc.cdsc_absaddr.msf.second+offset;
+- msf.cdmsf_min0 = cd->sc.cdsc_absaddr.msf.minute;
+- msf.cdmsf_frame0 = cd->sc.cdsc_absaddr.msf.frame;
+- msf.cdmsf_min1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.frame - 1;
++ MSF_START_SEC = SC_SECOND(cd->sc)+offset;
++ MSF_START_MIN = SC_MINUTE(cd->sc);
++ MSF_START_FRM = SC_FRAME(cd->sc);
++ MSF_END_MIN = TOC_MINUTE(cd->trk[C(cd->last_t+1)]);
++ MSF_END_SEC = TOC_SECOND(cd->trk[C(cd->last_t+1)]);
++ MSF_END_FRM = TOC_FRAME(cd->trk[C(cd->last_t+1)]) - 1;
+
+ #ifdef UNSIGNED_NUMBERS_CAN_BE_NEGATIVE
+- if(msf.cdmsf_frame1 < 0)
++ if(MSF_END_FRM < 0)
+ {
+- msf.cdmsf_sec1 += msf.cdmsf_frame1;
+- msf.cdmsf_frame1 = 0;
++ MSF_END_SEC += MSF_END_FRM;
++ MSF_END_FRM = 0;
+ }
+- if(msf.cdmsf_sec1 < 0)
++ if(MSF_END_SEC < 0)
+ {
+- msf.cdmsf_min1 += msf.cdmsf_sec1;
+- msf.cdmsf_sec1 = 0;
++ MSF_END_MIN += MSF_END_SEC;
++ MSF_END_SEC = 0;
+ }
+- if(msf.cdmsf_min1 < 0)
++ if(MSF_END_MIN < 0)
+ {
+- msf.cdmsf_min1 = 0;
++ MSF_END_MIN = 0;
+ }
+ #endif
+
+- if( msf.cdmsf_sec0 > 60 && (offset<0) )
++ if( MSF_START_SEC > 60 && (offset<0) )
+ {
+- msf.cdmsf_sec0 = 60-abs(offset);
+- msf.cdmsf_min0--;
++ MSF_START_SEC = 60-abs(offset);
++ MSF_START_MIN--;
+ }
++
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCPLAYMSF, &msf))
++#else
+ if(ioctl(cd->cd_dev, CDROMPLAYMSF, &msf))
++#endif
+ {
+ strcpy( cd->errmsg, "Error playing disc." );
+ cd->err = TRUE;
+
+ debug("cdrom.c: tcd_play_seconds error. CDROMPLAYMSF ioctl error.\n" );
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+ cd->isplayable=TRUE;
+@@ -442,7 +605,15 @@
+ if(cd->isplayable) tcd_stopcd(cd);
+ cd->err = FALSE;
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++
++#ifdef TCD_BSD
++ if(!ioctl(cd->cd_dev, CDIOCEJECT))
++#else
+ if(!ioctl(cd->cd_dev, CDROMEJECT))
++#endif
+ {
+ cd->isplayable = FALSE;
+ strcpy(cd->errmsg, "No disc in drive ");
+@@ -450,9 +621,17 @@
+ }
+ else
+ {
++#ifdef TCD_BSD
++ tmp = ioctl( cd->cd_dev, CDIOCCLOSE );
++#else
+ #ifdef CDROMCLOSETRAY
+ tmp = ioctl( cd->cd_dev, CDROMCLOSETRAY );
+ #endif
++#endif
++
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+
+ if(tcd_post_init(cd))
+ {
+@@ -461,6 +640,9 @@
+
+ debug("cdrom.c: tcd_eject - disc init error. %s\n",
+ strerror(errno) );
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+
+ return(-1);
+ }
+@@ -479,11 +661,19 @@
+ debug("cdrom.c: tcd_stopcd(%p)\n", cd );
+
+ /* SDH: Makes things cleaner on eject */
+- if( cd->sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PAUSED )
+ tcd_pausecd(cd);
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++
+ cd->err = FALSE;
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCSTOP))
++#else
+ if(ioctl(cd->cd_dev, CDROMSTOP))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't stop disc." );
+ cd->err = TRUE;
+@@ -501,31 +691,51 @@
+ int tmp;
+ cd->err = FALSE;
+
+- if(cd->sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED)
++ if(SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PAUSED)
+ {
++#ifdef TCD_BSD
++ if((tmp=ioctl(cd->cd_dev, CDIOCRESUME)))
++#else
+ if((tmp=ioctl(cd->cd_dev, CDROMRESUME)))
++#endif
+ {
+ strcpy(cd->errmsg, strerror(errno));
+ cd->err = TRUE;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+ return tmp;
+ }
+ else
+ {
++#ifdef TCD_BSD
++ if((tmp=ioctl(cd->cd_dev, CDIOCPAUSE)))
++#else
+ if((tmp=ioctl(cd->cd_dev, CDROMPAUSE)))
++#endif
+ {
+ strcpy( cd->errmsg, strerror( errno ) );
+ cd->err = TRUE;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+ return tmp;
+ }
+ }
+
+ int tcd_change_disc( cd_struct *cd, int disc )
+ {
+-#ifdef TCD_CHANGER_ENABLED
++#if defined(TCD_CHANGER_ENABLED) && !defined(TCD_BSD)
+ int tmp;
+ cd->err = FALSE;
+
+--- tcd/linux-cdrom.h.orig Thu Feb 11 18:49:43 1999
++++ tcd/linux-cdrom.h Wed Mar 3 10:57:00 1999
+@@ -27,11 +27,26 @@
+
+ #include <sys/types.h>
+
+-#if !defined(linux) && !defined(sun) && !defined(__sun__)
+-#error TCD only builds on linux and Solaris/SunOs
+-#endif
++#if defined(__FreeBSD__)
++
++#define TCD_BSD
++
++#include <sys/cdio.h>
+
+-#ifdef linux
++#define CDROM_AUDIO_INVALID CD_AS_AUDIO_INVALID
++#define CDROM_AUDIO_PLAY CD_AS_PLAY_IN_PROGRESS
++#define CDROM_AUDIO_PAUSED CD_AS_PLAY_PAUSED
++#define CDROM_AUDIO_COMPLETED CD_AS_PLAY_COMPLETED
++#define CDROM_AUDIO_ERROR CD_AS_PLAY_ERROR
++#define CDROM_AUDIO_NO_STATUS CD_AS_NO_STATUS
++
++#define CDROM
++
++#else
++
++#define TCD_LINUX
++
++#if defined(linux)
+ #include <linux/cdrom.h>
+ #endif
+
+@@ -98,6 +113,7 @@
+
+ #endif /* SVR4 */
+ #endif /* sun __sun__ */
++#endif /* __FreeBSD__ */
+
+ #define TRK_NAME_LEN 512
+ #define DISC_INFO_LEN 512
+@@ -106,7 +122,17 @@
+ struct cd_track
+ {
+ char name[TRK_NAME_LEN+1];
++#ifdef TCD_BSD
++ struct cd_toc_entry toc;
++#define TOC_MINUTE(trk) (trk.toc.addr.msf.minute)
++#define TOC_SECOND(trk) (trk.toc.addr.msf.second)
++#define TOC_FRAME(trk) (trk.toc.addr.msf.frame)
++#else
+ struct cdrom_tocentry toc;
++#define TOC_MINUTE(trk) (trk.toc.cdte_addr.msf.minute)
++#define TOC_SECOND(trk) (trk.toc.cdte_addr.msf.second)
++#define TOC_FRAME(trk) (trk.toc.cdte_addr.msf.frame)
++#endif
+ int titled;
+ int start, length;
+ int tot_min, tot_sec;
+@@ -130,10 +156,27 @@
+ char dtitle[DISC_INFO_LEN+1]; /* Disc title */
+ char album[DISC_INFO_LEN+1], artist[DISC_INFO_LEN+1];
+
++#ifdef TCD_BSD
++ /* See /usr/include/sys/cdio.h */
++ struct ioc_play_track ti;
++ struct ioc_toc_header tochdr;
++ struct cd_sub_channel_info sc;
++#define SC_AUDIOSTATUS(sc) (sc.header.audio_status)
++#define SC_TRACK(sc) (sc.what.position.track_number)
++#define SC_MINUTE(sc) (sc.what.position.absaddr.msf.minute)
++#define SC_SECOND(sc) (sc.what.position.absaddr.msf.second)
++#define SC_FRAME(sc) (sc.what.position.absaddr.msf.frame)
++#else
+ /* See /usr/src/linux/include/linux/cdrom.h */
+ struct cdrom_ti ti; /* Track info */
+ struct cdrom_tochdr tochdr; /* TOC header */
+ struct cdrom_subchnl sc; /* Subchannel, for time */
++#define SC_AUDIOSTATUS(sc) (sc.cdsc_audiostatus)
++#define SC_TRACK(sc) (sc.cdsc_trk)
++#define SC_MINUTE(sc) (sc.cdsc_absaddr.msf.minute)
++#define SC_SECOND(sc) (sc.cdsc_absaddr.msf.second)
++#define SC_FRAME(sc) (sc.cdsc_absaddr.msf.frame)
++#endif
+ int volume; /* Must range 0-100 */
+
+ int cd_min, cd_sec; /* Total CD time */
+--- tcd/tcd.c.orig Mon Feb 8 21:13:22 1999
++++ tcd/tcd.c Wed Mar 3 10:57:00 1999
+@@ -139,8 +139,8 @@
+
+ /* if the user hasn't stopped the cd, but it is
+ stopped anyway, fix it. */
+- if( cd->sc.cdsc_audiostatus != CDROM_AUDIO_PLAY &&
+- cd->sc.cdsc_audiostatus != CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd->sc) != CDROM_AUDIO_PLAY &&
++ SC_AUDIOSTATUS(cd->sc) != CDROM_AUDIO_PAUSED )
+ {
+ if( cd->play_method == REPEAT_CD )
+ tcd_playtracks(cd, cd->first_t, cd->last_t, 0);
diff --git a/audio/gnome-media/pkg-comment b/audio/gnome-media/pkg-comment
new file mode 100644
index 000000000000..d1ada7705ba3
--- /dev/null
+++ b/audio/gnome-media/pkg-comment
@@ -0,0 +1 @@
+Multimedia applications for the GNOME desktop.
diff --git a/audio/gnome-media/pkg-descr b/audio/gnome-media/pkg-descr
new file mode 100644
index 000000000000..3d3117e6a73a
--- /dev/null
+++ b/audio/gnome-media/pkg-descr
@@ -0,0 +1,3 @@
+Multimedia applications for the GNOME desktop. Includes gtcd, a CDDB
+aware CD player; GMix, for controlling the sound card's mixer; and
+VU-Meter, to slow down your desktop...
diff --git a/audio/gnome-media/pkg-plist b/audio/gnome-media/pkg-plist
new file mode 100644
index 000000000000..eb694b4d1e42
--- /dev/null
+++ b/audio/gnome-media/pkg-plist
@@ -0,0 +1,32 @@
+bin/cddbslave
+bin/gmix
+bin/gtcd
+bin/vumeter
+share/gnome/apps/Multimedia/gmix.desktop
+share/gnome/apps/Multimedia/gtcd.desktop
+share/gnome/apps/Multimedia/vumeter.desktop
+share/gnome/pixmaps/tcd/cdrom.xpm
+share/gnome/pixmaps/tcd/eject.xpm
+share/gnome/pixmaps/tcd/ff.xpm
+share/gnome/pixmaps/tcd/goto.xpm
+share/gnome/pixmaps/tcd/next_t.xpm
+share/gnome/pixmaps/tcd/pause.xpm
+share/gnome/pixmaps/tcd/play.xpm
+share/gnome/pixmaps/tcd/prev_t.xpm
+share/gnome/pixmaps/tcd/rw.xpm
+share/gnome/pixmaps/tcd/stop.xpm
+share/locale/da/LC_MESSAGES/gnome-media.mo
+share/locale/de/LC_MESSAGES/gnome-media.mo
+share/locale/es/LC_MESSAGES/gnome-media.mo
+share/locale/fi/LC_MESSAGES/gnome-media.mo
+share/locale/fr/LC_MESSAGES/gnome-media.mo
+share/locale/ga/LC_MESSAGES/gnome-media.mo
+share/locale/hu/LC_MESSAGES/gnome-media.mo
+share/locale/it/LC_MESSAGES/gnome-media.mo
+share/locale/ja/LC_MESSAGES/gnome-media.mo
+share/locale/ko/LC_MESSAGES/gnome-media.mo
+share/locale/nl/LC_MESSAGES/gnome-media.mo
+share/locale/no/LC_MESSAGES/gnome-media.mo
+share/locale/pt/LC_MESSAGES/gnome-media.mo
+share/locale/ru_RU/LC_MESSAGES/gnome-media.mo
+@dirrm share/gnome/pixmaps/tcd/
diff --git a/audio/gnomemedia/Makefile b/audio/gnomemedia/Makefile
new file mode 100644
index 000000000000..8a17ad7c6c90
--- /dev/null
+++ b/audio/gnomemedia/Makefile
@@ -0,0 +1,36 @@
+# New ports collection makefile for: gnome-media
+# Version required: 1.0.1
+# Date created: 20 January 1999
+# Whom: Jeremy Lea <reg@shale.csir.co.za>
+#
+# $Id: $
+#
+
+DISTNAME= gnome-media-1.0.1
+PKGNAME= gnomemedia-1.0.1
+CATEGORIES= audio gnome
+MASTER_SITES= ${MASTER_SITE_GNOME}
+MASTER_SITE_SUBDIR= gnome-1.0/sources
+
+MAINTAINER= reg@shale.csir.co.za
+
+BUILD_DEPENDS= panel:${PORTSDIR}/x11/gnomecore
+RUN_DEPENDS= panel:${PORTSDIR}/x11/gnomecore
+
+# implicit dependencies:
+# gettext, esound, gnomelibs
+
+USE_X_PREFIX= yes
+USE_GMAKE= yes
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --without-ncurses \
+ --localstatedir=${PREFIX}/share/gnome \
+ --datadir=${PREFIX}/share/gnome \
+ --with-gnome=${X11BASE}
+CONFIGURE_ENV= CPPFLAGS="-I${LOCALBASE}/include" \
+ LIBS="-L${LOCALBASE}/lib"
+
+post-install:
+ @${SETENV} OBJFORMAT=${PORTOBJFORMAT} ${LDCONFIG} -m ${PREFIX}/lib
+
+.include <bsd.port.mk>
diff --git a/audio/gnomemedia/distinfo b/audio/gnomemedia/distinfo
new file mode 100644
index 000000000000..6beda9aad6f4
--- /dev/null
+++ b/audio/gnomemedia/distinfo
@@ -0,0 +1 @@
+MD5 (gnome-media-1.0.1.tar.gz) = 34c5fa120431aa3ff07b087cbc7cdcdf
diff --git a/audio/gnomemedia/files/patch-ac b/audio/gnomemedia/files/patch-ac
new file mode 100644
index 000000000000..7c6e1965bf81
--- /dev/null
+++ b/audio/gnomemedia/files/patch-ac
@@ -0,0 +1,50 @@
+--- vu-meter/Makefile.in.orig Wed Mar 3 12:35:57 1999
++++ vu-meter/Makefile.in Wed Mar 3 12:36:25 1999
+@@ -116,9 +116,9 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+-INCLUDES = -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(GNOME_INCLUDEDIR)
++INCLUDES = -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(GNOME_INCLUDEDIR)
+
+
+ bin_PROGRAMS = vumeter
+--- gmix/Makefile.in.orig Sat Feb 27 09:22:00 1999
++++ gmix/Makefile.in Wed Mar 3 12:37:46 1999
+@@ -116,11 +116,11 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+ EXTRA_DIST = README TODO NEWS gmix.desktop
+
+-INCLUDES = -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(GNOME_INCLUDEDIR)
++INCLUDES = -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(GNOME_INCLUDEDIR)
+
+
+ bin_PROGRAMS = gmix
+--- tcd/Makefile.in.orig Sat Feb 27 09:22:02 1999
++++ tcd/Makefile.in Wed Mar 3 12:38:28 1999
+@@ -116,7 +116,7 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+ EXTRA_DIST = README TODO NEWS gtcd.desktop
+
+@@ -141,7 +141,7 @@
+
+ CLEANFILES = *~
+
+-INCLUDES = -I$(includedir) $(GNOME_INCLUDEDIR) $(CURSES_INCLUDEDIR) -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(USE_CD_CHANGER) -g
++INCLUDES = -I$(includedir) $(GNOME_INCLUDEDIR) $(CURSES_INCLUDEDIR) -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(USE_CD_CHANGER) -g
+
+
+ Audio_DATA = gtcd.desktop
diff --git a/audio/gnomemedia/files/patch-ad b/audio/gnomemedia/files/patch-ad
new file mode 100644
index 000000000000..6a817788707f
--- /dev/null
+++ b/audio/gnomemedia/files/patch-ad
@@ -0,0 +1,73 @@
+--- gmix/gmix.c.orig Fri Feb 19 18:30:49 1999
++++ gmix/gmix.c Wed Mar 3 10:49:51 1999
+@@ -94,6 +94,17 @@
+ /*
+ * All, that is known about a mixer-device
+ */
++
++#if !defined(OPEN_SOUND_SYSTEM)
++typedef struct mixer_info
++{
++ char id[16];
++ char name[32];
++ int modify_counter;
++ int fillers[10];
++} mixer_info;
++#endif
++
+ typedef struct device_info {
+ int fd;
+ mixer_info info;
+@@ -272,11 +283,7 @@
+ /*
+ * open the mixer-device
+ */
+- if (num==0) {
+- sprintf(device_name, "/dev/mixer");
+- } else {
+- sprintf(device_name, "/dev/mixer%i", num);
+- }
++ sprintf(device_name, "/dev/mixer%i", num);
+ new_device->fd=open(device_name, O_RDWR, 0);
+ if (new_device->fd<0) {
+ free(new_device);
+@@ -291,6 +298,8 @@
+ fprintf(stderr, "Warning: This version of gmix was compiled with a different version of\nsoundcard.h.\n");
+ }
+ #endif
++
++#if defined(OPEN_SOUND_SYSTEM)
+ /*
+ * mixer-name
+ */
+@@ -301,6 +310,11 @@
+ }
+ if(!isalpha(new_device->info.name[0]))
+ g_snprintf(new_device->info.name, 31, "Card %d", num+1);
++#else
++ g_snprintf(new_device->info.id, 15, "mixer%d", num);
++ g_snprintf(new_device->info.name, 31, "Sound Card %d", num+1);
++ new_device->info.modify_counter=0;
++#endif
+ /*
+ * several bitmasks describing the mixer
+ */
+@@ -386,15 +400,15 @@
+ {
+ int cnt;
+ device_info *new_device;
+- cnt=0; devices=NULL;
++ cnt=0; num_mixers=0; devices=NULL;
+ do {
+ new_device=open_device(cnt++);
+ if (new_device) {
+ new_device->channels=make_channels(new_device);
+ devices=g_list_append(devices, new_device);
++ num_mixers++;
+ }
+- } while (new_device);
+- num_mixers=cnt-1;
++ } while ((errno == EACCES) || (errno == EINVAL) || new_device);
+ }
+
+ void free_one_device(gpointer a, gpointer b)
diff --git a/audio/gnomemedia/files/patch-ae b/audio/gnomemedia/files/patch-ae
new file mode 100644
index 000000000000..6dd5f1c41e5f
--- /dev/null
+++ b/audio/gnomemedia/files/patch-ae
@@ -0,0 +1,881 @@
+--- tcd/callbacks.c.orig Sun Feb 21 20:32:04 1999
++++ tcd/callbacks.c Wed Mar 3 10:57:00 1999
+@@ -10,7 +10,7 @@
+
+ void play_cb(GtkWidget *widget, gpointer data)
+ {
+- if(cd.sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED)
++ if(SC_AUDIOSTATUS(cd.sc)==CDROM_AUDIO_PAUSED)
+ tcd_pausecd(&cd);
+ else
+ tcd_playtracks(&cd, cd.first_t, cd.last_t, prefs.only_use_trkind);
+@@ -42,7 +42,7 @@
+ cd.play_method = NORMAL;
+ cd.repeat_track = -1;
+ /* SDH: Make sure play/pause state change is noticed */
+- cd.sc.cdsc_audiostatus = -1;
++ SC_AUDIOSTATUS(cd.sc) = -1;
+ if(cd.isplayable)
+ {
+ make_goto_menu();
+--- tcd/cddb.c.orig Sat Feb 20 23:08:10 1999
++++ tcd/cddb.c Wed Mar 3 10:57:00 1999
+@@ -120,16 +120,16 @@
+ {
+ int min, sec;
+
+- min = cd->trk[i].toc.cdte_addr.msf.minute;
+- sec = cd->trk[i].toc.cdte_addr.msf.second;
++ min = TOC_MINUTE(cd->trk[i]);
++ sec = TOC_MINUTE(cd->trk[i]);
+
+ n = (min*60)+sec;
+- fprintf( fp, "# %u\n", (n*75)+cd->trk[i].toc.cdte_addr.msf.frame );
++ fprintf( fp, "# %u\n", (n*75)+TOC_FRAME(cd->trk[i]) );
+ }
+ /* Print the number of seconds */
+ fprintf( fp, "#\n# Disc length: %i seconds\n",
+- (cd->trk[cd->last_t+1].toc.cdte_addr.msf.minute*60)
+- +(cd->trk[cd->last_t+1].toc.cdte_addr.msf.second) );
++ (TOC_MINUTE(cd->trk[cd->last_t+1])*60)
++ +(TOC_SECOND(cd->trk[cd->last_t+1])) );
+
+ /* FIXME increment revision. sigh, lousy cddb */
+ fprintf( fp, "#\n# Revision: 0\n" );
+@@ -160,10 +160,10 @@
+ {
+ int min, sec;
+
+- min = cd->trk[i].toc.cdte_addr.msf.minute;
+- sec = cd->trk[i].toc.cdte_addr.msf.second;
++ min = TOC_MINUTE(cd->trk[i]);
++ sec = TOC_SECOND(cd->trk[i]);
+
+- l=sprintf( tmp, "%u ", calc_offset(min,sec,cd->trk[i].toc.cdte_addr.msf.frame));
++ l=sprintf( tmp, "%u ", calc_offset(min,sec,TOC_FRAME(cd->trk[i])));
+
+ if(blen>l)
+ {
+@@ -172,8 +172,8 @@
+ }
+ }
+ l=sprintf( tmp, "%i\n",
+- (cd->trk[cd->last_t+1].toc.cdte_addr.msf.minute*60)
+- +(cd->trk[cd->last_t+1].toc.cdte_addr.msf.second) );
++ (TOC_MINUTE(cd->trk[cd->last_t+1])*60)
++ +(TOC_SECOND(cd->trk[cd->last_t+1])) );
+ if(blen>l)
+ strcat( buf,tmp );
+
+@@ -203,9 +203,9 @@
+
+ for( i=0; i <= cd->last_t+1; i++ )
+ {
+- cdtoc[i].frame = cd->trk[i+1].toc.cdte_addr.msf.frame;
+- cdtoc[i].min = cd->trk[i+1].toc.cdte_addr.msf.minute;
+- cdtoc[i].sec = cd->trk[i+1].toc.cdte_addr.msf.second;
++ cdtoc[i].frame = TOC_FRAME(cd->trk[i+1]);
++ cdtoc[i].min = TOC_MINUTE(cd->trk[i+1]);
++ cdtoc[i].sec = TOC_SECOND(cd->trk[i+1]);
+ }
+
+
+--- tcd/gtcd.c.orig Wed Feb 24 02:48:49 1999
++++ tcd/gtcd.c Wed Mar 3 10:57:00 1999
+@@ -408,8 +408,8 @@
+ break;
+ case DISC_R:
+ cur = cd.cur_pos_abs;
+- end = (cd.trk[cd.last_t+1].toc.cdte_addr.msf.minute
+- *60)+cd.trk[cd.last_t+1].toc.cdte_addr.msf.second;
++ end = (TOC_MINUTE(cd.trk[cd.last_t+1])*60
++ +TOC_SECOND(cd.trk[cd.last_t+1]));
+ pos = end-cur;
+ min = pos/60;
+ sec = pos-(pos/60)*60;
+@@ -490,7 +490,7 @@
+
+ if( !cd.err )
+ {
+- switch( cd.sc.cdsc_audiostatus )
++ switch( SC_AUDIOSTATUS(cd.sc) )
+ {
+ case CDROM_AUDIO_INVALID:
+ strcpy(tmp, _("No Disc"));
+@@ -577,8 +577,8 @@
+ }
+
+ /* see if we need to repeat */
+- if( cd.sc.cdsc_audiostatus != CDROM_AUDIO_PLAY &&
+- cd.sc.cdsc_audiostatus != CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd.sc) != CDROM_AUDIO_PLAY &&
++ SC_AUDIOSTATUS(cd.sc) != CDROM_AUDIO_PAUSED )
+ {
+ if( cd.play_method == REPEAT_CD )
+ tcd_playtracks( &cd, cd.first_t, cd.last_t, prefs.only_use_trkind);
+@@ -593,14 +593,14 @@
+
+ void status_changed(void)
+ {
+- if(old_status != cd.sc.cdsc_audiostatus)
++ if(old_status != SC_AUDIOSTATUS(cd.sc))
+ {
+ GtkWidget *pixmap;
+ GtkSignalFunc func;
+ char tmp[256];
+ char *name;
+
+- old_status = cd.sc.cdsc_audiostatus;
++ old_status = SC_AUDIOSTATUS(cd.sc);
+ g_snprintf(tmp, 255, "tcd/%s.xpm",
+ (old_status==CDROM_AUDIO_PLAY)?"pause":"play");
+
+--- tcd/gtracked.c.orig Thu Feb 11 18:48:56 1999
++++ tcd/gtracked.c Wed Mar 3 10:57:00 1999
+@@ -166,8 +166,8 @@
+ /* Disc area */
+ disc_table = gtk_table_new(2, 2, FALSE);
+ g_snprintf(tmp, 63, _("Disc Information (%02u:%02u minutes)"),
+- cd.trk[cd.last_t+1].toc.cdte_addr.msf.minute,
+- cd.trk[cd.last_t+1].toc.cdte_addr.msf.second);
++ TOC_MINUTE(cd.trk[cd.last_t+1]),
++ TOC_SECOND(cd.trk[cd.last_t+1]));
+
+ disc_frame = gtk_frame_new(tmp);
+ label = gtk_label_new(_("Artist / Title"));
+--- tcd/linux-cdrom.c.orig Tue Feb 23 06:52:46 1999
++++ tcd/linux-cdrom.c Wed Mar 3 10:57:00 1999
+@@ -77,7 +77,7 @@
+ if(!homedir)
+ homedir = "/";
+
+-#if defined(TCD_CHANGER_ENABLED)
++#if defined(TCD_CHANGER_ENABLED) && !defined(TCD_BSD)
+ cd->nslots = ioctl( cd->cd_dev, CDROM_CHANGER_NSLOTS );
+ #else
+ cd->nslots = 0;
+@@ -120,34 +120,58 @@
+
+ int tcd_readtoc( cd_struct *cd )
+ {
+- int tmp,i;
++ int i;
+ int delsecs;
++#ifdef TCD_BSD
++ struct ioc_read_toc_single_entry tocentry;
++#endif
+
+ debug("cdrom.c: tcd_readtoc(%p) top\n", cd );
+ cd->err = FALSE;
+ cd->isplayable=FALSE;
+
+ /* read the TOC header */
++#ifdef TCD_BSD
++ if(ioctl( cd->cd_dev, CDIOREADTOCHEADER, &cd->tochdr))
++#else
+ if(ioctl( cd->cd_dev, CDROMREADTOCHDR, &cd->tochdr))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCHDR ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+
+ /* grab first & last tracks */
++#ifdef TCD_BSD
++ cd->first_t = cd->tochdr.starting_track;
++ cd->last_t = cd->tochdr.ending_track;
++#else
+ cd->first_t = cd->tochdr.cdth_trk0;
+ cd->last_t = cd->tochdr.cdth_trk1;
++#endif
+
+ /* read the leadout track */
++#ifdef TCD_BSD
++ tocentry.track = cd->last_t+1; /* Magic last track */
++ tocentry.address_format = CD_MSF_FORMAT;
++#else
+ cd->trk[C(cd->last_t+1)].toc.cdte_track = CDROM_LEADOUT;
+ cd->trk[C(cd->last_t+1)].toc.cdte_format = CDROM_MSF;
++#endif
+
+ /* read the leadout toc */
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOREADTOCENTRY, &tocentry))
++#else
+ if(ioctl(cd->cd_dev, CDROMREADTOCENTRY, &cd->trk[C(cd->last_t+1)].toc))
++#endif
+ {
+ strcpy(cd->errmsg, "Can't read disc.");
+ cd->err = TRUE;
+@@ -155,40 +179,65 @@
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCENTRY ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ cd->trk[C(cd->last_t+1)].toc = tocentry.entry;
++#endif
++ cd->trk[C(cd->last_t+1)].length = TOC_MINUTE(cd->trk[C(cd->last_t+1)]) * 60 +
++ TOC_SECOND(cd->trk[C(cd->last_t+1)]);
++ cd->trk[C(cd->last_t+1)].start = cd->trk[C(cd->last_t+1)].length * 75 +
++ TOC_FRAME(cd->trk[C(cd->last_t+1)]);
+
+ /* read the rest of the tocs */
+ for( i = cd->first_t; i <= cd->last_t; i++ )
+ {
++#ifdef TCD_BSD
++ tocentry.track = i;
++ tocentry.address_format = CD_MSF_FORMAT;
++#else
+ cd->trk[C(i)].toc.cdte_track = i;
+ cd->trk[C(i)].toc.cdte_format = CDROM_MSF;
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOREADTOCENTRY, &tocentry))
++#else
+ if(ioctl(cd->cd_dev, CDROMREADTOCENTRY, &cd->trk[C(i)].toc))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCENTRY ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+
++#ifdef TCD_BSD
++ cd->trk[C(i)].toc = tocentry.entry;
++ cd->trk[C(i)].type = cd->trk[C(i)].toc.control;
++#else
+ cd->trk[C(i)].type = cd->trk[C(i)].toc.cdte_ctrl;
+- cd->trk[C(i)].length = cd->trk[C(i)].toc.cdte_addr.msf.minute * 60 +
+- cd->trk[C(i)].toc.cdte_addr.msf.second;
++#endif
++ cd->trk[C(i)].length = TOC_MINUTE(cd->trk[C(i)]) * 60 +
++ TOC_SECOND(cd->trk[C(i)]);
+ cd->trk[C(i)].start = cd->trk[C(i)].length * 75 +
+- cd->trk[C(i)].toc.cdte_addr.msf.frame;
++ TOC_FRAME(cd->trk[C(i)]);
+ }
+
+ /* calculate track times */
+ for(i = cd->first_t; i <= cd->last_t; i ++)
+ {
+ /* Taken from cdtool...Thanks Thomas I.! */
+- delsecs = cd->trk[C(i+1)].toc.cdte_addr.msf.minute * 60
+- + cd->trk[C(i+1)].toc.cdte_addr.msf.second
+- - cd->trk[C(i)].toc.cdte_addr.msf.minute * 60
+- - cd->trk[C(i)].toc.cdte_addr.msf.second;
++ delsecs = cd->trk[C(i+1)].length
++ - cd->trk[C(i)].length;
+
+ cd->trk[C(i)].tot_min = delsecs / 60;
+ cd->trk[C(i)].tot_sec = delsecs - (delsecs/60)*60;
+@@ -207,7 +256,7 @@
+
+ cd->isplayable=TRUE;
+ debug("cdrom.c: tcd_readtoc exiting normally\n" );
+- return tmp;
++ return 0;
+ }
+
+ void tcd_recalculate(cd_struct *cd)
+@@ -215,9 +264,8 @@
+ int result;
+
+ /* calculate various timing values */
+- cd->cur_pos_abs = cd->sc.cdsc_absaddr.msf.minute * 60 +
+- cd->sc.cdsc_absaddr.msf.second;
+- cd->cur_frame = cd->cur_pos_abs * 75 + cd->sc.cdsc_absaddr.msf.frame;
++ cd->cur_pos_abs = SC_MINUTE(cd->sc) * 60 + SC_SECOND(cd->sc);
++ cd->cur_frame = cd->cur_pos_abs * 75 + SC_FRAME(cd->sc);
+
+ cd->cur_pos_rel = (cd->cur_frame - cd->trk[C(cd->cur_t)].start) / 75;
+
+@@ -235,42 +283,83 @@
+ cd->cd_sec = cd->cur_pos_abs % 60;
+ cd->cd_min = cd->cur_pos_abs / 60;
+
+-#ifdef TCD_CHANGER_ENABLED
++#if defined(TCD_CHANGER_ENABLED) & !defined(TCD_BSD)
+ cd->cur_disc = ioctl( cd->cd_dev, CDROM_SELECT_DISC, CDSL_CURRENT );
+ #endif
+ }
+
+ void tcd_gettime( cd_struct *cd )
+ {
++#ifdef TCD_BSD
++ struct ioc_read_subchannel subch;
++#endif
++
+ cd->err = FALSE;
++#ifdef TCD_BSD
++ subch.address_format = CD_MSF_FORMAT;
++ subch.data_format = CD_CURRENT_POSITION;
++ subch.data_len = sizeof(cd->sc);
++ subch.data = &(cd->sc);
++#else
+ cd->sc.cdsc_format = CDROM_MSF;
++#endif
+
+ if(cd->isplayable)
+ {
++#ifdef TCD_BSD
++ if(ioctl( cd->cd_dev, CDIOCREADSUBCHANNEL, &subch))
++#else
+ if(ioctl( cd->cd_dev, CDROMSUBCHNL, &cd->sc))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_gettime exiting early. CDROMSUBCHNL ioctl error.\n" );
+ cd->cur_t = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return;
+ }
+- if(cd->sc.cdsc_audiostatus==CDROM_AUDIO_PLAY)
+- cd->cur_t = cd->sc.cdsc_trk;
++ if( SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PLAY )
++ {
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
++ cd->cur_t = SC_TRACK(cd->sc);
++ }
+ else
+- cd->cur_t = 0;
++ {
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++ cd->cur_t = 0;
++ }
+ tcd_recalculate(cd);
+ }
+ }
+
+ int tcd_set_volume(cd_struct *cd, int volume)
+ {
++#ifdef TCD_BSD
++ struct ioc_vol vol;
++#else
+ struct cdrom_volctrl vol;
++#endif
+
++#ifdef TCD_BSD
++ vol.vol[0] = volume;
++ vol.vol[1] = vol.vol[2] = vol.vol[3] = vol.vol[0];
++#else
+ vol.channel0 = volume;
+ vol.channel1 = vol.channel2 = vol.channel3 = vol.channel0;
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCSETVOL, &vol) < 0)
++#else
+ if(ioctl(cd->cd_dev, CDROMVOLCTRL, &vol) < 0)
++#endif
+ return FALSE;
+
+ return TRUE;
+@@ -278,6 +367,14 @@
+
+ int tcd_get_volume(cd_struct *cd)
+ {
++#ifdef TCD_BSD
++ struct ioc_vol vol;
++
++ if(ioctl(cd->cd_dev, CDIOCGETVOL, &vol) < 0)
++ return -1;
++
++ return vol.vol[0];
++#else
+ #ifdef CDROMVOLREAD
+ struct cdrom_volctrl vol;
+
+@@ -287,13 +384,40 @@
+ return vol.channel0;
+ #else
+ return 0;
++#endif
+ #endif
+ }
+
+ int tcd_playtracks(cd_struct *cd, int start_t, int end_t, int only_use_trkind)
+ {
++#ifdef TCD_BSD
++ struct ioc_play_msf msf;
++#define MSF_START_MIN (msf.start_m)
++#define MSF_START_SEC (msf.start_s)
++#define MSF_START_FRM (msf.start_f)
++#define MSF_END_MIN (msf.end_m)
++#define MSF_END_SEC (msf.end_s)
++#define MSF_END_FRM (msf.end_f)
++ struct ioc_play_track trkind;
++#define TI_START_TRK (trkind.start_track)
++#define TI_START_IND (trkind.start_index)
++#define TI_END_TRK (trkind.end_track)
++#define TI_END_IND (trkind.end_index)
++#else
+ struct cdrom_msf msf;
++#define MSF_START_MIN (msf.cdmsf_min0)
++#define MSF_START_SEC (msf.cdmsf_sec0)
++#define MSF_START_FRM (msf.cdmsf_frame0)
++#define MSF_END_MIN (msf.cdmsf_min1)
++#define MSF_END_SEC (msf.cdmsf_sec1)
++#define MSF_END_FRM (msf.cdmsf_frame0)
+ struct cdrom_ti trkind;
++#define TI_START_TRK (trkind.cdti_trk0)
++#define TI_START_IND (trkind.cdti_ind0)
++#define TI_END_TRK (trkind.cdti_trk1)
++#define TI_END_IND (trkind.cdti_ind1)
++#endif
++
+ int tmp;
+ debug("cdrom.c: tcd_playtracks( %p, %d, %d )\n", cd, start_t, end_t );
+ cd->err = FALSE;
+@@ -302,7 +426,7 @@
+ tcd_gettime(cd);
+ if(cd->err)
+ {
+- /* try and inject cd */
++ /* try and eject cd */
+ tcd_ejectcd(cd);
+
+ if(cd->err)
+@@ -312,64 +436,88 @@
+ }
+ }
+
++#ifdef TCD_BSD
++ ioctl(cd->cd_dev, CDIOCCLOSE);
++#else
+ #if defined(CDROMCLOSETRAY)
+ ioctl(cd->cd_dev, CDROMCLOSETRAY);
+-#endif
+-
+- if(cd->trk[start_t].toc.cdte_ctrl == CDROM_DATA_TRACK)
+- start_t++; /* bad hack. most data tracks are the first track... */
++#endif
++#endif
+
+- msf.cdmsf_min0 = cd->trk[start_t].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec0 = cd->trk[start_t].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame0 = cd->trk[start_t].toc.cdte_addr.msf.frame;
++ /* bad hack. most data tracks are the first track... */
++#ifdef TCD_BSD
++ if(cd->trk[start_t].toc.control == 0x04)
++#else
++ if(cd->trk[start_t].toc.cdte_ctrl == CDROM_DATA_TRACK)
++#endif
++ start_t++;
++
++ MSF_START_MIN = TOC_MINUTE(cd->trk[start_t]);
++ MSF_START_SEC = TOC_SECOND(cd->trk[start_t]);
++ MSF_START_FRM = TOC_FRAME(cd->trk[start_t]);
+
+ if( end_t < 0 )
+ {
+- msf.cdmsf_min1 = cd->trk[start_t].tot_min+msf.cdmsf_min0;
+- msf.cdmsf_sec1 = cd->trk[start_t].tot_sec+msf.cdmsf_sec0;
+- msf.cdmsf_frame1=0;
++ MSF_END_MIN = cd->trk[start_t].tot_min+MSF_START_MIN;
++ MSF_END_SEC = cd->trk[start_t].tot_sec+MSF_START_SEC;
++ MSF_END_FRM = 0;
+ }
+ else
+ {
+- msf.cdmsf_min1 = cd->trk[end_t+1].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec1 = cd->trk[end_t+1].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame1 = cd->trk[end_t+1].toc.cdte_addr.msf.frame - 1;
++ MSF_END_MIN = TOC_MINUTE(cd->trk[end_t+1]);
++ MSF_END_SEC = TOC_SECOND(cd->trk[end_t+1]);
++ MSF_END_FRM = TOC_FRAME(cd->trk[end_t+1]) - 1;
+
+ #ifdef UNSIGNED_NUMBERS_CAN_BE_NEGATIVE
+- if(msf.cdmsf_frame1 < 0)
++ if(MSF_END_FRM < 0)
+ {
+- msf.cdmsf_sec1 += msf.cdmsf_frame1;
+- msf.cdmsf_frame1 = 0;
++ MSF_END_SEC += MSF_END_FRM;
++ MSF_END_FRM = 0;
+ }
+- if(msf.cdmsf_sec1 < 0)
++ if(MSF_END_SEC < 0)
+ {
+- msf.cdmsf_min1 += msf.cdmsf_sec1;
+- msf.cdmsf_sec1 = 0;
++ MSF_END_MIN += MSF_END_SEC;
++ MSF_END_SEC = 0;
+ }
+- if(msf.cdmsf_min1 < 0)
++ if(MSF_END_MIN < 0)
+ {
+- msf.cdmsf_min1 = 0;
++ MSF_END_MIN = 0;
+ }
+ #endif
+ }
+- msf.cdmsf_min1 += (msf.cdmsf_sec1 / 60);
+- msf.cdmsf_sec1 %= 60;
++ MSF_END_MIN += (MSF_END_SEC / 60);
++ MSF_END_SEC %= 60;
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
++
++#ifdef TCD_BSD
++ if(only_use_trkind || ioctl( cd->cd_dev, CDIOCPLAYMSF, &msf))
++#else
+ if(ioctl( cd->cd_dev, CDROMPLAYMSF, &msf) || only_use_trkind)
++#endif
+ {
+ debug("cdrom.c: tcd_playtracks error. CDROMPLAYMSF ioctl error (or user override). Trying PLAYTRKIND\n" );
+
+ /* Try alternate method of playing */
+- trkind.cdti_trk0 = start_t; /* start track */
+- trkind.cdti_ind0 = 0; /* start index */
+- trkind.cdti_trk1 = end_t; /* end track */
+- trkind.cdti_ind1 = 0; /* end index */
++ TI_START_TRK = start_t; /* start track */
++ TI_START_IND = 0; /* start index */
++ TI_END_TRK = end_t; /* end track */
++ TI_END_IND = 0; /* end index */
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCPLAYTRACKS, &trkind))
++#else
+ if(ioctl(cd->cd_dev, CDROMPLAYTRKIND, &trkind))
++#endif
+ {
+ strcpy( cd->errmsg, "Error playing disc" );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_playtracks error. CDROMPLAYTRKIND ioctl error.\n");
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return -1;
+ }
+ }
+@@ -381,7 +529,11 @@
+
+ int tcd_play_seconds( cd_struct *cd, long int offset )
+ {
++#ifdef TCD_BSD
++ struct ioc_play_msf msf;
++#else
+ struct cdrom_msf msf;
++#endif
+ int tmp;
+
+ debug("cdrom.c: tcd_playseconds( %p, %ld )\n", cd, offset );
+@@ -390,42 +542,53 @@
+ cd->isplayable=FALSE;
+
+ /* got subchannel? */
+- msf.cdmsf_sec0 = cd->sc.cdsc_absaddr.msf.second+offset;
+- msf.cdmsf_min0 = cd->sc.cdsc_absaddr.msf.minute;
+- msf.cdmsf_frame0 = cd->sc.cdsc_absaddr.msf.frame;
+- msf.cdmsf_min1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.frame - 1;
++ MSF_START_SEC = SC_SECOND(cd->sc)+offset;
++ MSF_START_MIN = SC_MINUTE(cd->sc);
++ MSF_START_FRM = SC_FRAME(cd->sc);
++ MSF_END_MIN = TOC_MINUTE(cd->trk[C(cd->last_t+1)]);
++ MSF_END_SEC = TOC_SECOND(cd->trk[C(cd->last_t+1)]);
++ MSF_END_FRM = TOC_FRAME(cd->trk[C(cd->last_t+1)]) - 1;
+
+ #ifdef UNSIGNED_NUMBERS_CAN_BE_NEGATIVE
+- if(msf.cdmsf_frame1 < 0)
++ if(MSF_END_FRM < 0)
+ {
+- msf.cdmsf_sec1 += msf.cdmsf_frame1;
+- msf.cdmsf_frame1 = 0;
++ MSF_END_SEC += MSF_END_FRM;
++ MSF_END_FRM = 0;
+ }
+- if(msf.cdmsf_sec1 < 0)
++ if(MSF_END_SEC < 0)
+ {
+- msf.cdmsf_min1 += msf.cdmsf_sec1;
+- msf.cdmsf_sec1 = 0;
++ MSF_END_MIN += MSF_END_SEC;
++ MSF_END_SEC = 0;
+ }
+- if(msf.cdmsf_min1 < 0)
++ if(MSF_END_MIN < 0)
+ {
+- msf.cdmsf_min1 = 0;
++ MSF_END_MIN = 0;
+ }
+ #endif
+
+- if( msf.cdmsf_sec0 > 60 && (offset<0) )
++ if( MSF_START_SEC > 60 && (offset<0) )
+ {
+- msf.cdmsf_sec0 = 60-abs(offset);
+- msf.cdmsf_min0--;
++ MSF_START_SEC = 60-abs(offset);
++ MSF_START_MIN--;
+ }
++
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCPLAYMSF, &msf))
++#else
+ if(ioctl(cd->cd_dev, CDROMPLAYMSF, &msf))
++#endif
+ {
+ strcpy( cd->errmsg, "Error playing disc." );
+ cd->err = TRUE;
+
+ debug("cdrom.c: tcd_play_seconds error. CDROMPLAYMSF ioctl error.\n" );
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+ cd->isplayable=TRUE;
+@@ -442,7 +605,15 @@
+ if(cd->isplayable) tcd_stopcd(cd);
+ cd->err = FALSE;
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++
++#ifdef TCD_BSD
++ if(!ioctl(cd->cd_dev, CDIOCEJECT))
++#else
+ if(!ioctl(cd->cd_dev, CDROMEJECT))
++#endif
+ {
+ cd->isplayable = FALSE;
+ strcpy(cd->errmsg, "No disc in drive ");
+@@ -450,9 +621,17 @@
+ }
+ else
+ {
++#ifdef TCD_BSD
++ tmp = ioctl( cd->cd_dev, CDIOCCLOSE );
++#else
+ #ifdef CDROMCLOSETRAY
+ tmp = ioctl( cd->cd_dev, CDROMCLOSETRAY );
+ #endif
++#endif
++
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+
+ if(tcd_post_init(cd))
+ {
+@@ -461,6 +640,9 @@
+
+ debug("cdrom.c: tcd_eject - disc init error. %s\n",
+ strerror(errno) );
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+
+ return(-1);
+ }
+@@ -479,11 +661,19 @@
+ debug("cdrom.c: tcd_stopcd(%p)\n", cd );
+
+ /* SDH: Makes things cleaner on eject */
+- if( cd->sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PAUSED )
+ tcd_pausecd(cd);
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++
+ cd->err = FALSE;
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCSTOP))
++#else
+ if(ioctl(cd->cd_dev, CDROMSTOP))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't stop disc." );
+ cd->err = TRUE;
+@@ -501,31 +691,51 @@
+ int tmp;
+ cd->err = FALSE;
+
+- if(cd->sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED)
++ if(SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PAUSED)
+ {
++#ifdef TCD_BSD
++ if((tmp=ioctl(cd->cd_dev, CDIOCRESUME)))
++#else
+ if((tmp=ioctl(cd->cd_dev, CDROMRESUME)))
++#endif
+ {
+ strcpy(cd->errmsg, strerror(errno));
+ cd->err = TRUE;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+ return tmp;
+ }
+ else
+ {
++#ifdef TCD_BSD
++ if((tmp=ioctl(cd->cd_dev, CDIOCPAUSE)))
++#else
+ if((tmp=ioctl(cd->cd_dev, CDROMPAUSE)))
++#endif
+ {
+ strcpy( cd->errmsg, strerror( errno ) );
+ cd->err = TRUE;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+ return tmp;
+ }
+ }
+
+ int tcd_change_disc( cd_struct *cd, int disc )
+ {
+-#ifdef TCD_CHANGER_ENABLED
++#if defined(TCD_CHANGER_ENABLED) && !defined(TCD_BSD)
+ int tmp;
+ cd->err = FALSE;
+
+--- tcd/linux-cdrom.h.orig Thu Feb 11 18:49:43 1999
++++ tcd/linux-cdrom.h Wed Mar 3 10:57:00 1999
+@@ -27,11 +27,26 @@
+
+ #include <sys/types.h>
+
+-#if !defined(linux) && !defined(sun) && !defined(__sun__)
+-#error TCD only builds on linux and Solaris/SunOs
+-#endif
++#if defined(__FreeBSD__)
++
++#define TCD_BSD
++
++#include <sys/cdio.h>
+
+-#ifdef linux
++#define CDROM_AUDIO_INVALID CD_AS_AUDIO_INVALID
++#define CDROM_AUDIO_PLAY CD_AS_PLAY_IN_PROGRESS
++#define CDROM_AUDIO_PAUSED CD_AS_PLAY_PAUSED
++#define CDROM_AUDIO_COMPLETED CD_AS_PLAY_COMPLETED
++#define CDROM_AUDIO_ERROR CD_AS_PLAY_ERROR
++#define CDROM_AUDIO_NO_STATUS CD_AS_NO_STATUS
++
++#define CDROM
++
++#else
++
++#define TCD_LINUX
++
++#if defined(linux)
+ #include <linux/cdrom.h>
+ #endif
+
+@@ -98,6 +113,7 @@
+
+ #endif /* SVR4 */
+ #endif /* sun __sun__ */
++#endif /* __FreeBSD__ */
+
+ #define TRK_NAME_LEN 512
+ #define DISC_INFO_LEN 512
+@@ -106,7 +122,17 @@
+ struct cd_track
+ {
+ char name[TRK_NAME_LEN+1];
++#ifdef TCD_BSD
++ struct cd_toc_entry toc;
++#define TOC_MINUTE(trk) (trk.toc.addr.msf.minute)
++#define TOC_SECOND(trk) (trk.toc.addr.msf.second)
++#define TOC_FRAME(trk) (trk.toc.addr.msf.frame)
++#else
+ struct cdrom_tocentry toc;
++#define TOC_MINUTE(trk) (trk.toc.cdte_addr.msf.minute)
++#define TOC_SECOND(trk) (trk.toc.cdte_addr.msf.second)
++#define TOC_FRAME(trk) (trk.toc.cdte_addr.msf.frame)
++#endif
+ int titled;
+ int start, length;
+ int tot_min, tot_sec;
+@@ -130,10 +156,27 @@
+ char dtitle[DISC_INFO_LEN+1]; /* Disc title */
+ char album[DISC_INFO_LEN+1], artist[DISC_INFO_LEN+1];
+
++#ifdef TCD_BSD
++ /* See /usr/include/sys/cdio.h */
++ struct ioc_play_track ti;
++ struct ioc_toc_header tochdr;
++ struct cd_sub_channel_info sc;
++#define SC_AUDIOSTATUS(sc) (sc.header.audio_status)
++#define SC_TRACK(sc) (sc.what.position.track_number)
++#define SC_MINUTE(sc) (sc.what.position.absaddr.msf.minute)
++#define SC_SECOND(sc) (sc.what.position.absaddr.msf.second)
++#define SC_FRAME(sc) (sc.what.position.absaddr.msf.frame)
++#else
+ /* See /usr/src/linux/include/linux/cdrom.h */
+ struct cdrom_ti ti; /* Track info */
+ struct cdrom_tochdr tochdr; /* TOC header */
+ struct cdrom_subchnl sc; /* Subchannel, for time */
++#define SC_AUDIOSTATUS(sc) (sc.cdsc_audiostatus)
++#define SC_TRACK(sc) (sc.cdsc_trk)
++#define SC_MINUTE(sc) (sc.cdsc_absaddr.msf.minute)
++#define SC_SECOND(sc) (sc.cdsc_absaddr.msf.second)
++#define SC_FRAME(sc) (sc.cdsc_absaddr.msf.frame)
++#endif
+ int volume; /* Must range 0-100 */
+
+ int cd_min, cd_sec; /* Total CD time */
+--- tcd/tcd.c.orig Mon Feb 8 21:13:22 1999
++++ tcd/tcd.c Wed Mar 3 10:57:00 1999
+@@ -139,8 +139,8 @@
+
+ /* if the user hasn't stopped the cd, but it is
+ stopped anyway, fix it. */
+- if( cd->sc.cdsc_audiostatus != CDROM_AUDIO_PLAY &&
+- cd->sc.cdsc_audiostatus != CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd->sc) != CDROM_AUDIO_PLAY &&
++ SC_AUDIOSTATUS(cd->sc) != CDROM_AUDIO_PAUSED )
+ {
+ if( cd->play_method == REPEAT_CD )
+ tcd_playtracks(cd, cd->first_t, cd->last_t, 0);
diff --git a/audio/gnomemedia/pkg-comment b/audio/gnomemedia/pkg-comment
new file mode 100644
index 000000000000..d1ada7705ba3
--- /dev/null
+++ b/audio/gnomemedia/pkg-comment
@@ -0,0 +1 @@
+Multimedia applications for the GNOME desktop.
diff --git a/audio/gnomemedia/pkg-descr b/audio/gnomemedia/pkg-descr
new file mode 100644
index 000000000000..3d3117e6a73a
--- /dev/null
+++ b/audio/gnomemedia/pkg-descr
@@ -0,0 +1,3 @@
+Multimedia applications for the GNOME desktop. Includes gtcd, a CDDB
+aware CD player; GMix, for controlling the sound card's mixer; and
+VU-Meter, to slow down your desktop...
diff --git a/audio/gnomemedia/pkg-plist b/audio/gnomemedia/pkg-plist
new file mode 100644
index 000000000000..eb694b4d1e42
--- /dev/null
+++ b/audio/gnomemedia/pkg-plist
@@ -0,0 +1,32 @@
+bin/cddbslave
+bin/gmix
+bin/gtcd
+bin/vumeter
+share/gnome/apps/Multimedia/gmix.desktop
+share/gnome/apps/Multimedia/gtcd.desktop
+share/gnome/apps/Multimedia/vumeter.desktop
+share/gnome/pixmaps/tcd/cdrom.xpm
+share/gnome/pixmaps/tcd/eject.xpm
+share/gnome/pixmaps/tcd/ff.xpm
+share/gnome/pixmaps/tcd/goto.xpm
+share/gnome/pixmaps/tcd/next_t.xpm
+share/gnome/pixmaps/tcd/pause.xpm
+share/gnome/pixmaps/tcd/play.xpm
+share/gnome/pixmaps/tcd/prev_t.xpm
+share/gnome/pixmaps/tcd/rw.xpm
+share/gnome/pixmaps/tcd/stop.xpm
+share/locale/da/LC_MESSAGES/gnome-media.mo
+share/locale/de/LC_MESSAGES/gnome-media.mo
+share/locale/es/LC_MESSAGES/gnome-media.mo
+share/locale/fi/LC_MESSAGES/gnome-media.mo
+share/locale/fr/LC_MESSAGES/gnome-media.mo
+share/locale/ga/LC_MESSAGES/gnome-media.mo
+share/locale/hu/LC_MESSAGES/gnome-media.mo
+share/locale/it/LC_MESSAGES/gnome-media.mo
+share/locale/ja/LC_MESSAGES/gnome-media.mo
+share/locale/ko/LC_MESSAGES/gnome-media.mo
+share/locale/nl/LC_MESSAGES/gnome-media.mo
+share/locale/no/LC_MESSAGES/gnome-media.mo
+share/locale/pt/LC_MESSAGES/gnome-media.mo
+share/locale/ru_RU/LC_MESSAGES/gnome-media.mo
+@dirrm share/gnome/pixmaps/tcd/
diff --git a/audio/gnomemedia2/Makefile b/audio/gnomemedia2/Makefile
new file mode 100644
index 000000000000..8a17ad7c6c90
--- /dev/null
+++ b/audio/gnomemedia2/Makefile
@@ -0,0 +1,36 @@
+# New ports collection makefile for: gnome-media
+# Version required: 1.0.1
+# Date created: 20 January 1999
+# Whom: Jeremy Lea <reg@shale.csir.co.za>
+#
+# $Id: $
+#
+
+DISTNAME= gnome-media-1.0.1
+PKGNAME= gnomemedia-1.0.1
+CATEGORIES= audio gnome
+MASTER_SITES= ${MASTER_SITE_GNOME}
+MASTER_SITE_SUBDIR= gnome-1.0/sources
+
+MAINTAINER= reg@shale.csir.co.za
+
+BUILD_DEPENDS= panel:${PORTSDIR}/x11/gnomecore
+RUN_DEPENDS= panel:${PORTSDIR}/x11/gnomecore
+
+# implicit dependencies:
+# gettext, esound, gnomelibs
+
+USE_X_PREFIX= yes
+USE_GMAKE= yes
+GNU_CONFIGURE= yes
+CONFIGURE_ARGS= --without-ncurses \
+ --localstatedir=${PREFIX}/share/gnome \
+ --datadir=${PREFIX}/share/gnome \
+ --with-gnome=${X11BASE}
+CONFIGURE_ENV= CPPFLAGS="-I${LOCALBASE}/include" \
+ LIBS="-L${LOCALBASE}/lib"
+
+post-install:
+ @${SETENV} OBJFORMAT=${PORTOBJFORMAT} ${LDCONFIG} -m ${PREFIX}/lib
+
+.include <bsd.port.mk>
diff --git a/audio/gnomemedia2/distinfo b/audio/gnomemedia2/distinfo
new file mode 100644
index 000000000000..6beda9aad6f4
--- /dev/null
+++ b/audio/gnomemedia2/distinfo
@@ -0,0 +1 @@
+MD5 (gnome-media-1.0.1.tar.gz) = 34c5fa120431aa3ff07b087cbc7cdcdf
diff --git a/audio/gnomemedia2/files/patch-ac b/audio/gnomemedia2/files/patch-ac
new file mode 100644
index 000000000000..7c6e1965bf81
--- /dev/null
+++ b/audio/gnomemedia2/files/patch-ac
@@ -0,0 +1,50 @@
+--- vu-meter/Makefile.in.orig Wed Mar 3 12:35:57 1999
++++ vu-meter/Makefile.in Wed Mar 3 12:36:25 1999
+@@ -116,9 +116,9 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+-INCLUDES = -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(GNOME_INCLUDEDIR)
++INCLUDES = -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(GNOME_INCLUDEDIR)
+
+
+ bin_PROGRAMS = vumeter
+--- gmix/Makefile.in.orig Sat Feb 27 09:22:00 1999
++++ gmix/Makefile.in Wed Mar 3 12:37:46 1999
+@@ -116,11 +116,11 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+ EXTRA_DIST = README TODO NEWS gmix.desktop
+
+-INCLUDES = -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(GNOME_INCLUDEDIR)
++INCLUDES = -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(GNOME_INCLUDEDIR)
+
+
+ bin_PROGRAMS = gmix
+--- tcd/Makefile.in.orig Sat Feb 27 09:22:02 1999
++++ tcd/Makefile.in Wed Mar 3 12:38:28 1999
+@@ -116,7 +116,7 @@
+ ZVT_LIBS = @ZVT_LIBS@
+ l = @l@
+
+-Audiodir = $(datadir)/gnome/apps/Multimedia
++Audiodir = $(datadir)/apps/Multimedia
+
+ EXTRA_DIST = README TODO NEWS gtcd.desktop
+
+@@ -141,7 +141,7 @@
+
+ CLEANFILES = *~
+
+-INCLUDES = -I$(includedir) $(GNOME_INCLUDEDIR) $(CURSES_INCLUDEDIR) -DGNOMELOCALEDIR=\""$(datadir)/locale"\" $(USE_CD_CHANGER) -g
++INCLUDES = -I$(includedir) $(GNOME_INCLUDEDIR) $(CURSES_INCLUDEDIR) -DGNOMELOCALEDIR=\""$(prefix)/share/locale"\" $(USE_CD_CHANGER) -g
+
+
+ Audio_DATA = gtcd.desktop
diff --git a/audio/gnomemedia2/files/patch-ad b/audio/gnomemedia2/files/patch-ad
new file mode 100644
index 000000000000..6a817788707f
--- /dev/null
+++ b/audio/gnomemedia2/files/patch-ad
@@ -0,0 +1,73 @@
+--- gmix/gmix.c.orig Fri Feb 19 18:30:49 1999
++++ gmix/gmix.c Wed Mar 3 10:49:51 1999
+@@ -94,6 +94,17 @@
+ /*
+ * All, that is known about a mixer-device
+ */
++
++#if !defined(OPEN_SOUND_SYSTEM)
++typedef struct mixer_info
++{
++ char id[16];
++ char name[32];
++ int modify_counter;
++ int fillers[10];
++} mixer_info;
++#endif
++
+ typedef struct device_info {
+ int fd;
+ mixer_info info;
+@@ -272,11 +283,7 @@
+ /*
+ * open the mixer-device
+ */
+- if (num==0) {
+- sprintf(device_name, "/dev/mixer");
+- } else {
+- sprintf(device_name, "/dev/mixer%i", num);
+- }
++ sprintf(device_name, "/dev/mixer%i", num);
+ new_device->fd=open(device_name, O_RDWR, 0);
+ if (new_device->fd<0) {
+ free(new_device);
+@@ -291,6 +298,8 @@
+ fprintf(stderr, "Warning: This version of gmix was compiled with a different version of\nsoundcard.h.\n");
+ }
+ #endif
++
++#if defined(OPEN_SOUND_SYSTEM)
+ /*
+ * mixer-name
+ */
+@@ -301,6 +310,11 @@
+ }
+ if(!isalpha(new_device->info.name[0]))
+ g_snprintf(new_device->info.name, 31, "Card %d", num+1);
++#else
++ g_snprintf(new_device->info.id, 15, "mixer%d", num);
++ g_snprintf(new_device->info.name, 31, "Sound Card %d", num+1);
++ new_device->info.modify_counter=0;
++#endif
+ /*
+ * several bitmasks describing the mixer
+ */
+@@ -386,15 +400,15 @@
+ {
+ int cnt;
+ device_info *new_device;
+- cnt=0; devices=NULL;
++ cnt=0; num_mixers=0; devices=NULL;
+ do {
+ new_device=open_device(cnt++);
+ if (new_device) {
+ new_device->channels=make_channels(new_device);
+ devices=g_list_append(devices, new_device);
++ num_mixers++;
+ }
+- } while (new_device);
+- num_mixers=cnt-1;
++ } while ((errno == EACCES) || (errno == EINVAL) || new_device);
+ }
+
+ void free_one_device(gpointer a, gpointer b)
diff --git a/audio/gnomemedia2/files/patch-ae b/audio/gnomemedia2/files/patch-ae
new file mode 100644
index 000000000000..6dd5f1c41e5f
--- /dev/null
+++ b/audio/gnomemedia2/files/patch-ae
@@ -0,0 +1,881 @@
+--- tcd/callbacks.c.orig Sun Feb 21 20:32:04 1999
++++ tcd/callbacks.c Wed Mar 3 10:57:00 1999
+@@ -10,7 +10,7 @@
+
+ void play_cb(GtkWidget *widget, gpointer data)
+ {
+- if(cd.sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED)
++ if(SC_AUDIOSTATUS(cd.sc)==CDROM_AUDIO_PAUSED)
+ tcd_pausecd(&cd);
+ else
+ tcd_playtracks(&cd, cd.first_t, cd.last_t, prefs.only_use_trkind);
+@@ -42,7 +42,7 @@
+ cd.play_method = NORMAL;
+ cd.repeat_track = -1;
+ /* SDH: Make sure play/pause state change is noticed */
+- cd.sc.cdsc_audiostatus = -1;
++ SC_AUDIOSTATUS(cd.sc) = -1;
+ if(cd.isplayable)
+ {
+ make_goto_menu();
+--- tcd/cddb.c.orig Sat Feb 20 23:08:10 1999
++++ tcd/cddb.c Wed Mar 3 10:57:00 1999
+@@ -120,16 +120,16 @@
+ {
+ int min, sec;
+
+- min = cd->trk[i].toc.cdte_addr.msf.minute;
+- sec = cd->trk[i].toc.cdte_addr.msf.second;
++ min = TOC_MINUTE(cd->trk[i]);
++ sec = TOC_MINUTE(cd->trk[i]);
+
+ n = (min*60)+sec;
+- fprintf( fp, "# %u\n", (n*75)+cd->trk[i].toc.cdte_addr.msf.frame );
++ fprintf( fp, "# %u\n", (n*75)+TOC_FRAME(cd->trk[i]) );
+ }
+ /* Print the number of seconds */
+ fprintf( fp, "#\n# Disc length: %i seconds\n",
+- (cd->trk[cd->last_t+1].toc.cdte_addr.msf.minute*60)
+- +(cd->trk[cd->last_t+1].toc.cdte_addr.msf.second) );
++ (TOC_MINUTE(cd->trk[cd->last_t+1])*60)
++ +(TOC_SECOND(cd->trk[cd->last_t+1])) );
+
+ /* FIXME increment revision. sigh, lousy cddb */
+ fprintf( fp, "#\n# Revision: 0\n" );
+@@ -160,10 +160,10 @@
+ {
+ int min, sec;
+
+- min = cd->trk[i].toc.cdte_addr.msf.minute;
+- sec = cd->trk[i].toc.cdte_addr.msf.second;
++ min = TOC_MINUTE(cd->trk[i]);
++ sec = TOC_SECOND(cd->trk[i]);
+
+- l=sprintf( tmp, "%u ", calc_offset(min,sec,cd->trk[i].toc.cdte_addr.msf.frame));
++ l=sprintf( tmp, "%u ", calc_offset(min,sec,TOC_FRAME(cd->trk[i])));
+
+ if(blen>l)
+ {
+@@ -172,8 +172,8 @@
+ }
+ }
+ l=sprintf( tmp, "%i\n",
+- (cd->trk[cd->last_t+1].toc.cdte_addr.msf.minute*60)
+- +(cd->trk[cd->last_t+1].toc.cdte_addr.msf.second) );
++ (TOC_MINUTE(cd->trk[cd->last_t+1])*60)
++ +(TOC_SECOND(cd->trk[cd->last_t+1])) );
+ if(blen>l)
+ strcat( buf,tmp );
+
+@@ -203,9 +203,9 @@
+
+ for( i=0; i <= cd->last_t+1; i++ )
+ {
+- cdtoc[i].frame = cd->trk[i+1].toc.cdte_addr.msf.frame;
+- cdtoc[i].min = cd->trk[i+1].toc.cdte_addr.msf.minute;
+- cdtoc[i].sec = cd->trk[i+1].toc.cdte_addr.msf.second;
++ cdtoc[i].frame = TOC_FRAME(cd->trk[i+1]);
++ cdtoc[i].min = TOC_MINUTE(cd->trk[i+1]);
++ cdtoc[i].sec = TOC_SECOND(cd->trk[i+1]);
+ }
+
+
+--- tcd/gtcd.c.orig Wed Feb 24 02:48:49 1999
++++ tcd/gtcd.c Wed Mar 3 10:57:00 1999
+@@ -408,8 +408,8 @@
+ break;
+ case DISC_R:
+ cur = cd.cur_pos_abs;
+- end = (cd.trk[cd.last_t+1].toc.cdte_addr.msf.minute
+- *60)+cd.trk[cd.last_t+1].toc.cdte_addr.msf.second;
++ end = (TOC_MINUTE(cd.trk[cd.last_t+1])*60
++ +TOC_SECOND(cd.trk[cd.last_t+1]));
+ pos = end-cur;
+ min = pos/60;
+ sec = pos-(pos/60)*60;
+@@ -490,7 +490,7 @@
+
+ if( !cd.err )
+ {
+- switch( cd.sc.cdsc_audiostatus )
++ switch( SC_AUDIOSTATUS(cd.sc) )
+ {
+ case CDROM_AUDIO_INVALID:
+ strcpy(tmp, _("No Disc"));
+@@ -577,8 +577,8 @@
+ }
+
+ /* see if we need to repeat */
+- if( cd.sc.cdsc_audiostatus != CDROM_AUDIO_PLAY &&
+- cd.sc.cdsc_audiostatus != CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd.sc) != CDROM_AUDIO_PLAY &&
++ SC_AUDIOSTATUS(cd.sc) != CDROM_AUDIO_PAUSED )
+ {
+ if( cd.play_method == REPEAT_CD )
+ tcd_playtracks( &cd, cd.first_t, cd.last_t, prefs.only_use_trkind);
+@@ -593,14 +593,14 @@
+
+ void status_changed(void)
+ {
+- if(old_status != cd.sc.cdsc_audiostatus)
++ if(old_status != SC_AUDIOSTATUS(cd.sc))
+ {
+ GtkWidget *pixmap;
+ GtkSignalFunc func;
+ char tmp[256];
+ char *name;
+
+- old_status = cd.sc.cdsc_audiostatus;
++ old_status = SC_AUDIOSTATUS(cd.sc);
+ g_snprintf(tmp, 255, "tcd/%s.xpm",
+ (old_status==CDROM_AUDIO_PLAY)?"pause":"play");
+
+--- tcd/gtracked.c.orig Thu Feb 11 18:48:56 1999
++++ tcd/gtracked.c Wed Mar 3 10:57:00 1999
+@@ -166,8 +166,8 @@
+ /* Disc area */
+ disc_table = gtk_table_new(2, 2, FALSE);
+ g_snprintf(tmp, 63, _("Disc Information (%02u:%02u minutes)"),
+- cd.trk[cd.last_t+1].toc.cdte_addr.msf.minute,
+- cd.trk[cd.last_t+1].toc.cdte_addr.msf.second);
++ TOC_MINUTE(cd.trk[cd.last_t+1]),
++ TOC_SECOND(cd.trk[cd.last_t+1]));
+
+ disc_frame = gtk_frame_new(tmp);
+ label = gtk_label_new(_("Artist / Title"));
+--- tcd/linux-cdrom.c.orig Tue Feb 23 06:52:46 1999
++++ tcd/linux-cdrom.c Wed Mar 3 10:57:00 1999
+@@ -77,7 +77,7 @@
+ if(!homedir)
+ homedir = "/";
+
+-#if defined(TCD_CHANGER_ENABLED)
++#if defined(TCD_CHANGER_ENABLED) && !defined(TCD_BSD)
+ cd->nslots = ioctl( cd->cd_dev, CDROM_CHANGER_NSLOTS );
+ #else
+ cd->nslots = 0;
+@@ -120,34 +120,58 @@
+
+ int tcd_readtoc( cd_struct *cd )
+ {
+- int tmp,i;
++ int i;
+ int delsecs;
++#ifdef TCD_BSD
++ struct ioc_read_toc_single_entry tocentry;
++#endif
+
+ debug("cdrom.c: tcd_readtoc(%p) top\n", cd );
+ cd->err = FALSE;
+ cd->isplayable=FALSE;
+
+ /* read the TOC header */
++#ifdef TCD_BSD
++ if(ioctl( cd->cd_dev, CDIOREADTOCHEADER, &cd->tochdr))
++#else
+ if(ioctl( cd->cd_dev, CDROMREADTOCHDR, &cd->tochdr))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCHDR ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+
+ /* grab first & last tracks */
++#ifdef TCD_BSD
++ cd->first_t = cd->tochdr.starting_track;
++ cd->last_t = cd->tochdr.ending_track;
++#else
+ cd->first_t = cd->tochdr.cdth_trk0;
+ cd->last_t = cd->tochdr.cdth_trk1;
++#endif
+
+ /* read the leadout track */
++#ifdef TCD_BSD
++ tocentry.track = cd->last_t+1; /* Magic last track */
++ tocentry.address_format = CD_MSF_FORMAT;
++#else
+ cd->trk[C(cd->last_t+1)].toc.cdte_track = CDROM_LEADOUT;
+ cd->trk[C(cd->last_t+1)].toc.cdte_format = CDROM_MSF;
++#endif
+
+ /* read the leadout toc */
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOREADTOCENTRY, &tocentry))
++#else
+ if(ioctl(cd->cd_dev, CDROMREADTOCENTRY, &cd->trk[C(cd->last_t+1)].toc))
++#endif
+ {
+ strcpy(cd->errmsg, "Can't read disc.");
+ cd->err = TRUE;
+@@ -155,40 +179,65 @@
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCENTRY ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ cd->trk[C(cd->last_t+1)].toc = tocentry.entry;
++#endif
++ cd->trk[C(cd->last_t+1)].length = TOC_MINUTE(cd->trk[C(cd->last_t+1)]) * 60 +
++ TOC_SECOND(cd->trk[C(cd->last_t+1)]);
++ cd->trk[C(cd->last_t+1)].start = cd->trk[C(cd->last_t+1)].length * 75 +
++ TOC_FRAME(cd->trk[C(cd->last_t+1)]);
+
+ /* read the rest of the tocs */
+ for( i = cd->first_t; i <= cd->last_t; i++ )
+ {
++#ifdef TCD_BSD
++ tocentry.track = i;
++ tocentry.address_format = CD_MSF_FORMAT;
++#else
+ cd->trk[C(i)].toc.cdte_track = i;
+ cd->trk[C(i)].toc.cdte_format = CDROM_MSF;
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOREADTOCENTRY, &tocentry))
++#else
+ if(ioctl(cd->cd_dev, CDROMREADTOCENTRY, &cd->trk[C(i)].toc))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_readtoc exiting prematurly. CDROMREADTOCENTRY ioctl error.\n" );
+ cd->cur_t = 0;
+ cd->cddb_id = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+
++#ifdef TCD_BSD
++ cd->trk[C(i)].toc = tocentry.entry;
++ cd->trk[C(i)].type = cd->trk[C(i)].toc.control;
++#else
+ cd->trk[C(i)].type = cd->trk[C(i)].toc.cdte_ctrl;
+- cd->trk[C(i)].length = cd->trk[C(i)].toc.cdte_addr.msf.minute * 60 +
+- cd->trk[C(i)].toc.cdte_addr.msf.second;
++#endif
++ cd->trk[C(i)].length = TOC_MINUTE(cd->trk[C(i)]) * 60 +
++ TOC_SECOND(cd->trk[C(i)]);
+ cd->trk[C(i)].start = cd->trk[C(i)].length * 75 +
+- cd->trk[C(i)].toc.cdte_addr.msf.frame;
++ TOC_FRAME(cd->trk[C(i)]);
+ }
+
+ /* calculate track times */
+ for(i = cd->first_t; i <= cd->last_t; i ++)
+ {
+ /* Taken from cdtool...Thanks Thomas I.! */
+- delsecs = cd->trk[C(i+1)].toc.cdte_addr.msf.minute * 60
+- + cd->trk[C(i+1)].toc.cdte_addr.msf.second
+- - cd->trk[C(i)].toc.cdte_addr.msf.minute * 60
+- - cd->trk[C(i)].toc.cdte_addr.msf.second;
++ delsecs = cd->trk[C(i+1)].length
++ - cd->trk[C(i)].length;
+
+ cd->trk[C(i)].tot_min = delsecs / 60;
+ cd->trk[C(i)].tot_sec = delsecs - (delsecs/60)*60;
+@@ -207,7 +256,7 @@
+
+ cd->isplayable=TRUE;
+ debug("cdrom.c: tcd_readtoc exiting normally\n" );
+- return tmp;
++ return 0;
+ }
+
+ void tcd_recalculate(cd_struct *cd)
+@@ -215,9 +264,8 @@
+ int result;
+
+ /* calculate various timing values */
+- cd->cur_pos_abs = cd->sc.cdsc_absaddr.msf.minute * 60 +
+- cd->sc.cdsc_absaddr.msf.second;
+- cd->cur_frame = cd->cur_pos_abs * 75 + cd->sc.cdsc_absaddr.msf.frame;
++ cd->cur_pos_abs = SC_MINUTE(cd->sc) * 60 + SC_SECOND(cd->sc);
++ cd->cur_frame = cd->cur_pos_abs * 75 + SC_FRAME(cd->sc);
+
+ cd->cur_pos_rel = (cd->cur_frame - cd->trk[C(cd->cur_t)].start) / 75;
+
+@@ -235,42 +283,83 @@
+ cd->cd_sec = cd->cur_pos_abs % 60;
+ cd->cd_min = cd->cur_pos_abs / 60;
+
+-#ifdef TCD_CHANGER_ENABLED
++#if defined(TCD_CHANGER_ENABLED) & !defined(TCD_BSD)
+ cd->cur_disc = ioctl( cd->cd_dev, CDROM_SELECT_DISC, CDSL_CURRENT );
+ #endif
+ }
+
+ void tcd_gettime( cd_struct *cd )
+ {
++#ifdef TCD_BSD
++ struct ioc_read_subchannel subch;
++#endif
++
+ cd->err = FALSE;
++#ifdef TCD_BSD
++ subch.address_format = CD_MSF_FORMAT;
++ subch.data_format = CD_CURRENT_POSITION;
++ subch.data_len = sizeof(cd->sc);
++ subch.data = &(cd->sc);
++#else
+ cd->sc.cdsc_format = CDROM_MSF;
++#endif
+
+ if(cd->isplayable)
+ {
++#ifdef TCD_BSD
++ if(ioctl( cd->cd_dev, CDIOCREADSUBCHANNEL, &subch))
++#else
+ if(ioctl( cd->cd_dev, CDROMSUBCHNL, &cd->sc))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't read disc." );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_gettime exiting early. CDROMSUBCHNL ioctl error.\n" );
+ cd->cur_t = 0;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return;
+ }
+- if(cd->sc.cdsc_audiostatus==CDROM_AUDIO_PLAY)
+- cd->cur_t = cd->sc.cdsc_trk;
++ if( SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PLAY )
++ {
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
++ cd->cur_t = SC_TRACK(cd->sc);
++ }
+ else
+- cd->cur_t = 0;
++ {
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++ cd->cur_t = 0;
++ }
+ tcd_recalculate(cd);
+ }
+ }
+
+ int tcd_set_volume(cd_struct *cd, int volume)
+ {
++#ifdef TCD_BSD
++ struct ioc_vol vol;
++#else
+ struct cdrom_volctrl vol;
++#endif
+
++#ifdef TCD_BSD
++ vol.vol[0] = volume;
++ vol.vol[1] = vol.vol[2] = vol.vol[3] = vol.vol[0];
++#else
+ vol.channel0 = volume;
+ vol.channel1 = vol.channel2 = vol.channel3 = vol.channel0;
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCSETVOL, &vol) < 0)
++#else
+ if(ioctl(cd->cd_dev, CDROMVOLCTRL, &vol) < 0)
++#endif
+ return FALSE;
+
+ return TRUE;
+@@ -278,6 +367,14 @@
+
+ int tcd_get_volume(cd_struct *cd)
+ {
++#ifdef TCD_BSD
++ struct ioc_vol vol;
++
++ if(ioctl(cd->cd_dev, CDIOCGETVOL, &vol) < 0)
++ return -1;
++
++ return vol.vol[0];
++#else
+ #ifdef CDROMVOLREAD
+ struct cdrom_volctrl vol;
+
+@@ -287,13 +384,40 @@
+ return vol.channel0;
+ #else
+ return 0;
++#endif
+ #endif
+ }
+
+ int tcd_playtracks(cd_struct *cd, int start_t, int end_t, int only_use_trkind)
+ {
++#ifdef TCD_BSD
++ struct ioc_play_msf msf;
++#define MSF_START_MIN (msf.start_m)
++#define MSF_START_SEC (msf.start_s)
++#define MSF_START_FRM (msf.start_f)
++#define MSF_END_MIN (msf.end_m)
++#define MSF_END_SEC (msf.end_s)
++#define MSF_END_FRM (msf.end_f)
++ struct ioc_play_track trkind;
++#define TI_START_TRK (trkind.start_track)
++#define TI_START_IND (trkind.start_index)
++#define TI_END_TRK (trkind.end_track)
++#define TI_END_IND (trkind.end_index)
++#else
+ struct cdrom_msf msf;
++#define MSF_START_MIN (msf.cdmsf_min0)
++#define MSF_START_SEC (msf.cdmsf_sec0)
++#define MSF_START_FRM (msf.cdmsf_frame0)
++#define MSF_END_MIN (msf.cdmsf_min1)
++#define MSF_END_SEC (msf.cdmsf_sec1)
++#define MSF_END_FRM (msf.cdmsf_frame0)
+ struct cdrom_ti trkind;
++#define TI_START_TRK (trkind.cdti_trk0)
++#define TI_START_IND (trkind.cdti_ind0)
++#define TI_END_TRK (trkind.cdti_trk1)
++#define TI_END_IND (trkind.cdti_ind1)
++#endif
++
+ int tmp;
+ debug("cdrom.c: tcd_playtracks( %p, %d, %d )\n", cd, start_t, end_t );
+ cd->err = FALSE;
+@@ -302,7 +426,7 @@
+ tcd_gettime(cd);
+ if(cd->err)
+ {
+- /* try and inject cd */
++ /* try and eject cd */
+ tcd_ejectcd(cd);
+
+ if(cd->err)
+@@ -312,64 +436,88 @@
+ }
+ }
+
++#ifdef TCD_BSD
++ ioctl(cd->cd_dev, CDIOCCLOSE);
++#else
+ #if defined(CDROMCLOSETRAY)
+ ioctl(cd->cd_dev, CDROMCLOSETRAY);
+-#endif
+-
+- if(cd->trk[start_t].toc.cdte_ctrl == CDROM_DATA_TRACK)
+- start_t++; /* bad hack. most data tracks are the first track... */
++#endif
++#endif
+
+- msf.cdmsf_min0 = cd->trk[start_t].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec0 = cd->trk[start_t].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame0 = cd->trk[start_t].toc.cdte_addr.msf.frame;
++ /* bad hack. most data tracks are the first track... */
++#ifdef TCD_BSD
++ if(cd->trk[start_t].toc.control == 0x04)
++#else
++ if(cd->trk[start_t].toc.cdte_ctrl == CDROM_DATA_TRACK)
++#endif
++ start_t++;
++
++ MSF_START_MIN = TOC_MINUTE(cd->trk[start_t]);
++ MSF_START_SEC = TOC_SECOND(cd->trk[start_t]);
++ MSF_START_FRM = TOC_FRAME(cd->trk[start_t]);
+
+ if( end_t < 0 )
+ {
+- msf.cdmsf_min1 = cd->trk[start_t].tot_min+msf.cdmsf_min0;
+- msf.cdmsf_sec1 = cd->trk[start_t].tot_sec+msf.cdmsf_sec0;
+- msf.cdmsf_frame1=0;
++ MSF_END_MIN = cd->trk[start_t].tot_min+MSF_START_MIN;
++ MSF_END_SEC = cd->trk[start_t].tot_sec+MSF_START_SEC;
++ MSF_END_FRM = 0;
+ }
+ else
+ {
+- msf.cdmsf_min1 = cd->trk[end_t+1].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec1 = cd->trk[end_t+1].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame1 = cd->trk[end_t+1].toc.cdte_addr.msf.frame - 1;
++ MSF_END_MIN = TOC_MINUTE(cd->trk[end_t+1]);
++ MSF_END_SEC = TOC_SECOND(cd->trk[end_t+1]);
++ MSF_END_FRM = TOC_FRAME(cd->trk[end_t+1]) - 1;
+
+ #ifdef UNSIGNED_NUMBERS_CAN_BE_NEGATIVE
+- if(msf.cdmsf_frame1 < 0)
++ if(MSF_END_FRM < 0)
+ {
+- msf.cdmsf_sec1 += msf.cdmsf_frame1;
+- msf.cdmsf_frame1 = 0;
++ MSF_END_SEC += MSF_END_FRM;
++ MSF_END_FRM = 0;
+ }
+- if(msf.cdmsf_sec1 < 0)
++ if(MSF_END_SEC < 0)
+ {
+- msf.cdmsf_min1 += msf.cdmsf_sec1;
+- msf.cdmsf_sec1 = 0;
++ MSF_END_MIN += MSF_END_SEC;
++ MSF_END_SEC = 0;
+ }
+- if(msf.cdmsf_min1 < 0)
++ if(MSF_END_MIN < 0)
+ {
+- msf.cdmsf_min1 = 0;
++ MSF_END_MIN = 0;
+ }
+ #endif
+ }
+- msf.cdmsf_min1 += (msf.cdmsf_sec1 / 60);
+- msf.cdmsf_sec1 %= 60;
++ MSF_END_MIN += (MSF_END_SEC / 60);
++ MSF_END_SEC %= 60;
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
++
++#ifdef TCD_BSD
++ if(only_use_trkind || ioctl( cd->cd_dev, CDIOCPLAYMSF, &msf))
++#else
+ if(ioctl( cd->cd_dev, CDROMPLAYMSF, &msf) || only_use_trkind)
++#endif
+ {
+ debug("cdrom.c: tcd_playtracks error. CDROMPLAYMSF ioctl error (or user override). Trying PLAYTRKIND\n" );
+
+ /* Try alternate method of playing */
+- trkind.cdti_trk0 = start_t; /* start track */
+- trkind.cdti_ind0 = 0; /* start index */
+- trkind.cdti_trk1 = end_t; /* end track */
+- trkind.cdti_ind1 = 0; /* end index */
++ TI_START_TRK = start_t; /* start track */
++ TI_START_IND = 0; /* start index */
++ TI_END_TRK = end_t; /* end track */
++ TI_END_IND = 0; /* end index */
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCPLAYTRACKS, &trkind))
++#else
+ if(ioctl(cd->cd_dev, CDROMPLAYTRKIND, &trkind))
++#endif
+ {
+ strcpy( cd->errmsg, "Error playing disc" );
+ cd->err = TRUE;
+ debug("cdrom.c: tcd_playtracks error. CDROMPLAYTRKIND ioctl error.\n");
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return -1;
+ }
+ }
+@@ -381,7 +529,11 @@
+
+ int tcd_play_seconds( cd_struct *cd, long int offset )
+ {
++#ifdef TCD_BSD
++ struct ioc_play_msf msf;
++#else
+ struct cdrom_msf msf;
++#endif
+ int tmp;
+
+ debug("cdrom.c: tcd_playseconds( %p, %ld )\n", cd, offset );
+@@ -390,42 +542,53 @@
+ cd->isplayable=FALSE;
+
+ /* got subchannel? */
+- msf.cdmsf_sec0 = cd->sc.cdsc_absaddr.msf.second+offset;
+- msf.cdmsf_min0 = cd->sc.cdsc_absaddr.msf.minute;
+- msf.cdmsf_frame0 = cd->sc.cdsc_absaddr.msf.frame;
+- msf.cdmsf_min1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.minute;
+- msf.cdmsf_sec1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.second;
+- msf.cdmsf_frame1 = cd->trk[C(cd->last_t+1)].toc.cdte_addr.msf.frame - 1;
++ MSF_START_SEC = SC_SECOND(cd->sc)+offset;
++ MSF_START_MIN = SC_MINUTE(cd->sc);
++ MSF_START_FRM = SC_FRAME(cd->sc);
++ MSF_END_MIN = TOC_MINUTE(cd->trk[C(cd->last_t+1)]);
++ MSF_END_SEC = TOC_SECOND(cd->trk[C(cd->last_t+1)]);
++ MSF_END_FRM = TOC_FRAME(cd->trk[C(cd->last_t+1)]) - 1;
+
+ #ifdef UNSIGNED_NUMBERS_CAN_BE_NEGATIVE
+- if(msf.cdmsf_frame1 < 0)
++ if(MSF_END_FRM < 0)
+ {
+- msf.cdmsf_sec1 += msf.cdmsf_frame1;
+- msf.cdmsf_frame1 = 0;
++ MSF_END_SEC += MSF_END_FRM;
++ MSF_END_FRM = 0;
+ }
+- if(msf.cdmsf_sec1 < 0)
++ if(MSF_END_SEC < 0)
+ {
+- msf.cdmsf_min1 += msf.cdmsf_sec1;
+- msf.cdmsf_sec1 = 0;
++ MSF_END_MIN += MSF_END_SEC;
++ MSF_END_SEC = 0;
+ }
+- if(msf.cdmsf_min1 < 0)
++ if(MSF_END_MIN < 0)
+ {
+- msf.cdmsf_min1 = 0;
++ MSF_END_MIN = 0;
+ }
+ #endif
+
+- if( msf.cdmsf_sec0 > 60 && (offset<0) )
++ if( MSF_START_SEC > 60 && (offset<0) )
+ {
+- msf.cdmsf_sec0 = 60-abs(offset);
+- msf.cdmsf_min0--;
++ MSF_START_SEC = 60-abs(offset);
++ MSF_START_MIN--;
+ }
++
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCPLAYMSF, &msf))
++#else
+ if(ioctl(cd->cd_dev, CDROMPLAYMSF, &msf))
++#endif
+ {
+ strcpy( cd->errmsg, "Error playing disc." );
+ cd->err = TRUE;
+
+ debug("cdrom.c: tcd_play_seconds error. CDROMPLAYMSF ioctl error.\n" );
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
+ cd->isplayable=TRUE;
+@@ -442,7 +605,15 @@
+ if(cd->isplayable) tcd_stopcd(cd);
+ cd->err = FALSE;
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++
++#ifdef TCD_BSD
++ if(!ioctl(cd->cd_dev, CDIOCEJECT))
++#else
+ if(!ioctl(cd->cd_dev, CDROMEJECT))
++#endif
+ {
+ cd->isplayable = FALSE;
+ strcpy(cd->errmsg, "No disc in drive ");
+@@ -450,9 +621,17 @@
+ }
+ else
+ {
++#ifdef TCD_BSD
++ tmp = ioctl( cd->cd_dev, CDIOCCLOSE );
++#else
+ #ifdef CDROMCLOSETRAY
+ tmp = ioctl( cd->cd_dev, CDROMCLOSETRAY );
+ #endif
++#endif
++
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+
+ if(tcd_post_init(cd))
+ {
+@@ -461,6 +640,9 @@
+
+ debug("cdrom.c: tcd_eject - disc init error. %s\n",
+ strerror(errno) );
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+
+ return(-1);
+ }
+@@ -479,11 +661,19 @@
+ debug("cdrom.c: tcd_stopcd(%p)\n", cd );
+
+ /* SDH: Makes things cleaner on eject */
+- if( cd->sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PAUSED )
+ tcd_pausecd(cd);
+
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
++
+ cd->err = FALSE;
++#ifdef TCD_BSD
++ if(ioctl(cd->cd_dev, CDIOCSTOP))
++#else
+ if(ioctl(cd->cd_dev, CDROMSTOP))
++#endif
+ {
+ strcpy( cd->errmsg, "Can't stop disc." );
+ cd->err = TRUE;
+@@ -501,31 +691,51 @@
+ int tmp;
+ cd->err = FALSE;
+
+- if(cd->sc.cdsc_audiostatus==CDROM_AUDIO_PAUSED)
++ if(SC_AUDIOSTATUS(cd->sc)==CDROM_AUDIO_PAUSED)
+ {
++#ifdef TCD_BSD
++ if((tmp=ioctl(cd->cd_dev, CDIOCRESUME)))
++#else
+ if((tmp=ioctl(cd->cd_dev, CDROMRESUME)))
++#endif
+ {
+ strcpy(cd->errmsg, strerror(errno));
+ cd->err = TRUE;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+ return tmp;
+ }
+ else
+ {
++#ifdef TCD_BSD
++ if((tmp=ioctl(cd->cd_dev, CDIOCPAUSE)))
++#else
+ if((tmp=ioctl(cd->cd_dev, CDROMPAUSE)))
++#endif
+ {
+ strcpy( cd->errmsg, strerror( errno ) );
+ cd->err = TRUE;
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCALLOW);
++#endif
+ return(-1);
+ }
++#ifdef TCD_BSD
++ ioctl( cd->cd_dev, CDIOCPREVENT);
++#endif
+ return tmp;
+ }
+ }
+
+ int tcd_change_disc( cd_struct *cd, int disc )
+ {
+-#ifdef TCD_CHANGER_ENABLED
++#if defined(TCD_CHANGER_ENABLED) && !defined(TCD_BSD)
+ int tmp;
+ cd->err = FALSE;
+
+--- tcd/linux-cdrom.h.orig Thu Feb 11 18:49:43 1999
++++ tcd/linux-cdrom.h Wed Mar 3 10:57:00 1999
+@@ -27,11 +27,26 @@
+
+ #include <sys/types.h>
+
+-#if !defined(linux) && !defined(sun) && !defined(__sun__)
+-#error TCD only builds on linux and Solaris/SunOs
+-#endif
++#if defined(__FreeBSD__)
++
++#define TCD_BSD
++
++#include <sys/cdio.h>
+
+-#ifdef linux
++#define CDROM_AUDIO_INVALID CD_AS_AUDIO_INVALID
++#define CDROM_AUDIO_PLAY CD_AS_PLAY_IN_PROGRESS
++#define CDROM_AUDIO_PAUSED CD_AS_PLAY_PAUSED
++#define CDROM_AUDIO_COMPLETED CD_AS_PLAY_COMPLETED
++#define CDROM_AUDIO_ERROR CD_AS_PLAY_ERROR
++#define CDROM_AUDIO_NO_STATUS CD_AS_NO_STATUS
++
++#define CDROM
++
++#else
++
++#define TCD_LINUX
++
++#if defined(linux)
+ #include <linux/cdrom.h>
+ #endif
+
+@@ -98,6 +113,7 @@
+
+ #endif /* SVR4 */
+ #endif /* sun __sun__ */
++#endif /* __FreeBSD__ */
+
+ #define TRK_NAME_LEN 512
+ #define DISC_INFO_LEN 512
+@@ -106,7 +122,17 @@
+ struct cd_track
+ {
+ char name[TRK_NAME_LEN+1];
++#ifdef TCD_BSD
++ struct cd_toc_entry toc;
++#define TOC_MINUTE(trk) (trk.toc.addr.msf.minute)
++#define TOC_SECOND(trk) (trk.toc.addr.msf.second)
++#define TOC_FRAME(trk) (trk.toc.addr.msf.frame)
++#else
+ struct cdrom_tocentry toc;
++#define TOC_MINUTE(trk) (trk.toc.cdte_addr.msf.minute)
++#define TOC_SECOND(trk) (trk.toc.cdte_addr.msf.second)
++#define TOC_FRAME(trk) (trk.toc.cdte_addr.msf.frame)
++#endif
+ int titled;
+ int start, length;
+ int tot_min, tot_sec;
+@@ -130,10 +156,27 @@
+ char dtitle[DISC_INFO_LEN+1]; /* Disc title */
+ char album[DISC_INFO_LEN+1], artist[DISC_INFO_LEN+1];
+
++#ifdef TCD_BSD
++ /* See /usr/include/sys/cdio.h */
++ struct ioc_play_track ti;
++ struct ioc_toc_header tochdr;
++ struct cd_sub_channel_info sc;
++#define SC_AUDIOSTATUS(sc) (sc.header.audio_status)
++#define SC_TRACK(sc) (sc.what.position.track_number)
++#define SC_MINUTE(sc) (sc.what.position.absaddr.msf.minute)
++#define SC_SECOND(sc) (sc.what.position.absaddr.msf.second)
++#define SC_FRAME(sc) (sc.what.position.absaddr.msf.frame)
++#else
+ /* See /usr/src/linux/include/linux/cdrom.h */
+ struct cdrom_ti ti; /* Track info */
+ struct cdrom_tochdr tochdr; /* TOC header */
+ struct cdrom_subchnl sc; /* Subchannel, for time */
++#define SC_AUDIOSTATUS(sc) (sc.cdsc_audiostatus)
++#define SC_TRACK(sc) (sc.cdsc_trk)
++#define SC_MINUTE(sc) (sc.cdsc_absaddr.msf.minute)
++#define SC_SECOND(sc) (sc.cdsc_absaddr.msf.second)
++#define SC_FRAME(sc) (sc.cdsc_absaddr.msf.frame)
++#endif
+ int volume; /* Must range 0-100 */
+
+ int cd_min, cd_sec; /* Total CD time */
+--- tcd/tcd.c.orig Mon Feb 8 21:13:22 1999
++++ tcd/tcd.c Wed Mar 3 10:57:00 1999
+@@ -139,8 +139,8 @@
+
+ /* if the user hasn't stopped the cd, but it is
+ stopped anyway, fix it. */
+- if( cd->sc.cdsc_audiostatus != CDROM_AUDIO_PLAY &&
+- cd->sc.cdsc_audiostatus != CDROM_AUDIO_PAUSED )
++ if( SC_AUDIOSTATUS(cd->sc) != CDROM_AUDIO_PLAY &&
++ SC_AUDIOSTATUS(cd->sc) != CDROM_AUDIO_PAUSED )
+ {
+ if( cd->play_method == REPEAT_CD )
+ tcd_playtracks(cd, cd->first_t, cd->last_t, 0);
diff --git a/audio/gnomemedia2/pkg-comment b/audio/gnomemedia2/pkg-comment
new file mode 100644
index 000000000000..d1ada7705ba3
--- /dev/null
+++ b/audio/gnomemedia2/pkg-comment
@@ -0,0 +1 @@
+Multimedia applications for the GNOME desktop.
diff --git a/audio/gnomemedia2/pkg-descr b/audio/gnomemedia2/pkg-descr
new file mode 100644
index 000000000000..3d3117e6a73a
--- /dev/null
+++ b/audio/gnomemedia2/pkg-descr
@@ -0,0 +1,3 @@
+Multimedia applications for the GNOME desktop. Includes gtcd, a CDDB
+aware CD player; GMix, for controlling the sound card's mixer; and
+VU-Meter, to slow down your desktop...
diff --git a/audio/gnomemedia2/pkg-plist b/audio/gnomemedia2/pkg-plist
new file mode 100644
index 000000000000..eb694b4d1e42
--- /dev/null
+++ b/audio/gnomemedia2/pkg-plist
@@ -0,0 +1,32 @@
+bin/cddbslave
+bin/gmix
+bin/gtcd
+bin/vumeter
+share/gnome/apps/Multimedia/gmix.desktop
+share/gnome/apps/Multimedia/gtcd.desktop
+share/gnome/apps/Multimedia/vumeter.desktop
+share/gnome/pixmaps/tcd/cdrom.xpm
+share/gnome/pixmaps/tcd/eject.xpm
+share/gnome/pixmaps/tcd/ff.xpm
+share/gnome/pixmaps/tcd/goto.xpm
+share/gnome/pixmaps/tcd/next_t.xpm
+share/gnome/pixmaps/tcd/pause.xpm
+share/gnome/pixmaps/tcd/play.xpm
+share/gnome/pixmaps/tcd/prev_t.xpm
+share/gnome/pixmaps/tcd/rw.xpm
+share/gnome/pixmaps/tcd/stop.xpm
+share/locale/da/LC_MESSAGES/gnome-media.mo
+share/locale/de/LC_MESSAGES/gnome-media.mo
+share/locale/es/LC_MESSAGES/gnome-media.mo
+share/locale/fi/LC_MESSAGES/gnome-media.mo
+share/locale/fr/LC_MESSAGES/gnome-media.mo
+share/locale/ga/LC_MESSAGES/gnome-media.mo
+share/locale/hu/LC_MESSAGES/gnome-media.mo
+share/locale/it/LC_MESSAGES/gnome-media.mo
+share/locale/ja/LC_MESSAGES/gnome-media.mo
+share/locale/ko/LC_MESSAGES/gnome-media.mo
+share/locale/nl/LC_MESSAGES/gnome-media.mo
+share/locale/no/LC_MESSAGES/gnome-media.mo
+share/locale/pt/LC_MESSAGES/gnome-media.mo
+share/locale/ru_RU/LC_MESSAGES/gnome-media.mo
+@dirrm share/gnome/pixmaps/tcd/