aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Formula
diff options
context:
space:
mode:
authorDominyk Tiller2014-11-05 04:59:31 +0000
committerMike McQuaid2014-11-06 08:53:23 +0000
commit67ab25fd88cbd7778e73897095cf6e949db12f44 (patch)
treea721c2cd1963a8d1f1071ee71d8e826737fb35fe /Library/Formula
parent71d2816c9ecdfae8e08042cb31b45b61a5953db9 (diff)
downloadhomebrew-67ab25fd88cbd7778e73897095cf6e949db12f44.tar.bz2
mat: general cleanup.
Modernizes the MAT formula a little, especially around the handling of the Python elements. Closes #33923.
Diffstat (limited to 'Library/Formula')
-rw-r--r--Library/Formula/mat.rb91
1 files changed, 50 insertions, 41 deletions
diff --git a/Library/Formula/mat.rb b/Library/Formula/mat.rb
index 2fa41f1e5..38f33e9d7 100644
--- a/Library/Formula/mat.rb
+++ b/Library/Formula/mat.rb
@@ -1,8 +1,8 @@
require "formula"
-# OSX has case-insensitive file names, and the Mat archive contains a 'MAT'
-# directory *and* a 'mat' file. `tar xf` will fail on it, so we rename 'mat'
-# into 'mat-cli' here.
+# OSX has case-insensitive file names, and the Mat archive contains a "MAT"
+# directory *and* a "mat" file. `tar xf` will fail on it, so we rename "mat"
+# into "mat-cli" here.
class MatDownloadStrategy < CurlDownloadStrategy
def stage
if tarball_path.compression_type == :xz
@@ -21,70 +21,79 @@ class Mat < Formula
url "https://mat.boum.org/files/mat-0.5.2.tar.xz", :using => MatDownloadStrategy
sha1 "932ac13863c994ca8874e3271f817efd879e28c3"
- depends_on :python
- depends_on 'coreutils'
- depends_on 'poppler'
- depends_on 'intltool' => :build
- depends_on 'gettext' => :build
+ depends_on :python => :optional
+ depends_on "coreutils"
+ depends_on "poppler"
+ depends_on "intltool" => :build
+ depends_on "gettext" => :build
- depends_on 'exiftool' => :optional
+ depends_on "exiftool" => :optional
- option 'with-massive-audio', 'Enable massive audio format support'
+ option "with-massive-audio", "Enable massive audio format support"
# mat relies on `shred`, which is called `gshred` on OSX with coreutils, and
- # import the 'gi' python module which is not available here.
+ # import the "gi" python module which is not available here.
# Fixed upstream for next version.
patch :DATA
- resource 'hachoir-core' do
- url 'https://pypi.python.org/packages/source/h/hachoir-core/hachoir-core-1.3.3.tar.gz'
- sha1 'e1d3b5da7d57087c922942b7653cb3b195c7769f'
+ resource "hachoir-core" do
+ url "https://pypi.python.org/packages/source/h/hachoir-core/hachoir-core-1.3.3.tar.gz"
+ sha1 "e1d3b5da7d57087c922942b7653cb3b195c7769f"
end
- resource 'hachoir-parser' do
- url 'https://pypi.python.org/packages/source/h/hachoir-parser/hachoir-parser-1.3.4.tar.gz'
- sha1 '8433e1598b1e8d9404e6978117a203775e68c075'
+ resource "hachoir-parser" do
+ url "https://pypi.python.org/packages/source/h/hachoir-parser/hachoir-parser-1.3.4.tar.gz"
+ sha1 "8433e1598b1e8d9404e6978117a203775e68c075"
end
- resource 'pdfrw' do
- url 'https://pypi.python.org/packages/source/p/pdfrw/pdfrw-0.1.tar.gz'
- sha1 '9824ad502ecb2bf093fd8727fd7fa2b524140e41'
+ resource "pdfrw" do
+ url "https://pypi.python.org/packages/source/p/pdfrw/pdfrw-0.1.tar.gz"
+ sha1 "9824ad502ecb2bf093fd8727fd7fa2b524140e41"
end
- resource 'distutils-extra' do
- url 'https://launchpad.net/python-distutils-extra/trunk/2.38/+download/python-distutils-extra-2.38.tar.gz'
- sha1 'db9ac81daf3e069b8838ae6d379abac2f0094663'
+ resource "distutils-extra" do
+ url "https://launchpad.net/python-distutils-extra/trunk/2.38/+download/python-distutils-extra-2.38.tar.gz"
+ sha1 "db9ac81daf3e069b8838ae6d379abac2f0094663"
end
- resource 'mutagen' do
- url 'https://pypi.python.org/packages/source/m/mutagen/mutagen-1.22.tar.gz'
- sha1 '9bdd4a7a491008e62d140d83fc31d355577f94e7'
+ resource "mutagen" do
+ url "https://pypi.python.org/packages/source/m/mutagen/mutagen-1.22.tar.gz"
+ sha1 "9bdd4a7a491008e62d140d83fc31d355577f94e7"
end
def install
- ENV.prepend_create_path 'PYTHONPATH', libexec/'lib/python2.7/site-packages'
- install_args = [ "setup.py", "install", "--prefix=#{libexec}" ]
-
- resource('hachoir-core').stage { system "python", *install_args }
- resource('hachoir-parser').stage { system "python", *install_args }
- resource('pdfrw').stage { system "python", *install_args }
- resource('distutils-extra').stage { system "python", *install_args }
- if build.with? 'massive-audio'
- resource('mutagen').stage { system "python", *install_args }
+ ENV["PYTHONPATH"] = lib+"python2.7/site-packages"
+ ENV.prepend_create_path "PYTHONPATH", libexec+"lib/python2.7/site-packages"
+
+ %w[hachoir-core hachoir-parser pdfrw distutils-extra].each do |r|
+ resource(r).stage do
+ pyargs = ["setup.py", "install", "--prefix=#{libexec}"]
+ unless %w[hachoir-core hachoir-parser pdfrw].include? r
+ pyargs << "--single-version-externally-managed" << "--record=installed.txt"
+ end
+ system "python", *pyargs
+ end
end
- inreplace 'setup.py' do |s|
- s.gsub!("'mat'", "'mat-cli'")
+ if build.with? "massive-audio"
+ resource("mutagen").stage do
+ system "python", "setup.py", "install", "--prefix=#{libexec}"
+ end
end
+ # Installs Mat as mat-cli temporarily
+ inreplace "setup.py", "'mat'", "'mat-cli'"
+
system "python", "setup.py", "install", "--prefix=#{prefix}"
# move executable back to its real name
- mv bin/'mat-cli', bin/'mat'
-
- man1.install Dir['*.1']
+ mv bin/"mat-cli", bin/"mat"
+ # Since we don't support it, Let's remove the GUI binary.
+ rm bin/"mat-gui"
+ # Install manpages into expected directory.
+ man1.install Dir["*.1"]
- bin.env_script_all_files(libexec/'bin', :PYTHONPATH => ENV['PYTHONPATH'])
+ bin.env_script_all_files(libexec+"bin", :PYTHONPATH => ENV["PYTHONPATH"])
end
test do