36ab794bb7
The sip path option was missing from the sip keg. This broke py2app. Closes Homebrew/homebrew#12388.
101 lines
3.4 KiB
Ruby
101 lines
3.4 KiB
Ruby
require 'formula'
|
|
|
|
# NOTE TO MAINTAINERS:
|
|
#
|
|
# Unless Riverbank policy changes in the future or the Mercurial archive
|
|
# becomes unavailable, *do not use* the SIP download URL from the Riverbank
|
|
# website. This URL will break as soon as a new version of SIP is released
|
|
# which causes panic and terror to flood the Homebrew issue tracker.
|
|
|
|
class Sip < Formula
|
|
homepage 'http://www.riverbankcomputing.co.uk/software/sip'
|
|
url 'http://www.riverbankcomputing.co.uk/hg/sip/archive/4.13.3.tar.gz'
|
|
sha1 '672f0bd9c13860979ab2a7753b2bf91475a4deeb'
|
|
|
|
head 'http://www.riverbankcomputing.co.uk/hg/sip', :using => :hg
|
|
|
|
def patches
|
|
DATA
|
|
end
|
|
|
|
def install
|
|
if ARGV.build_head?
|
|
# Set fallback version to the same value it would have without the patch
|
|
# and link the Mercurial repository into the download directory so
|
|
# buid.py can use it to figure out a version number.
|
|
sip_version = "0.1.0"
|
|
ln_s downloader.cached_location + '.hg', '.hg'
|
|
else
|
|
sip_version = version
|
|
end
|
|
inreplace 'build.py', /@SIP_VERSION@/, (sip_version.gsub '.', ',')
|
|
|
|
system "python", "build.py", "prepare"
|
|
# Set --destdir such that the python modules will be in the HOMEBREWPREFIX/lib/pythonX.Y/site-packages
|
|
system "python", "configure.py",
|
|
"--destdir=#{lib}/#{which_python}/site-packages",
|
|
"--bindir=#{bin}",
|
|
"--incdir=#{include}",
|
|
"--sipdir=#{HOMEBREW_PREFIX}/share/sip",
|
|
"CFLAGS=#{ENV.cflags}",
|
|
"LFLAGS=#{ENV.ldflags}"
|
|
system "make install"
|
|
end
|
|
|
|
def caveats; <<-EOS.undent
|
|
For non-homebrew Python, you need to amend your PYTHONPATH like so:
|
|
export PYTHONPATH=#{HOMEBREW_PREFIX}/lib/#{which_python}/site-packages:$PYTHONPATH
|
|
EOS
|
|
end
|
|
|
|
def which_python
|
|
"python" + `python -c 'import sys;print(sys.version[:3])'`.strip
|
|
end
|
|
end
|
|
|
|
|
|
__END__
|
|
Patch to allow the SIP build.py script to generate a reasonable version number
|
|
for installing from a Mercurial snapshot without the .hg directory from the
|
|
Mercurial repository. The install code hooks on to the @SIP_VERSION@ tag and
|
|
inserts a real version tuple
|
|
|
|
diff --git a/build.py b/build.py
|
|
index 927d7f1..fdf13a3 100755
|
|
--- a/build.py
|
|
+++ b/build.py
|
|
@@ -179,7 +179,7 @@ def _get_release():
|
|
changelog = None
|
|
name = os.path.basename(_RootDir)
|
|
|
|
- release_suffix = "-unknown"
|
|
+ release_suffix = ""
|
|
version = None
|
|
|
|
parts = name.split('-')
|
|
@@ -192,7 +192,7 @@ def _get_release():
|
|
|
|
# Format the results.
|
|
if version is None:
|
|
- version = (0, 1, 0)
|
|
+ version = (@SIP_VERSION@)
|
|
|
|
major, minor, micro = version
|
|
|
|
|
|
Patch to remove the seemingly unnecessary framework build requirement
|
|
diff --git a/siputils.py b/siputils.py
|
|
index 57e8911..1af6152 100644
|
|
--- a/siputils.py
|
|
+++ b/siputils.py
|
|
@@ -1434,8 +1434,8 @@ class ModuleMakefile(Makefile):
|
|
# 'real_prefix' exists if virtualenv is being used.
|
|
dl = getattr(sys, 'real_prefix', sys.exec_prefix).split(os.sep)
|
|
|
|
- if "Python.framework" not in dl:
|
|
- error("SIP requires Python to be built as a framework")
|
|
+ # if "Python.framework" not in dl:
|
|
+ # error("SIP requires Python to be built as a framework")
|
|
|
|
self.LFLAGS.append("-undefined dynamic_lookup")
|
|
|