aboutsummaryrefslogtreecommitdiff
path: root/audio/musica
diff options
context:
space:
mode:
authorMartin Wilke <miwi@FreeBSD.org>2007-12-18 23:19:54 +0000
committerMartin Wilke <miwi@FreeBSD.org>2007-12-18 23:19:54 +0000
commit577335aa66e60cb57ed3f992681a087f02a1f322 (patch)
treec96d536e54bd44c40bcdfd71f2033101ceeae255 /audio/musica
parente0a81edccec122af65f0ef787e1a95800b632e39 (diff)
Musica is a GTK based MIDI player.
- Plays MIDI files on Linux machines with an OSS sound card interface. - GTK based user interface supporting drag-and-drop for easy file selection. Drag a MIDI file from the GNOME-ified Midnight Commander to Musica's drop pocket and it automatically loads the file. - Tempo adjustment, Play a MIDI file up to four times faster or slower. - Fast forward. Skip those dull passages in a MIDI file. WWW: http://www-ict.its.tudelft.nl/~erik/open-source/musica PR: ports/118839 Submitted by: Pietro Cerutti <gahr at gahr.ch>
Notes
Notes: svn path=/head/; revision=204056
Diffstat (limited to 'audio/musica')
-rw-r--r--audio/musica/Makefile27
-rw-r--r--audio/musica/distinfo3
-rw-r--r--audio/musica/files/patch-src_channel2device.cc11
-rw-r--r--audio/musica/files/patch-src_dnd.cc11
-rw-r--r--audio/musica/files/patch-src_events.cc37
-rw-r--r--audio/musica/files/patch-src_gui.cc183
-rw-r--r--audio/musica/files/patch-src_help.cc11
-rw-r--r--audio/musica/files/patch-src_main.cc29
-rw-r--r--audio/musica/files/patch-src_ossmidi.cc21
-rw-r--r--audio/musica/files/patch-src_program2device.cc11
-rw-r--r--audio/musica/files/patch-src_readmidi.cc12
-rw-r--r--audio/musica/files/patch-src_sequence.cc13
-rw-r--r--audio/musica/pkg-descr10
13 files changed, 379 insertions, 0 deletions
diff --git a/audio/musica/Makefile b/audio/musica/Makefile
new file mode 100644
index 000000000000..bb4c85aaaa43
--- /dev/null
+++ b/audio/musica/Makefile
@@ -0,0 +1,27 @@
+# New ports collection makefile for: musica
+# Date created: 18 December 2007
+# Whom: Pietro Cerutti <gahr@gahr.ch>
+#
+# $FreeBSD$
+
+PORTNAME= musica
+PORTVERSION= 1.1.4
+CATEGORIES= audio
+MASTER_SITES= http://www-ict.its.tudelft.nl/~erik/open-source/musica/ \
+ http://www.gahr.ch/FreeBSD/musica/
+
+MAINTAINER= gahr@gahr.ch
+COMMENT= GTK based midi player
+
+USE_GNOME= gtk12
+
+GNU_CONFIGURE= yes
+USE_GMAKE= yes
+
+PLIST_FILES= bin/musica
+
+post-patch:
+ ${REINPLACE_CMD} -e 's|char|const char|g' \
+ ${WRKSRC}/src/*.xpm ${WRKSRC}/include/pixmaps.hh
+
+.include <bsd.port.mk>
diff --git a/audio/musica/distinfo b/audio/musica/distinfo
new file mode 100644
index 000000000000..5646cc549567
--- /dev/null
+++ b/audio/musica/distinfo
@@ -0,0 +1,3 @@
+MD5 (musica-1.1.4.tar.gz) = c235cf2e5075f85e419bfb4c9f378b26
+SHA256 (musica-1.1.4.tar.gz) = fc5ed92942a97d16c68168ed4e25c297a581f15d976c112bd160f5a8d41cf621
+SIZE (musica-1.1.4.tar.gz) = 135754
diff --git a/audio/musica/files/patch-src_channel2device.cc b/audio/musica/files/patch-src_channel2device.cc
new file mode 100644
index 000000000000..df657292f5c0
--- /dev/null
+++ b/audio/musica/files/patch-src_channel2device.cc
@@ -0,0 +1,11 @@
+--- src/channel2device.cc.orig 2007-12-18 19:44:10.000000000 +0100
++++ src/channel2device.cc 2007-12-18 19:44:31.000000000 +0100
+@@ -45,7 +45,7 @@
+
+
+
+-static char *deviceType = "channel-to-device";
++static char deviceType[] = "channel-to-device";
+
+
+
diff --git a/audio/musica/files/patch-src_dnd.cc b/audio/musica/files/patch-src_dnd.cc
new file mode 100644
index 000000000000..2cf9a7293de9
--- /dev/null
+++ b/audio/musica/files/patch-src_dnd.cc
@@ -0,0 +1,11 @@
+--- src/dnd.cc.orig 2007-12-18 19:45:04.000000000 +0100
++++ src/dnd.cc 2007-12-18 19:45:56.000000000 +0100
+@@ -221,7 +221,7 @@
+
+ static void makeDropStyles(void)
+ {
+- GdkColor color;
++ GdkColor color = { 0,0,0,0 };
+ int i;
+
+ if(eventBoxDefaultStyle == 0)
diff --git a/audio/musica/files/patch-src_events.cc b/audio/musica/files/patch-src_events.cc
new file mode 100644
index 000000000000..6d6c3d000cfe
--- /dev/null
+++ b/audio/musica/files/patch-src_events.cc
@@ -0,0 +1,37 @@
+--- src/events.cc.orig 1999-06-09 12:14:04.000000000 +0200
++++ src/events.cc 2007-12-18 19:09:20.000000000 +0100
+@@ -30,7 +30,8 @@
+ # include <config.h>
+ #endif
+
+-#include <iostream.h>
++#include <iostream>
++using namespace std;
+
+ #ifdef STDC_HEADERS
+ # include <string.h>
+@@ -267,8 +268,7 @@
+ //
+ //-------------------------------------------------------------------------
+
+-midiMetaTextEvent::midiMetaTextEvent(long int dT = 0L, midiEvent *n = 0,
+- char *t = 0) :
++midiMetaTextEvent::midiMetaTextEvent(long int dT, midiEvent *n, char *t) :
+ midiEvent(dT, n)
+ {
+ if(t == 0)
+@@ -602,10 +602,10 @@
+ //
+ //-------------------------------------------------------------------------
+
+-midiSequencerSpecificEvent::midiSequencerSpecificEvent(long int dT = 0L,
+- midiEvent *n = 0,
+- unsigned char *d = 0,
+- int l = 0) :
++midiSequencerSpecificEvent::midiSequencerSpecificEvent(long int dT,
++ midiEvent *n,
++ unsigned char *d,
++ int l) :
+ midiEvent(dT, n)
+ {
+ if(d == 0)
diff --git a/audio/musica/files/patch-src_gui.cc b/audio/musica/files/patch-src_gui.cc
new file mode 100644
index 000000000000..f0b7eb34555a
--- /dev/null
+++ b/audio/musica/files/patch-src_gui.cc
@@ -0,0 +1,183 @@
+--- src/gui.cc.orig 1999-06-09 12:14:04.000000000 +0200
++++ src/gui.cc 2007-12-18 19:55:33.000000000 +0100
+@@ -31,7 +31,9 @@
+ #endif
+
+ #include <stdio.h>
+-#include <iostream.h>
++#include <iostream>
++using namespace std;
++
+ #include <ctype.h>
+ #include <assert.h>
+
+@@ -101,79 +103,59 @@
+ static GTimer *midiTimer;
+ static gulong currentTime = 0;
+
++static gchar fileEntry[] = "/_File";
++static gchar fileOpenEntry[] = "/File/_Open...";
++static gchar fileSep1Entry[] = "/File/sep1";
++static gchar fileQuitEntry[] = "/File/_Quit";
++static gchar editEntry[] = "/_Edit";
++static gchar editPlayEntry[] = "/Edit/_Play options...";
++static gchar editDevEntry[] = "/Edit/_Device options...";
++static gchar midiEntry[] = "/_Midi";
++static gchar midiNotesOffEntry[] = "/Midi/All notes off";
++static gchar midiResetEntry[] = "/Midi/Reset";
++static gchar helpEntry[] = "/_Help";
++static gchar helpAboutEntry[] = "/Help/_About ...";
++static gchar helpSep1Entry[] = "/Help/sep1";
++static gchar helpCopyEntry[] = "/Help/_Copying ...";
++static gchar branchEntry[] = "<Branch>";
++static gchar lastBranchEntry[] = "<LastBranch>";
++static gchar controlDEntry[] = "<control>D";
++static gchar controlOEntry[] = "<control>O";
++static gchar controlPEntry[] = "<control>P";
++static gchar controlQEntry[] = "<control>Q";
++static gchar separatorEntry[] = "<Separator>";
++
+ static GtkItemFactoryEntry menu_items[] =
+ {
+- {"/_File", 0,
+- 0, 0,
+- "<Branch>"},
+-
+- {"/File/_Open...", "<control>O",
+- GTK_SIGNAL_FUNC(fileOpenCallback), 0,
+- 0},
+-
+- {"/File/sep1", 0,
+- 0, 0,
+- "<Separator>"},
+-
+- {"/File/_Quit", "<control>Q",
+- GTK_SIGNAL_FUNC(gtk_main_quit), 0,
+- 0},
+-
+-
+- {"/_Edit", 0,
+- 0, 0,
+- "<Branch>"},
+-
+- {"/Edit/_Play options...", "<control>P",
+- GTK_SIGNAL_FUNC(optionsPlayCallback), 0,
+- 0},
+-
+- {"/Edit/_Device options...", "<control>D",
+- GTK_SIGNAL_FUNC(optionsDeviceCallback), 0,
+- 0},
+-
+-
+- {"/_Midi", 0,
+- 0, 0,
+- "<Branch>"},
+-
+- {"/Midi/All notes off", 0,
+- 0, 0,
+- 0},
+-
+- {"/Midi/Reset", 0,
+- 0, 0,
+- 0},
+-
+-
+- {"/_Help", 0,
+- 0, 0,
+- "<LastBranch>"},
+-
+- {"/Help/_About ...", 0,
+- GTK_SIGNAL_FUNC(helpAboutCallback), 0,
+- 0},
+-
+- {"/Help/sep1", 0,
+- 0, 0,
+- "<Separator>"},
+-
+- {"/Help/_Copying ...", 0,
+- GTK_SIGNAL_FUNC(helpCopyingCallback), 0,
+- 0}
++ {fileEntry, NULL, NULL, NULL, branchEntry},
++ {fileOpenEntry, controlOEntry, GTK_SIGNAL_FUNC(fileOpenCallback), 0, NULL},
++ {fileSep1Entry, NULL, NULL, 0, separatorEntry},
++ {fileQuitEntry, controlQEntry, GTK_SIGNAL_FUNC(gtk_main_quit), 0, NULL},
++ {editEntry, NULL, NULL, 0, branchEntry},
++ {editPlayEntry, controlPEntry, GTK_SIGNAL_FUNC(optionsPlayCallback), 0, NULL},
++ {editDevEntry, controlDEntry, GTK_SIGNAL_FUNC(optionsDeviceCallback), 0, NULL},
++ {midiEntry, NULL, NULL, NULL, branchEntry},
++ {midiNotesOffEntry, NULL, NULL, 0, NULL},
++ {midiResetEntry, NULL, NULL, 0, NULL},
++ {helpEntry, NULL, NULL, 0, lastBranchEntry},
++ {helpAboutEntry, NULL, GTK_SIGNAL_FUNC(helpAboutCallback), 0, NULL},
++ {helpSep1Entry, NULL, NULL, 0, separatorEntry},
++ {helpCopyEntry, NULL, GTK_SIGNAL_FUNC(helpCopyingCallback), 0, NULL}
+ };
+
++static gchar stringEntry[] = "STRING";
++static gchar textplainEntry[] = "text/plain";
+
+ static GtkTargetEntry target_table[] =
+ {
+- { "STRING", 0, 0 },
+- { "text/plain", 0, 0 }
++ { stringEntry, 0, 0 },
++ { textplainEntry, 0, 0 }
+ };
+
+
+ typedef struct
+ {
+- char **pixmap;
++ const char **pixmap;
+ char *text;
+ char *tooltip_text;
+ GtkSignalFunc callback;
+@@ -181,15 +163,24 @@
+ GtkWidget *widget;
+ } toolbarEntry;
+
++static char rewindEntry[] = "Rewind";
++static char rewindEntryDescr[] = "Rewind MIDI file";
++static char stopEntry[] = "Stop";
++static char stopEntryDescr[] = "Stop playing and shut off all MIDI controllers";
++static char playEntry[] = "Play";
++static char playEntryDescr[] = "Play MIDI file";
++static char pauseEntry[] = "Pause";
++static char pauseEntryDescr[] = "Pause playing";
++static char ffwdEntry[] = "Ffwd";
++static char ffwdEntryDescr[] = "Fast forward";
+
+ static toolbarEntry toolbar_items[] =
+ {
+- { rewind_xpm, "Rewind", "Rewind MIDI file", GTK_SIGNAL_FUNC(rewindCallback), 0, 0},
+- { stop_xpm, "Stop",
+- "Stop playing and shut off all MIDI controllers", GTK_SIGNAL_FUNC(stopCallback), 0, 0},
+- { play_xpm, "Play", "Play MIDI file", GTK_SIGNAL_FUNC(playCallback), 0, 0},
+- { pause_xpm, "Pause", "Pause playing", GTK_SIGNAL_FUNC(pauseCallback), 0, 0},
+- { fastforward_xpm, "Ffwd", "Fast forward", 0, 0, 0}
++ { rewind_xpm, rewindEntry, rewindEntryDescr, GTK_SIGNAL_FUNC(rewindCallback), NULL, NULL},
++ { stop_xpm, stopEntry, stopEntryDescr, GTK_SIGNAL_FUNC(stopCallback), NULL, NULL},
++ { play_xpm, playEntry, playEntryDescr, GTK_SIGNAL_FUNC(playCallback), NULL, NULL},
++ { pause_xpm, pauseEntry, pauseEntryDescr, GTK_SIGNAL_FUNC(pauseCallback), NULL, NULL},
++ { fastforward_xpm, ffwdEntry, ffwdEntryDescr, NULL, NULL, NULL}
+ };
+
+
+@@ -212,7 +203,7 @@
+
+
+
+-GtkWidget *createMainWindow(char *filename = 0)
++GtkWidget *createMainWindow(char *filename)
+ {
+ GtkWidget *mainVbox;
+ GtkWidget *hbox;
+@@ -509,7 +500,7 @@
+ {
+ pmap = gdk_pixmap_create_from_xpm_d(window->window, &mask,
+ &style->bg[GTK_STATE_NORMAL],
+- toolbar_items[i].pixmap);
++ (gchar **)toolbar_items[i].pixmap);
+ pixmap = gtk_pixmap_new(pmap, mask);
+ // FIXME: is this enough to destroy pmap and mask?
+ gdk_pixmap_unref(pmap);
diff --git a/audio/musica/files/patch-src_help.cc b/audio/musica/files/patch-src_help.cc
new file mode 100644
index 000000000000..dc491a011d09
--- /dev/null
+++ b/audio/musica/files/patch-src_help.cc
@@ -0,0 +1,11 @@
+--- src/help.cc.orig 2007-12-18 19:46:20.000000000 +0100
++++ src/help.cc 2007-12-18 19:46:34.000000000 +0100
+@@ -59,7 +59,7 @@
+
+
+
+-static char *copyingText =
++static char copyingText[] =
+ PACKAGE " " VERSION " - a MIDI player\n\n" \
+ "Copyright (C) 1999, Erik Mouw (J.A.K.Mouw@its.tudelft.nl)\n\n" \
+ "This program is free software; you can redistribute it and/or modify " \
diff --git a/audio/musica/files/patch-src_main.cc b/audio/musica/files/patch-src_main.cc
new file mode 100644
index 000000000000..3f9611d0bd4b
--- /dev/null
+++ b/audio/musica/files/patch-src_main.cc
@@ -0,0 +1,29 @@
+--- src/main.cc.orig 2007-12-18 19:46:50.000000000 +0100
++++ src/main.cc 2007-12-18 19:48:06.000000000 +0100
+@@ -59,7 +59,7 @@
+
+
+
+-
++static char deviceName[] = "/dev/sequencer";
+
+ int main(int argc, char *argv[])
+ {
+@@ -79,7 +79,7 @@
+ // create some MIDI devices
+ // first a "real" device: the Roland HP330 on the external MIDI port
+ rolandHp330 = new ossSequencer("External MIDI port");
+- rolandHp330->setDevice("/dev/sequencer", 0);
++ rolandHp330->setDevice(deviceName, 0);
+ rolandHp330->open();
+
+ // map all channels on channel 0 (the default receive channel)
+@@ -98,7 +98,7 @@
+
+ // another "real" device: the EMU 8000 synthesiser on the SB 64 AWE Gold
+ sbAwe64 = new ossSequencer("SB AWE 64");
+- sbAwe64->setDevice("/dev/sequencer", 1);
++ sbAwe64->setDevice(deviceName, 1);
+ sbAwe64->open();
+
+
diff --git a/audio/musica/files/patch-src_ossmidi.cc b/audio/musica/files/patch-src_ossmidi.cc
new file mode 100644
index 000000000000..b8a103af950d
--- /dev/null
+++ b/audio/musica/files/patch-src_ossmidi.cc
@@ -0,0 +1,21 @@
+--- src/ossmidi.cc.orig 2007-12-18 19:48:23.000000000 +0100
++++ src/ossmidi.cc 2007-12-18 19:50:01.000000000 +0100
+@@ -32,7 +32,8 @@
+
+ #include <assert.h>
+
+-#include <iostream.h>
++#include <iostream>
++using namespace std;
+ #include <stdio.h>
+ #include <errno.h>
+
+@@ -63,6 +64,8 @@
+
+ #ifdef HAVE_LINUX_SOUNDCARD_H
+ # include <linux/soundcard.h>
++#else
++# include <sys/soundcard.h>
+ #endif
+
+ #ifdef HAVE_SYS_IOCTL_H
diff --git a/audio/musica/files/patch-src_program2device.cc b/audio/musica/files/patch-src_program2device.cc
new file mode 100644
index 000000000000..e5122f36e434
--- /dev/null
+++ b/audio/musica/files/patch-src_program2device.cc
@@ -0,0 +1,11 @@
+--- src/program2device.cc.orig 2007-12-18 19:56:19.000000000 +0100
++++ src/program2device.cc 2007-12-18 19:56:34.000000000 +0100
+@@ -45,7 +45,7 @@
+
+
+
+-static char *deviceType = "program-to-device";
++static char deviceType[] = "program-to-device";
+
+
+
diff --git a/audio/musica/files/patch-src_readmidi.cc b/audio/musica/files/patch-src_readmidi.cc
new file mode 100644
index 000000000000..b0cb9ab39190
--- /dev/null
+++ b/audio/musica/files/patch-src_readmidi.cc
@@ -0,0 +1,12 @@
+--- src/readmidi.cc.orig 2007-12-18 19:57:34.000000000 +0100
++++ src/readmidi.cc 2007-12-18 19:57:44.000000000 +0100
+@@ -30,7 +30,8 @@
+ # include "config.h"
+ #endif
+
+-#include <iostream.h>
++#include <iostream>
++using namespace std;
+ #include <stdio.h>
+ #include <errno.h>
+
diff --git a/audio/musica/files/patch-src_sequence.cc b/audio/musica/files/patch-src_sequence.cc
new file mode 100644
index 000000000000..bdac8488cbd9
--- /dev/null
+++ b/audio/musica/files/patch-src_sequence.cc
@@ -0,0 +1,13 @@
+--- src/sequence.cc.orig 2007-12-18 19:57:14.000000000 +0100
++++ src/sequence.cc 2007-12-18 19:59:18.000000000 +0100
+@@ -52,8 +52,10 @@
+
+
+
++#ifdef TIMING_DEBUG
+ static long int lastNextTime = 0L;
+ static int lastNextTrack = 0;
++#endif
+
+
+
diff --git a/audio/musica/pkg-descr b/audio/musica/pkg-descr
new file mode 100644
index 000000000000..fa5525bd7e0c
--- /dev/null
+++ b/audio/musica/pkg-descr
@@ -0,0 +1,10 @@
+Musica is a GTK based MIDI player.
+
+- Plays MIDI files on Linux machines with an OSS sound card interface.
+- GTK based user interface supporting drag-and-drop for easy file
+ selection. Drag a MIDI file from the GNOME-ified Midnight Commander
+ to Musica's drop pocket and it automatically loads the file.
+- Tempo adjustment, Play a MIDI file up to four times faster or slower.
+- Fast forward. Skip those dull passages in a MIDI file.
+
+WWW: http://www-ict.its.tudelft.nl/~erik/open-source/musica