diff options
author | Jonathan Scruggs <j.scruggs@gmail.com> | 2016-08-26 15:28:21 +0100 |
---|---|---|
committer | James Le Cuirot <chewi@gentoo.org> | 2016-08-29 22:30:41 +0100 |
commit | 6ed0c1e3e76aed0126175dbe7a9db4dd98782e90 (patch) | |
tree | 2f5124b630592e139831f834e917475903d9b575 /media-sound | |
parent | dev-libs/boost: re-add keywords for mpi multilib ebuild (diff) | |
download | gentoo-6ed0c1e3e76aed0126175dbe7a9db4dd98782e90.tar.gz gentoo-6ed0c1e3e76aed0126175dbe7a9db4dd98782e90.tar.bz2 gentoo-6ed0c1e3e76aed0126175dbe7a9db4dd98782e90.zip |
media-sound/tuxguitar: New package
A multitrack tablature editor and player that allows you to
compose music using the following features:
- Tablature editor
- Score Viewer
- Multitrack display
- Autoscroll while playing
- Note duration management
- Various effects (bend, slide, vibrato, hammer-on/pull-off)
- Support for triplets (5,6,7,9,10,11,12)
- Repeat open and close
- Time signature management
- Tempo management
- Imports and exports gp3,gp4 and gp5 files
Gentoo-Bug: https://bugs.gentoo.org/show_bug.cgi?id=360117
Package-Manager: portage-2.3.0
Signed-off-by: Jonathan Scruggs (j.scruggs@gmail.com)
Closes: https://github.com/gentoo/gentoo/pull/2149
Signed-off-by: James Le Cuirot <chewi@gentoo.org>
Diffstat (limited to 'media-sound')
-rw-r--r-- | media-sound/tuxguitar/Manifest | 1 | ||||
-rw-r--r-- | media-sound/tuxguitar/files/tuxguitar-fixed-ant-files.patch | 237 | ||||
-rw-r--r-- | media-sound/tuxguitar/metadata.xml | 42 | ||||
-rw-r--r-- | media-sound/tuxguitar/tuxguitar-1.3.2.ebuild | 130 |
4 files changed, 410 insertions, 0 deletions
diff --git a/media-sound/tuxguitar/Manifest b/media-sound/tuxguitar/Manifest new file mode 100644 index 000000000000..c687c7d86000 --- /dev/null +++ b/media-sound/tuxguitar/Manifest @@ -0,0 +1 @@ +DIST tuxguitar-1.3.2-src.tar.gz 82294553 SHA256 1295cded91a76e4310648036578a6631faaa7231cd5524786891fbfdc3a0b551 SHA512 fb94472df25578d94ad11cd385cfc9347bfefcdd8ebedd2e785f3645d6b2e0d6d87d3fc457af159865b3fae77ad443ac4246b3c6fbe42397f4d15908dd3b7149 WHIRLPOOL 35e538692ca546d045c607347d57a7f4601f7444753a208065458efc40d24060dfc5aca2d5b3a66869136a42e143676366334c5d49ef6913b2ad15583b2a3e3f diff --git a/media-sound/tuxguitar/files/tuxguitar-fixed-ant-files.patch b/media-sound/tuxguitar/files/tuxguitar-fixed-ant-files.patch new file mode 100644 index 000000000000..9e1cbf778e57 --- /dev/null +++ b/media-sound/tuxguitar/files/tuxguitar-fixed-ant-files.patch @@ -0,0 +1,237 @@ +diff -purN a/TuxGuitar/build.properties b/TuxGuitar/build.properties +--- a/TuxGuitar/build.properties 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar/build.properties 2016-08-23 10:55:06.271917712 +0100 +@@ -5,4 +5,5 @@ ant.build.javac.source=1.5 + ant.build.javac.target=1.5 + + path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar ++path.tuxguitar-editor-utils=../TuxGuitar-editor-utils/tuxguitar-editor-utils.jar + path.swt=../TuxGuitar/lib/swt.jar +diff -purN a/TuxGuitar/build.xml b/TuxGuitar/build.xml +--- a/TuxGuitar/build.xml 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar/build.xml 2016-08-23 08:59:03.987797193 +0100 +@@ -12,6 +12,7 @@ + + <path id="class.path"> + <pathelement location="${path.tuxguitar-lib}"/> ++ <pathelement location="${path.tuxguitar-editor-utils}"/> + <pathelement location="${path.swt}"/> + </path > + +diff -purN a/TuxGuitar-awt-graphics/build.properties b/TuxGuitar-awt-graphics/build.properties +--- a/TuxGuitar-awt-graphics/build.properties 1970-01-01 01:00:00.000000000 +0100 ++++ b/TuxGuitar-awt-graphics/build.properties 2016-08-23 09:11:06.737851049 +0100 +@@ -0,0 +1,7 @@ ++### ANT Flags ++# ++# build.compiler=gcj ++ant.build.javac.source=1.5 ++ant.build.javac.target=1.5 ++ ++path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar +diff -purN a/TuxGuitar-awt-graphics/build.xml b/TuxGuitar-awt-graphics/build.xml +--- a/TuxGuitar-awt-graphics/build.xml 1970-01-01 01:00:00.000000000 +0100 ++++ b/TuxGuitar-awt-graphics/build.xml 2016-08-23 12:40:24.005858183 +0100 +@@ -0,0 +1,45 @@ ++<?xml version="1.0" encoding="iso-8859-1"?> ++ ++<project name="TuxGuitar-awt-graphics" basedir="." default="all"> ++ <description> ++ TuxGuitar AWT Graphics ++ </description> ++ ++ <property file="build.properties" /> ++ <property name="build.src.path" value="src" /> ++ <property name="build.path" value="build" /> ++ <property name="build.jar" value="tuxguitar-awt-graphics.jar" /> ++ ++ <path id="class.path"> ++ <pathelement location="${path.tuxguitar-lib}"/> ++ </path > ++ ++ <target name="init" depends="clean"> ++ <mkdir dir="${build.path}" /> ++ </target> ++ ++ <target name="build" depends="init"> ++ <echo>+-------------------------------------------------+</echo> ++ <echo>| B U I L D I N G P L U G I N |</echo> ++ <echo>+-------------------------------------------------+</echo> ++ ++ <javac srcdir="${build.src.path}" destdir="${build.path}" debug="false" > ++ <classpath refid="class.path"/> ++ <include name="**/*.java"/> ++ </javac> ++ ++ <echo>+-----------------------------------------------+</echo> ++ <echo>| P A C K A G I N G P L U G I N |</echo> ++ <echo>+-----------------------------------------------+</echo> ++ ++ <jar destfile="${build.jar}" basedir="${build.path}" /> ++ <delete quiet="true" dir="${build.path}" /> ++ </target> ++ ++ <target name="clean"> ++ <delete quiet="true" dir="${build.path}" /> ++ <delete quiet="true" file="${build.jar}" /> ++ </target> ++ ++ <target name="all" depends="build" /> ++</project> +diff -purN a/TuxGuitar-editor-utils/build.properties b/TuxGuitar-editor-utils/build.properties +--- a/TuxGuitar-editor-utils/build.properties 1970-01-01 01:00:00.000000000 +0100 ++++ b/TuxGuitar-editor-utils/build.properties 2016-08-23 08:46:42.164749665 +0100 +@@ -0,0 +1,7 @@ ++### ANT Flags ++# ++# build.compiler=gcj ++ant.build.javac.source=1.5 ++ant.build.javac.target=1.5 ++ ++path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar +diff -purN a/TuxGuitar-editor-utils/build.xml b/TuxGuitar-editor-utils/build.xml +--- a/TuxGuitar-editor-utils/build.xml 1970-01-01 01:00:00.000000000 +0100 ++++ b/TuxGuitar-editor-utils/build.xml 2016-08-23 10:51:44.533478977 +0100 +@@ -0,0 +1,45 @@ ++<?xml version="1.0" encoding="iso-8859-1"?> ++ ++<project name="TuxGuitar-editor-utils" basedir="." default="all"> ++ <description> ++ TuxGuitar Editor Utils ++ </description> ++ ++ <property file="build.properties" /> ++ <property name="build.src.path" value="src" /> ++ <property name="build.path" value="build" /> ++ <property name="build.jar" value="tuxguitar-editor-utils.jar" /> ++ ++ <path id="class.path"> ++ <pathelement location="${path.tuxguitar-lib}"/> ++ </path > ++ ++ <target name="init" depends="clean"> ++ <mkdir dir="${build.path}" /> ++ </target> ++ ++ <target name="build" depends="init"> ++ <echo>+-------------------------------------------------+</echo> ++ <echo>| B U I L D I N G L I B R A R Y |</echo> ++ <echo>+-------------------------------------------------+</echo> ++ ++ <javac srcdir="${build.src.path}" destdir="${build.path}" debug="false" > ++ <classpath refid="class.path"/> ++ <include name="**/*.java"/> ++ </javac> ++ ++ <echo>+-----------------------------------------------+</echo> ++ <echo>| P A C K A G I N G L I B R A R Y |</echo> ++ <echo>+-----------------------------------------------+</echo> ++ ++ <jar destfile="${build.jar}" basedir="${build.path}" /> ++ <delete quiet="true" dir="${build.path}" /> ++ </target> ++ ++ <target name="clean"> ++ <delete quiet="true" dir="${build.path}" /> ++ <delete quiet="true" file="${build.jar}" /> ++ </target> ++ ++ <target name="all" depends="build" /> ++</project> +diff -purN a/TuxGuitar-gtp-ui/build.xml b/TuxGuitar-gtp-ui/build.xml +--- a/TuxGuitar-gtp-ui/build.xml 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-gtp-ui/build.xml 2016-08-23 15:21:38.068032721 +0100 +@@ -9,7 +9,7 @@ + <property name="build.src.path" value="src${file.separator}" /> + <property name="build.share.path" value="share${file.separator}" /> + <property name="build.path" value="build${file.separator}" /> +- <property name="build.jar" value="tuxguitar-gtp.jar" /> ++ <property name="build.jar" value="tuxguitar-gtp-ui.jar" /> + + <path id="class.path"> + <pathelement location="${path.tuxguitar-lib}"/> +diff -purN a/TuxGuitar-jsa/build.properties b/TuxGuitar-jsa/build.properties +--- a/TuxGuitar-jsa/build.properties 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-jsa/build.properties 2016-08-23 12:45:00.324325595 +0100 +@@ -7,4 +7,5 @@ ant.build.javac.target=1.5 + path.tuxguitar=../TuxGuitar/tuxguitar.jar + path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar + path.tuxguitar-gm-utils=../TuxGuitar-gm-utils/tuxguitar-gm-utils.jar ++path.tuxguitar-editor-utils=../TuxGuitar-editor-utils/tuxguitar-editor-utils.jar + path.swt=../TuxGuitar/lib/swt.jar +diff -purN a/TuxGuitar-jsa/build.xml b/TuxGuitar-jsa/build.xml +--- a/TuxGuitar-jsa/build.xml 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-jsa/build.xml 2016-08-23 12:46:07.932440095 +0100 +@@ -14,6 +14,7 @@ + <path id="class.path"> + <pathelement location="${path.tuxguitar-lib}"/> + <pathelement location="${path.tuxguitar-gm-utils}"/> ++ <pathelement location="${path.tuxguitar-editor-utils}"/> + <pathelement location="${path.tuxguitar}"/> + <pathelement location="${path.swt}"/> + </path > +diff -purN a/TuxGuitar-pdf/build.properties b/TuxGuitar-pdf/build.properties +--- a/TuxGuitar-pdf/build.properties 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-pdf/build.properties 2016-08-23 13:37:17.230856507 +0100 +@@ -7,5 +7,7 @@ ant.build.javac.target=1.5 + path.tuxguitar=../TuxGuitar/tuxguitar.jar + path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar + path.tuxguitar-gm-utils=../TuxGuitar-gm-utils/tuxguitar-gm-utils.jar ++path.tuxguitar-editor-utils=../TuxGuitar-editor-utils/tuxguitar-editor-utils.jar ++path.tuxguitar-awt-graphics=../TuxGuitar-awt-graphics/tuxguitar-awt-graphics.jar + path.itext=../TuxGuitar/lib/itext.jar + path.swt=../TuxGuitar/lib/swt.jar +diff -purN a/TuxGuitar-pdf/build.xml b/TuxGuitar-pdf/build.xml +--- a/TuxGuitar-pdf/build.xml 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-pdf/build.xml 2016-08-23 13:37:40.843895665 +0100 +@@ -17,6 +17,8 @@ + <pathelement location="${path.tuxguitar}"/> + <pathelement location="${path.tuxguitar-lib}"/> + <pathelement location="${path.tuxguitar-gm-utils}"/> ++ <pathelement location="${path.tuxguitar-editor-utils}"/> ++ <pathelement location="${path.tuxguitar-awt-graphics}"/> + </path > + + <target name="init" depends="clean"> +diff -purN a/TuxGuitar-tray/build.properties b/TuxGuitar-tray/build.properties +--- a/TuxGuitar-tray/build.properties 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-tray/build.properties 2016-08-23 13:41:10.241259782 +0100 +@@ -6,4 +6,6 @@ ant.build.javac.target=1.5 + + path.tuxguitar=../TuxGuitar/tuxguitar.jar + path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar ++path.tuxguitar-gm-utils=../TuxGuitar-gm-utils/tuxguitar-gm-utils.jar ++path.tuxguitar-editor-utils=../TuxGuitar-editor-utils/tuxguitar-editor-utils.jar + path.swt=../TuxGuitar/lib/swt.jar +diff -purN a/TuxGuitar-tray/build.xml b/TuxGuitar-tray/build.xml +--- a/TuxGuitar-tray/build.xml 2016-03-16 21:26:23.000000000 +0000 ++++ b/TuxGuitar-tray/build.xml 2016-08-23 13:41:41.262315895 +0100 +@@ -15,6 +15,8 @@ + <property name="service.provider" value="org.herac.tuxguitar.tray.TGTrayPlugin" /> + + <path id="class.path"> ++ <pathelement location="${path.tuxguitar-editor-utils}"/> ++ <pathelement location="${path.tuxguitar-gm-utils}"/> + <pathelement location="${path.tuxguitar-lib}"/> + <pathelement location="${path.tuxguitar}"/> + <pathelement location="${path.swt}"/> +diff -purN a/TuxGuitar-tuner/build.properties b/TuxGuitar-tuner/build.properties +--- a/TuxGuitar-tuner/build.properties 2016-03-16 21:26:14.000000000 +0000 ++++ b/TuxGuitar-tuner/build.properties 2016-08-23 13:42:25.501396719 +0100 +@@ -6,4 +6,5 @@ ant.build.javac.target=1.5 + + path.tuxguitar=../TuxGuitar/tuxguitar.jar + path.tuxguitar-lib=../TuxGuitar-lib/tuxguitar-lib.jar ++path.tuxguitar-gm-utils=../TuxGuitar-gm-utils/tuxguitar-gm-utils.jar + path.swt=../TuxGuitar/lib/swt.jar +diff -purN a/TuxGuitar-tuner/build.xml b/TuxGuitar-tuner/build.xml +--- a/TuxGuitar-tuner/build.xml 2016-03-16 21:26:14.000000000 +0000 ++++ b/TuxGuitar-tuner/build.xml 2016-08-23 13:42:50.180442190 +0100 +@@ -12,6 +12,7 @@ + <property name="build.jar" value="tuxguitar-tuner.jar" /> + + <path id="class.path"> ++ <pathelement location="${path.tuxguitar-gm-utils}"/> + <pathelement location="${path.tuxguitar-lib}"/> + <pathelement location="${path.tuxguitar}"/> + <pathelement location="${path.swt}"/> diff --git a/media-sound/tuxguitar/metadata.xml b/media-sound/tuxguitar/metadata.xml new file mode 100644 index 000000000000..67a86a3f2fe2 --- /dev/null +++ b/media-sound/tuxguitar/metadata.xml @@ -0,0 +1,42 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd"> +<pkgmetadata> + <maintainer type="person"> + <email>j.scruggs@gmail.com</email> + <name>Jonathan Scruggs</name> + </maintainer> + <maintainer type="project"> + <email>proxy-maint@gentoo.org</email> + <name>Proxy Maintainers</name> + </maintainer> + <longdescription> + A multitrack tablature editor and player that allows you to + compose music using the following features: + - Tablature editor + - Score Viewer + - Multitrack display + - Autoscroll while playing + - Note duration management + - Various effects (bend, slide, vibrato, hammer-on/pull-off) + - Support for triplets (5,6,7,9,10,11,12) + - Repeat open and close + - Time signature management + - Tempo management + - Imports and exports gp3,gp4 and gp5 files + </longdescription> + <use> + <flag name="fluidsynth"> + Enables Fluidsynth MIDI software synthesis (with external sound fonts). + JSA must be disabled in the plug-ins menu to use this. + </flag> + <flag name="lilypond"> + Exports the score in a lilypond compatible format. + </flag> + <flag name="pdf"> + Exports the score as a PDF file using <pkg>dev-java/itext</pkg>. + </flag> + <flag name="tray"> + Adds an icon to the tray that controls midi playback. + </flag> + </use> +</pkgmetadata> diff --git a/media-sound/tuxguitar/tuxguitar-1.3.2.ebuild b/media-sound/tuxguitar/tuxguitar-1.3.2.ebuild new file mode 100644 index 000000000000..001b67cc0c2d --- /dev/null +++ b/media-sound/tuxguitar/tuxguitar-1.3.2.ebuild @@ -0,0 +1,130 @@ +# Copyright 1999-2016 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $id$ + +EAPI="6" +JAVA_PKG_IUSE="source" + +inherit eutils java-pkg-2 java-ant-2 toolchain-funcs flag-o-matic fdo-mime gnome2-utils + +MY_P="${P}-src" +DESCRIPTION="TuxGuitar is a multitrack guitar tablature editor and player written in Java-SWT" +HOMEPAGE="http://tuxguitar.herac.com.ar/" +SRC_URI="mirror://sourceforge/${PN}/${MY_P}.tar.gz" +LICENSE="LGPL-2.1" +SLOT="0" + +IUSE="alsa fluidsynth jack lilypond oss pdf timidity tray" + +KEYWORDS="~amd64 ~x86" + +CDEPEND="dev-java/swt:3.7[cairo] + alsa? ( media-libs/alsa-lib ) + pdf? ( dev-java/itext:5 ) + fluidsynth? ( media-sound/fluidsynth ) + lilypond? ( media-sound/lilypond )" + +RDEPEND=">=virtual/jre-1.5 + timidity? ( media-sound/timidity++[alsa?,oss?] ) + ${CDEPEND}" + +DEPEND=">=virtual/jdk-1.5 + ${CDEPEND}" + +S="${WORKDIR}/${MY_P}" + +PATCHES=( "${FILESDIR}"/${PN}-fixed-ant-files.patch ) + +LIBRARY_LIST=() +PLUGIN_LIST=() + +src_prepare() { + java-pkg-2_src_prepare + default_src_prepare + + sed -e "s|../TuxGuitar/lib/swt.jar|$(java-pkg_getjar swt-3.7 swt.jar)|" \ + -i TuxGuitar*/build.properties || die "sed TuxGuitar*/build.properties failed" + + if use pdf; then + sed -e "s|../TuxGuitar/lib/itext.jar|$(java-pkg_getjar itext-5 itext.jar)|" \ + -i TuxGuitar-pdf/build.properties || die "sed TuxGuitar-pdf/build.properties failed" + fi + + LIBRARY_LIST=( TuxGuitar-lib TuxGuitar-awt-graphics TuxGuitar-editor-utils + TuxGuitar-gm-utils TuxGuitar + ) + + PLUGIN_LIST=( $(usev alsa) ascii browser-ftp community compat + converter $(usev fluidsynth) gm-settings gpx gtp gtp-ui image + $(usev jack) $(usex jack jack-ui "") jsa $(usev lilypond) midi + musicxml $(usev oss) $(usev pdf) ptb svg tef $(usev tray) tuner + ) +} + +src_compile() { + local build_order=( ${LIBRARY_LIST[@]} ${PLUGIN_LIST[@]/#/TuxGuitar-} ) + local directory + + for directory in ${build_order[@]}; do + cd "${S}"/${directory} || die "cd ${directory} failed" + eant + if [[ -d jni ]]; then + append-flags -fPIC $(java-pkg_get-jni-cflags) + CC=$(tc-getCC) emake -C jni + fi + done +} + +src_install() { + local tuxguitar_inst_path="/usr/share/${PN}" + local library + local plugin + + for library in ${LIBRARY_LIST[@]}; do + cd "${S}"/${library} || die "cd ${library} failed" + java-pkg_dojar ${library,,}.jar + use source && java-pkg_dosrc src/org + done + + java-pkg_dolauncher ${PN} \ + --main org.herac.tuxguitar.app.TGMainSingleton \ + --java_args "-Xmx512m -Dtuxguitar.share.path=${tuxguitar_inst_path}/share" + + # Images and Files + insinto ${tuxguitar_inst_path} + doins -r share + + java-pkg_sointo ${tuxguitar_inst_path}/lib + insinto ${tuxguitar_inst_path}/share/plugins + for plugin in ${PLUGIN_LIST[@]/#/TuxGuitar-}; do + cd "${S}"/${plugin} || die "cd ${plugin} failed" + doins ${plugin,,}.jar + + #TuxGuitar has its own classloader. No need to register the plugins. + if [[ -d jni ]]; then + java-pkg_doso jni/lib${plugin,,}-jni.so + fi + done + + insinto ${tuxguitar_inst_path}/share + doins -r "${S}"/TuxGuitar-resources/resources/soundfont + doman "${S}/misc/${PN}.1" + insinto /usr/share/mime/packages + doins "${S}/misc/${PN}.xml" + doicon "${S}/misc/${PN}.xpm" + domenu "${S}/misc/${PN}.desktop" +} + +pkg_postinst() { + fdo-mime_desktop_database_update + gnome2_icon_cache_update + if use fluidsynth; then + ewarn "Fluidsynth plugin blocks behavior of JSA plugin." + ewarn "Enable only one of them in \"Tools > Plugins\"" + fi +} + +pkg_postrm() { + fdo-mime_desktop_database_update + gnome2_icon_cache_update +} |