python 3.6.4
renamed from python3 Also, install unversioned symlinks "python", "python-config", "pip" etc. pointing to "python3", "python3-config", "pip3" etc., respectively.
This commit is contained in:
parent
57cd0561a8
commit
788b65e645
5 changed files with 186 additions and 576 deletions
1
Aliases/python3
Symbolic link
1
Aliases/python3
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../Formula/python.rb
|
|
@ -1 +1 @@
|
||||||
../Formula/python3.rb
|
../Formula/python.rb
|
|
@ -1,10 +1,10 @@
|
||||||
class Python < Formula
|
class Python < Formula
|
||||||
desc "Interpreted, interactive, object-oriented programming language"
|
desc "Interpreted, interactive, object-oriented programming language"
|
||||||
homepage "https://www.python.org/"
|
homepage "https://www.python.org/"
|
||||||
url "https://www.python.org/ftp/python/2.7.14/Python-2.7.14.tar.xz"
|
url "https://www.python.org/ftp/python/3.6.4/Python-3.6.4.tar.xz"
|
||||||
sha256 "71ffb26e09e78650e424929b2b457b9c912ac216576e6bd9e7d204ed03296a66"
|
sha256 "159b932bf56aeaa76fd66e7420522d8c8853d486b8567c459b84fe2ed13bcaba"
|
||||||
revision 3
|
revision 3
|
||||||
head "https://github.com/python/cpython.git", :branch => "2.7"
|
head "https://github.com/python/cpython.git"
|
||||||
|
|
||||||
bottle do
|
bottle do
|
||||||
sha256 "4e05897c538937126494a2e611e109e95e761a333dc1911e4ea77171f7cf2e4d" => :high_sierra
|
sha256 "4e05897c538937126494a2e611e109e95e761a333dc1911e4ea77171f7cf2e4d" => :high_sierra
|
||||||
|
@ -12,19 +12,15 @@ class Python < Formula
|
||||||
sha256 "bd8cbaf020a476bfd53c75538244520b7713554feafeac3f0d454f8fb92c1293" => :el_capitan
|
sha256 "bd8cbaf020a476bfd53c75538244520b7713554feafeac3f0d454f8fb92c1293" => :el_capitan
|
||||||
end
|
end
|
||||||
|
|
||||||
# Please don't add a wide/ucs4 option as it won't be accepted.
|
devel do
|
||||||
# More details in: https://github.com/Homebrew/homebrew/pull/32368
|
url "https://www.python.org/ftp/python/3.7.0/Python-3.7.0b1.tar.xz"
|
||||||
option "with-quicktest", "Run `make quicktest` after the build (for devs; may fail)"
|
sha256 "2bee6320443ab475ecc9ee8b36e96230787eb12cdb336e3079dceef23039b970"
|
||||||
option "with-tcl-tk", "Use Homebrew's Tk instead of macOS Tk (has optional Cocoa and threads support)"
|
|
||||||
option "with-poll", "Enable select.poll, which is not fully implemented on macOS (https://bugs.python.org/issue5154)"
|
|
||||||
|
|
||||||
# sphinx-doc depends on python, but on 10.6 or earlier python is fulfilled by
|
|
||||||
# brew, which would lead to circular dependency.
|
|
||||||
if MacOS.version > :snow_leopard
|
|
||||||
option "with-sphinx-doc", "Build HTML documentation"
|
|
||||||
depends_on "sphinx-doc" => [:build, :optional]
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
option "with-tcl-tk", "Use Homebrew's Tk instead of macOS Tk (has optional Cocoa and threads support)"
|
||||||
|
option "with-quicktest", "Run `make quicktest` after the build"
|
||||||
|
option "with-sphinx-doc", "Build HTML documentation"
|
||||||
|
|
||||||
deprecated_option "quicktest" => "with-quicktest"
|
deprecated_option "quicktest" => "with-quicktest"
|
||||||
deprecated_option "with-brewed-tk" => "with-tcl-tk"
|
deprecated_option "with-brewed-tk" => "with-tcl-tk"
|
||||||
|
|
||||||
|
@ -33,12 +29,16 @@ class Python < Formula
|
||||||
depends_on "sqlite" => :recommended
|
depends_on "sqlite" => :recommended
|
||||||
depends_on "gdbm" => :recommended
|
depends_on "gdbm" => :recommended
|
||||||
depends_on "openssl"
|
depends_on "openssl"
|
||||||
|
depends_on "xz" => :recommended # for the lzma module added in 3.3
|
||||||
depends_on "tcl-tk" => :optional
|
depends_on "tcl-tk" => :optional
|
||||||
depends_on "berkeley-db@4" => :optional
|
depends_on "sphinx-doc" => [:build, :optional]
|
||||||
|
|
||||||
|
skip_clean "bin/pip3", "bin/pip-3.4", "bin/pip-3.5", "bin/pip-3.6"
|
||||||
|
skip_clean "bin/easy_install3", "bin/easy_install-3.4", "bin/easy_install-3.5", "bin/easy_install-3.6"
|
||||||
|
|
||||||
resource "setuptools" do
|
resource "setuptools" do
|
||||||
url "https://files.pythonhosted.org/packages/a4/c8/9a7a47f683d54d83f648d37c3e180317f80dc126a304c45dc6663246233a/setuptools-36.5.0.zip"
|
url "https://files.pythonhosted.org/packages/6c/54/f7e9cea6897636a04e74c3954f0d8335cc38f7d01e27eec98026b049a300/setuptools-38.5.1.zip"
|
||||||
sha256 "ce2007c1cea3359870b80657d634253a0765b0c7dc5a988d77ba803fc86f2c64"
|
sha256 "6425484c08e99a98a42209c25c3d325f749230b55284d66192784f941a7e6628"
|
||||||
end
|
end
|
||||||
|
|
||||||
resource "pip" do
|
resource "pip" do
|
||||||
|
@ -51,27 +51,15 @@ class Python < Formula
|
||||||
sha256 "9515fe0a94e823fd90b08d22de45d7bde57c90edce705b22f5e1ecf7e1b653c8"
|
sha256 "9515fe0a94e823fd90b08d22de45d7bde57c90edce705b22f5e1ecf7e1b653c8"
|
||||||
end
|
end
|
||||||
|
|
||||||
# Patch to disable the search for Tk.framework, since Homebrew's Tk is
|
fails_with :clang do
|
||||||
# a plain unix build. Remove `-lX11`, too because our Tk is "AquaTk".
|
build 425
|
||||||
if build.with? "tcl-tk"
|
cause "https://bugs.python.org/issue24844"
|
||||||
patch do
|
|
||||||
url "https://raw.githubusercontent.com/Homebrew/patches/42fcf22/python/brewed-tk-patch.diff"
|
|
||||||
sha256 "15c153bdfe51a98efe48f8e8379f5d9b5c6c4015e53d3f9364d23c8689857f09"
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def lib_cellar
|
# Homebrew's tcl-tk is built in a standard unix fashion (due to link errors)
|
||||||
prefix/"Frameworks/Python.framework/Versions/2.7/lib/python2.7"
|
# so we have to stop python from searching for frameworks and linking against
|
||||||
end
|
# X11.
|
||||||
|
patch :DATA if build.with? "tcl-tk"
|
||||||
def site_packages_cellar
|
|
||||||
lib_cellar/"site-packages"
|
|
||||||
end
|
|
||||||
|
|
||||||
# The HOMEBREW_PREFIX location of site-packages.
|
|
||||||
def site_packages
|
|
||||||
HOMEBREW_PREFIX/"lib/python2.7/site-packages"
|
|
||||||
end
|
|
||||||
|
|
||||||
# setuptools remembers the build flags python is built with and uses them to
|
# setuptools remembers the build flags python is built with and uses them to
|
||||||
# build packages later. Xcode-only systems need different flags.
|
# build packages later. Xcode-only systems need different flags.
|
||||||
|
@ -85,17 +73,14 @@ class Python < Formula
|
||||||
end
|
end
|
||||||
|
|
||||||
def install
|
def install
|
||||||
ENV.permit_weak_imports
|
|
||||||
|
|
||||||
if build.with? "poll"
|
|
||||||
opoo "The given option --with-poll enables a somewhat broken poll() on macOS (https://bugs.python.org/issue5154)."
|
|
||||||
end
|
|
||||||
|
|
||||||
# Unset these so that installing pip and setuptools puts them where we want
|
# Unset these so that installing pip and setuptools puts them where we want
|
||||||
# and not into some other Python the user has installed.
|
# and not into some other Python the user has installed.
|
||||||
ENV["PYTHONHOME"] = nil
|
ENV["PYTHONHOME"] = nil
|
||||||
ENV["PYTHONPATH"] = nil
|
ENV["PYTHONPATH"] = nil
|
||||||
|
|
||||||
|
xy = (buildpath/"configure.ac").read.slice(/PYTHON_VERSION, (3\.\d)/, 1)
|
||||||
|
lib_cellar = prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}"
|
||||||
|
|
||||||
args = %W[
|
args = %W[
|
||||||
--prefix=#{prefix}
|
--prefix=#{prefix}
|
||||||
--enable-ipv6
|
--enable-ipv6
|
||||||
|
@ -103,18 +88,11 @@ class Python < Formula
|
||||||
--datadir=#{share}
|
--datadir=#{share}
|
||||||
--enable-framework=#{frameworks}
|
--enable-framework=#{frameworks}
|
||||||
--without-ensurepip
|
--without-ensurepip
|
||||||
|
--with-dtrace
|
||||||
]
|
]
|
||||||
|
|
||||||
# See upstream bug report from 22 Jan 2018 "Significant performance problems
|
|
||||||
# with Python 2.7 built with clang 3.x or 4.x"
|
|
||||||
# https://bugs.python.org/issue32616
|
|
||||||
# https://github.com/Homebrew/homebrew-core/issues/22743
|
|
||||||
if DevelopmentTools.clang_build_version >= 802 &&
|
|
||||||
DevelopmentTools.clang_build_version < 1000
|
|
||||||
args << "--without-computed-gotos"
|
|
||||||
end
|
|
||||||
|
|
||||||
args << "--without-gcc" if ENV.compiler == :clang
|
args << "--without-gcc" if ENV.compiler == :clang
|
||||||
|
args << "--enable-loadable-sqlite-extensions" if build.with?("sqlite")
|
||||||
|
|
||||||
cflags = []
|
cflags = []
|
||||||
ldflags = []
|
ldflags = []
|
||||||
|
@ -131,17 +109,19 @@ class Python < Formula
|
||||||
cflags << "-I#{MacOS.sdk_path}/System/Library/Frameworks/Tk.framework/Versions/8.5/Headers"
|
cflags << "-I#{MacOS.sdk_path}/System/Library/Frameworks/Tk.framework/Versions/8.5/Headers"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
# Avoid linking to libgcc https://mail.python.org/pipermail/python-dev/2012-February/116205.html
|
||||||
# Avoid linking to libgcc https://code.activestate.com/lists/python-dev/112195/
|
|
||||||
args << "MACOSX_DEPLOYMENT_TARGET=#{MacOS.version}"
|
args << "MACOSX_DEPLOYMENT_TARGET=#{MacOS.version}"
|
||||||
|
|
||||||
# We want our readline and openssl! This is just to outsmart the detection code,
|
# We want our readline! This is just to outsmart the detection code,
|
||||||
# superenv handles that cc finds includes/libs!
|
# superenv makes cc always find includes/libs!
|
||||||
inreplace "setup.py" do |s|
|
inreplace "setup.py",
|
||||||
s.gsub! "do_readline = self.compiler.find_library_file(lib_dirs, 'readline')",
|
"do_readline = self.compiler.find_library_file(lib_dirs, 'readline')",
|
||||||
"do_readline = '#{Formula["readline"].opt_lib}/libhistory.dylib'"
|
"do_readline = '#{Formula["readline"].opt_lib}/libhistory.dylib'"
|
||||||
s.gsub! "/usr/local/ssl", Formula["openssl"].opt_prefix
|
|
||||||
s.gsub! "/usr/include/db4", Formula["berkeley-db@4"].opt_include
|
if build.stable?
|
||||||
|
inreplace "setup.py", "/usr/local/ssl", Formula["openssl"].opt_prefix
|
||||||
|
else
|
||||||
|
args << "--with-openssl=#{Formula["openssl"].opt_prefix}"
|
||||||
end
|
end
|
||||||
|
|
||||||
if build.with? "sqlite"
|
if build.with? "sqlite"
|
||||||
|
@ -149,16 +129,12 @@ class Python < Formula
|
||||||
s.gsub! "sqlite_setup_debug = False", "sqlite_setup_debug = True"
|
s.gsub! "sqlite_setup_debug = False", "sqlite_setup_debug = True"
|
||||||
s.gsub! "for d_ in inc_dirs + sqlite_inc_paths:",
|
s.gsub! "for d_ in inc_dirs + sqlite_inc_paths:",
|
||||||
"for d_ in ['#{Formula["sqlite"].opt_include}']:"
|
"for d_ in ['#{Formula["sqlite"].opt_include}']:"
|
||||||
|
|
||||||
# Allow sqlite3 module to load extensions:
|
|
||||||
# https://docs.python.org/library/sqlite3.html#f1
|
|
||||||
s.gsub! 'sqlite_defines.append(("SQLITE_OMIT_LOAD_EXTENSION", "1"))', ""
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Allow python modules to use ctypes.find_library to find homebrew's stuff
|
# Allow python modules to use ctypes.find_library to find homebrew's stuff
|
||||||
# even if homebrew is not a /usr/local/lib. Try this with:
|
# even if homebrew is not a /usr/local/lib. Try this with:
|
||||||
# `brew install enchant && pip2 install pyenchant`
|
# `brew install enchant && pip install pyenchant`
|
||||||
inreplace "./Lib/ctypes/macholib/dyld.py" do |f|
|
inreplace "./Lib/ctypes/macholib/dyld.py" do |f|
|
||||||
f.gsub! "DEFAULT_LIBRARY_FALLBACK = [", "DEFAULT_LIBRARY_FALLBACK = [ '#{HOMEBREW_PREFIX}/lib',"
|
f.gsub! "DEFAULT_LIBRARY_FALLBACK = [", "DEFAULT_LIBRARY_FALLBACK = [ '#{HOMEBREW_PREFIX}/lib',"
|
||||||
f.gsub! "DEFAULT_FRAMEWORK_FALLBACK = [", "DEFAULT_FRAMEWORK_FALLBACK = [ '#{HOMEBREW_PREFIX}/Frameworks',"
|
f.gsub! "DEFAULT_FRAMEWORK_FALLBACK = [", "DEFAULT_FRAMEWORK_FALLBACK = [ '#{HOMEBREW_PREFIX}/Frameworks',"
|
||||||
|
@ -176,79 +152,73 @@ class Python < Formula
|
||||||
|
|
||||||
system "./configure", *args
|
system "./configure", *args
|
||||||
|
|
||||||
# HAVE_POLL is "broken" on macOS. See:
|
|
||||||
# https://trac.macports.org/ticket/18376
|
|
||||||
# https://bugs.python.org/issue5154
|
|
||||||
if build.without? "poll"
|
|
||||||
inreplace "pyconfig.h", /.*?(HAVE_POLL[_A-Z]*).*/, '#undef \1'
|
|
||||||
end
|
|
||||||
|
|
||||||
system "make"
|
system "make"
|
||||||
if build.with?("quicktest") || build.bottle?
|
if build.with?("quicktest")
|
||||||
system "make", "quicktest", "TESTPYTHONOPTS=-s", "TESTOPTS=-j#{ENV.make_jobs} -w"
|
system "make", "quicktest", "TESTPYTHONOPTS=-s", "TESTOPTS=-j#{ENV.make_jobs} -w"
|
||||||
end
|
end
|
||||||
|
|
||||||
ENV.deparallelize do
|
ENV.deparallelize do
|
||||||
# Tell Python not to install into /Applications
|
# Tell Python not to install into /Applications (default for framework builds)
|
||||||
system "make", "install", "PYTHONAPPSDIR=#{prefix}"
|
system "make", "install", "PYTHONAPPSDIR=#{prefix}"
|
||||||
system "make", "frameworkinstallextras", "PYTHONAPPSDIR=#{pkgshare}"
|
system "make", "frameworkinstallextras", "PYTHONAPPSDIR=#{pkgshare}"
|
||||||
end
|
end
|
||||||
|
|
||||||
# Fixes setting Python build flags for certain software
|
|
||||||
# See: https://github.com/Homebrew/homebrew/pull/20182
|
|
||||||
# https://bugs.python.org/issue3588
|
|
||||||
inreplace lib_cellar/"config/Makefile" do |s|
|
|
||||||
s.change_make_var! "LINKFORSHARED",
|
|
||||||
"-u _PyMac_Error $(PYTHONFRAMEWORKINSTALLDIR)/Versions/$(VERSION)/$(PYTHONFRAMEWORK)"
|
|
||||||
end
|
|
||||||
|
|
||||||
# Prevent third-party packages from building against fragile Cellar paths
|
# Prevent third-party packages from building against fragile Cellar paths
|
||||||
inreplace [lib_cellar/"_sysconfigdata.py",
|
inreplace Dir[lib_cellar/"**/_sysconfigdata_m_darwin_darwin.py",
|
||||||
lib_cellar/"config/Makefile",
|
lib_cellar/"config*/Makefile",
|
||||||
frameworks/"Python.framework/Versions/Current/lib/pkgconfig/python-2.7.pc"],
|
frameworks/"Python.framework/Versions/3*/lib/pkgconfig/python-3.?.pc"],
|
||||||
prefix, opt_prefix
|
prefix, opt_prefix
|
||||||
|
|
||||||
|
# Help third-party packages find the Python framework
|
||||||
|
inreplace Dir[lib_cellar/"config*/Makefile"],
|
||||||
|
/^LINKFORSHARED=(.*)PYTHONFRAMEWORKDIR(.*)/,
|
||||||
|
"LINKFORSHARED=\\1PYTHONFRAMEWORKINSTALLDIR\\2"
|
||||||
|
|
||||||
|
# Fix for https://github.com/Homebrew/homebrew-core/issues/21212
|
||||||
|
inreplace Dir[lib_cellar/"**/_sysconfigdata_m_darwin_darwin.py"],
|
||||||
|
%r{('LINKFORSHARED': .*?)'(Python.framework/Versions/3.\d+/Python)'}m,
|
||||||
|
"\\1'#{opt_prefix}/Frameworks/\\2'"
|
||||||
|
|
||||||
# Symlink the pkgconfig files into HOMEBREW_PREFIX so they're accessible.
|
# Symlink the pkgconfig files into HOMEBREW_PREFIX so they're accessible.
|
||||||
(lib/"pkgconfig").install_symlink Dir[frameworks/"Python.framework/Versions/Current/lib/pkgconfig/*"]
|
(lib/"pkgconfig").install_symlink Dir["#{frameworks}/Python.framework/Versions/#{xy}/lib/pkgconfig/*"]
|
||||||
|
|
||||||
# Remove the site-packages that Python created in its Cellar.
|
# Remove the site-packages that Python created in its Cellar.
|
||||||
site_packages_cellar.rmtree
|
(prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}/site-packages").rmtree
|
||||||
|
|
||||||
(libexec/"setuptools").install resource("setuptools")
|
%w[setuptools pip wheel].each do |r|
|
||||||
(libexec/"pip").install resource("pip")
|
(libexec/r).install resource(r)
|
||||||
(libexec/"wheel").install resource("wheel")
|
end
|
||||||
|
|
||||||
if MacOS.version > :snow_leopard && build.with?("sphinx-doc")
|
if build.with? "sphinx-doc"
|
||||||
cd "Doc" do
|
cd "Doc" do
|
||||||
system "make", "html"
|
system "make", "html"
|
||||||
doc.install Dir["build/html/*"]
|
doc.install Dir["build/html/*"]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Remove commands shadowing system python.
|
# Install unversioned symlinks.
|
||||||
{
|
{
|
||||||
"2to3" => "2to3-2",
|
"idle" => "idle3",
|
||||||
"easy_install" => "easy_install-2.7",
|
"pydoc" => "pydoc3",
|
||||||
"idle" => "idle2",
|
"python" => "python3",
|
||||||
"pip" => "pip2",
|
"python-config" => "python3-config",
|
||||||
"pydoc" => "pydoc2",
|
|
||||||
"python" => "python2",
|
|
||||||
"python-config" => "python2-config",
|
|
||||||
"pythonw" => "pythonw2",
|
|
||||||
"smtpd.py" => "smtpd2.py",
|
|
||||||
"wheel" => nil,
|
|
||||||
}.each do |unversioned_name, versioned_name|
|
}.each do |unversioned_name, versioned_name|
|
||||||
rm_f bin/unversioned_name
|
bin.install_symlink (bin/versioned_name).realpath => unversioned_name
|
||||||
next unless versioned_name
|
|
||||||
(libexec/"bin").install_symlink bin/versioned_name => unversioned_name
|
|
||||||
end
|
end
|
||||||
|
man1.install_symlink man1/"python#{xy}.1" => "python.1"
|
||||||
end
|
end
|
||||||
|
|
||||||
def post_install
|
def post_install
|
||||||
# Fix up the site-packages so that user-installed Python software survives
|
ENV.delete "PYTHONPATH"
|
||||||
# minor updates, such as going from 2.7.0 to 2.7.1:
|
|
||||||
|
|
||||||
# Create a site-packages in HOMEBREW_PREFIX/lib/python2.7/site-packages
|
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
||||||
|
site_packages = HOMEBREW_PREFIX/"lib/python#{xy}/site-packages"
|
||||||
|
site_packages_cellar = prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}/site-packages"
|
||||||
|
|
||||||
|
# Fix up the site-packages so that user-installed Python software survives
|
||||||
|
# minor updates, such as going from 3.3.2 to 3.3.3:
|
||||||
|
|
||||||
|
# Create a site-packages in HOMEBREW_PREFIX/lib/python#{xy}/site-packages
|
||||||
site_packages.mkpath
|
site_packages.mkpath
|
||||||
|
|
||||||
# Symlink the prefix site-packages into the cellar.
|
# Symlink the prefix site-packages into the cellar.
|
||||||
|
@ -262,25 +232,25 @@ class Python < Formula
|
||||||
# Remove old setuptools installations that may still fly around and be
|
# Remove old setuptools installations that may still fly around and be
|
||||||
# listed in the easy_install.pth. This can break setuptools build with
|
# listed in the easy_install.pth. This can break setuptools build with
|
||||||
# zipimport.ZipImportError: bad local file header
|
# zipimport.ZipImportError: bad local file header
|
||||||
# setuptools-0.9.5-py3.3.egg
|
# setuptools-0.9.8-py3.3.egg
|
||||||
rm_rf Dir["#{site_packages}/setuptools*"]
|
rm_rf Dir["#{site_packages}/setuptools*"]
|
||||||
rm_rf Dir["#{site_packages}/distribute*"]
|
rm_rf Dir["#{site_packages}/distribute*"]
|
||||||
rm_rf Dir["#{site_packages}/pip[-_.][0-9]*", "#{site_packages}/pip"]
|
rm_rf Dir["#{site_packages}/pip[-_.][0-9]*", "#{site_packages}/pip"]
|
||||||
|
|
||||||
setup_args = ["-s", "setup.py", "--no-user-cfg", "install", "--force",
|
%w[setuptools pip wheel].each do |pkg|
|
||||||
"--verbose",
|
(libexec/pkg).cd do
|
||||||
"--single-version-externally-managed",
|
system bin/"python3", "-s", "setup.py", "--no-user-cfg", "install",
|
||||||
"--record=installed.txt",
|
"--force", "--verbose", "--install-scripts=#{bin}",
|
||||||
"--install-scripts=#{bin}",
|
"--install-lib=#{site_packages}",
|
||||||
"--install-lib=#{site_packages}"]
|
"--single-version-externally-managed",
|
||||||
|
"--record=installed.txt"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
(libexec/"setuptools").cd { system "#{bin}/python2", *setup_args }
|
bin.install_symlink bin/"wheel" => "wheel3"
|
||||||
(libexec/"pip").cd { system "#{bin}/python2", *setup_args }
|
|
||||||
(libexec/"wheel").cd { system "#{bin}/python2", *setup_args }
|
|
||||||
|
|
||||||
# When building from source, these symlinks will not exist, since
|
# post_install happens after link
|
||||||
# post_install happens after linking.
|
%W[pip pip3 pip#{xy} easy_install easy_install-#{xy} wheel wheel3].each do |e|
|
||||||
%w[pip2 pip2.7 easy_install-2.7].each do |e|
|
|
||||||
(HOMEBREW_PREFIX/"bin").install_symlink bin/e
|
(HOMEBREW_PREFIX/"bin").install_symlink bin/e
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -298,7 +268,8 @@ class Python < Formula
|
||||||
library_dirs << Formula["tcl-tk"].opt_lib
|
library_dirs << Formula["tcl-tk"].opt_lib
|
||||||
end
|
end
|
||||||
|
|
||||||
cfg = lib_cellar/"distutils/distutils.cfg"
|
cfg = prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}/distutils/distutils.cfg"
|
||||||
|
|
||||||
cfg.atomic_write <<~EOS
|
cfg.atomic_write <<~EOS
|
||||||
[install]
|
[install]
|
||||||
prefix=#{HOMEBREW_PREFIX}
|
prefix=#{HOMEBREW_PREFIX}
|
||||||
|
@ -310,6 +281,8 @@ class Python < Formula
|
||||||
end
|
end
|
||||||
|
|
||||||
def sitecustomize
|
def sitecustomize
|
||||||
|
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
||||||
|
|
||||||
<<~EOS
|
<<~EOS
|
||||||
# This file is created by Homebrew and is executed on each python startup.
|
# This file is created by Homebrew and is executed on each python startup.
|
||||||
# Don't print from here, or else python command line scripts may fail!
|
# Don't print from here, or else python command line scripts may fail!
|
||||||
|
@ -318,73 +291,125 @@ class Python < Formula
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
if sys.version_info[0] != 2:
|
if sys.version_info[0] != 3:
|
||||||
# This can only happen if the user has set the PYTHONPATH for 3.x and run Python 2.x or vice versa.
|
# This can only happen if the user has set the PYTHONPATH for 3.x and run Python 2.x or vice versa.
|
||||||
# Every Python looks at the PYTHONPATH variable and we can't fix it here in sitecustomize.py,
|
# Every Python looks at the PYTHONPATH variable and we can't fix it here in sitecustomize.py,
|
||||||
# because the PYTHONPATH is evaluated after the sitecustomize.py. Many modules (e.g. PyQt4) are
|
# because the PYTHONPATH is evaluated after the sitecustomize.py. Many modules (e.g. PyQt4) are
|
||||||
# built only for a specific version of Python and will fail with cryptic error messages.
|
# built only for a specific version of Python and will fail with cryptic error messages.
|
||||||
# In the end this means: Don't set the PYTHONPATH permanently if you use different Python versions.
|
# In the end this means: Don't set the PYTHONPATH permanently if you use different Python versions.
|
||||||
exit('Your PYTHONPATH points to a site-packages dir for Python 2.x but you are running Python ' +
|
exit('Your PYTHONPATH points to a site-packages dir for Python 3.x but you are running Python ' +
|
||||||
str(sys.version_info[0]) + '.x!\\n PYTHONPATH is currently: "' + str(os.environ['PYTHONPATH']) + '"\\n' +
|
str(sys.version_info[0]) + '.x!\\n PYTHONPATH is currently: "' + str(os.environ['PYTHONPATH']) + '"\\n' +
|
||||||
' You should `unset PYTHONPATH` to fix this.')
|
' You should `unset PYTHONPATH` to fix this.')
|
||||||
|
|
||||||
# Only do this for a brewed python:
|
# Only do this for a brewed python:
|
||||||
if os.path.realpath(sys.executable).startswith('#{rack}'):
|
if os.path.realpath(sys.executable).startswith('#{rack}'):
|
||||||
# Shuffle /Library site-packages to the end of sys.path and reject
|
# Shuffle /Library site-packages to the end of sys.path
|
||||||
# paths in /System pre-emptively (#14712)
|
library_site = '/Library/Python/#{xy}/site-packages'
|
||||||
library_site = '/Library/Python/2.7/site-packages'
|
|
||||||
library_packages = [p for p in sys.path if p.startswith(library_site)]
|
library_packages = [p for p in sys.path if p.startswith(library_site)]
|
||||||
sys.path = [p for p in sys.path if not p.startswith(library_site) and
|
sys.path = [p for p in sys.path if not p.startswith(library_site)]
|
||||||
not p.startswith('/System')]
|
|
||||||
# .pth files have already been processed so don't use addsitedir
|
# .pth files have already been processed so don't use addsitedir
|
||||||
sys.path.extend(library_packages)
|
sys.path.extend(library_packages)
|
||||||
|
|
||||||
# the Cellar site-packages is a symlink to the HOMEBREW_PREFIX
|
# the Cellar site-packages is a symlink to the HOMEBREW_PREFIX
|
||||||
# site_packages; prefer the shorter paths
|
# site_packages; prefer the shorter paths
|
||||||
long_prefix = re.compile(r'#{rack}/[0-9\._abrc]+/Frameworks/Python\.framework/Versions/2\.7/lib/python2\.7/site-packages')
|
long_prefix = re.compile(r'#{rack}/[0-9\._abrc]+/Frameworks/Python\.framework/Versions/#{xy}/lib/python#{xy}/site-packages')
|
||||||
sys.path = [long_prefix.sub('#{site_packages}', p) for p in sys.path]
|
sys.path = [long_prefix.sub('#{HOMEBREW_PREFIX/"lib/python#{xy}/site-packages"}', p) for p in sys.path]
|
||||||
|
|
||||||
# LINKFORSHARED (and python-config --ldflags) return the
|
|
||||||
# full path to the lib (yes, "Python" is actually the lib, not a
|
|
||||||
# dir) so that third-party software does not need to add the
|
|
||||||
# -F/#{HOMEBREW_PREFIX}/Frameworks switch.
|
|
||||||
try:
|
|
||||||
from _sysconfigdata import build_time_vars
|
|
||||||
build_time_vars['LINKFORSHARED'] = '-u _PyMac_Error #{opt_prefix}/Frameworks/Python.framework/Versions/2.7/Python'
|
|
||||||
except:
|
|
||||||
pass # remember: don't print here. Better to fail silently.
|
|
||||||
|
|
||||||
# Set the sys.executable to use the opt_prefix
|
# Set the sys.executable to use the opt_prefix
|
||||||
sys.executable = '#{opt_bin}/python2.7'
|
sys.executable = '#{opt_bin}/python#{xy}'
|
||||||
EOS
|
EOS
|
||||||
end
|
end
|
||||||
|
|
||||||
def caveats; <<~EOS
|
def caveats
|
||||||
This formula installs a python2 executable to #{HOMEBREW_PREFIX}/bin.
|
if prefix.exist?
|
||||||
If you wish to have this formula's python executable in your PATH then add
|
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
||||||
the following to #{shell_profile}:
|
else
|
||||||
export PATH="#{opt_libexec}/bin:$PATH"
|
xy = version.to_s.slice(/(3\.\d)/) || "3.6"
|
||||||
|
end
|
||||||
|
text = <<~EOS
|
||||||
|
Pip, setuptools, and wheel have been installed. To update them
|
||||||
|
pip3 install --upgrade pip setuptools wheel
|
||||||
|
|
||||||
Pip and setuptools have been installed. To update them
|
You can install Python packages with
|
||||||
pip2 install --upgrade pip setuptools
|
pip3 install <package>
|
||||||
|
|
||||||
You can install Python packages with
|
They will install into the site-package directory
|
||||||
pip2 install <package>
|
#{HOMEBREW_PREFIX/"lib/python#{xy}/site-packages"}
|
||||||
|
|
||||||
They will install into the site-package directory
|
See: https://docs.brew.sh/Homebrew-and-Python
|
||||||
#{site_packages}
|
|
||||||
|
|
||||||
See: https://docs.brew.sh/Homebrew-and-Python
|
Unversioned symlinks python, python-config, pip etc. pointing to python3,
|
||||||
|
python3-config, pip3 etc., respectively, have been installed.
|
||||||
EOS
|
EOS
|
||||||
|
|
||||||
|
# Tk warning only for 10.6
|
||||||
|
tk_caveats = <<~EOS
|
||||||
|
|
||||||
|
Apple's Tcl/Tk is not recommended for use with Python on Mac OS X 10.6.
|
||||||
|
For more information see: https://www.python.org/download/mac/tcltk/
|
||||||
|
EOS
|
||||||
|
|
||||||
|
text += tk_caveats unless MacOS.version >= :lion
|
||||||
|
text
|
||||||
end
|
end
|
||||||
|
|
||||||
test do
|
test do
|
||||||
# Check if sqlite is ok, because we build with --enable-loadable-sqlite-extensions
|
# Check if sqlite is ok, because we build with --enable-loadable-sqlite-extensions
|
||||||
# and it can occur that building sqlite silently fails if OSX's sqlite is used.
|
# and it can occur that building sqlite silently fails if OSX's sqlite is used.
|
||||||
system "#{bin}/python2", "-c", "import sqlite3"
|
system "#{bin}/python", "-c", "import sqlite3"
|
||||||
# Check if some other modules import. Then the linked libs are working.
|
# Check if some other modules import. Then the linked libs are working.
|
||||||
system "#{bin}/python2", "-c", "import Tkinter; root = Tkinter.Tk()"
|
system "#{bin}/python", "-c", "import tkinter; root = tkinter.Tk()"
|
||||||
system "#{bin}/python2", "-c", "import gdbm"
|
system "#{bin}/python", "-c", "import _gdbm"
|
||||||
system bin/"pip2", "list"
|
system bin/"pip", "list", "--format=columns"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
__END__
|
||||||
|
diff --git a/setup.py b/setup.py
|
||||||
|
index 2779658..902d0eb 100644
|
||||||
|
--- a/setup.py
|
||||||
|
+++ b/setup.py
|
||||||
|
@@ -1699,9 +1699,6 @@ class PyBuildExt(build_ext):
|
||||||
|
# Rather than complicate the code below, detecting and building
|
||||||
|
# AquaTk is a separate method. Only one Tkinter will be built on
|
||||||
|
# Darwin - either AquaTk, if it is found, or X11 based Tk.
|
||||||
|
- if (host_platform == 'darwin' and
|
||||||
|
- self.detect_tkinter_darwin(inc_dirs, lib_dirs)):
|
||||||
|
- return
|
||||||
|
|
||||||
|
# Assume we haven't found any of the libraries or include files
|
||||||
|
# The versions with dots are used on Unix, and the versions without
|
||||||
|
@@ -1747,22 +1744,6 @@ class PyBuildExt(build_ext):
|
||||||
|
if dir not in include_dirs:
|
||||||
|
include_dirs.append(dir)
|
||||||
|
|
||||||
|
- # Check for various platform-specific directories
|
||||||
|
- if host_platform == 'sunos5':
|
||||||
|
- include_dirs.append('/usr/openwin/include')
|
||||||
|
- added_lib_dirs.append('/usr/openwin/lib')
|
||||||
|
- elif os.path.exists('/usr/X11R6/include'):
|
||||||
|
- include_dirs.append('/usr/X11R6/include')
|
||||||
|
- added_lib_dirs.append('/usr/X11R6/lib64')
|
||||||
|
- added_lib_dirs.append('/usr/X11R6/lib')
|
||||||
|
- elif os.path.exists('/usr/X11R5/include'):
|
||||||
|
- include_dirs.append('/usr/X11R5/include')
|
||||||
|
- added_lib_dirs.append('/usr/X11R5/lib')
|
||||||
|
- else:
|
||||||
|
- # Assume default location for X11
|
||||||
|
- include_dirs.append('/usr/X11/include')
|
||||||
|
- added_lib_dirs.append('/usr/X11/lib')
|
||||||
|
-
|
||||||
|
# If Cygwin, then verify that X is installed before proceeding
|
||||||
|
if host_platform == 'cygwin':
|
||||||
|
x11_inc = find_file('X11/Xlib.h', [], include_dirs)
|
||||||
|
@@ -1786,10 +1767,6 @@ class PyBuildExt(build_ext):
|
||||||
|
if host_platform in ['aix3', 'aix4']:
|
||||||
|
libs.append('ld')
|
||||||
|
|
||||||
|
- # Finally, link with the X11 libraries (not appropriate on cygwin)
|
||||||
|
- if host_platform != "cygwin":
|
||||||
|
- libs.append('X11')
|
||||||
|
-
|
||||||
|
ext = Extension('_tkinter', ['_tkinter.c', 'tkappinit.c'],
|
||||||
|
define_macros=[('WITH_APPINIT', 1)] + defs,
|
||||||
|
include_dirs = include_dirs,
|
||||||
|
|
|
@ -1,417 +0,0 @@
|
||||||
class Python3 < Formula
|
|
||||||
desc "Interpreted, interactive, object-oriented programming language"
|
|
||||||
homepage "https://www.python.org/"
|
|
||||||
url "https://www.python.org/ftp/python/3.6.4/Python-3.6.4.tar.xz"
|
|
||||||
sha256 "159b932bf56aeaa76fd66e7420522d8c8853d486b8567c459b84fe2ed13bcaba"
|
|
||||||
revision 2
|
|
||||||
head "https://github.com/python/cpython", :using => :git
|
|
||||||
|
|
||||||
bottle do
|
|
||||||
sha256 "85e704c3ce17fb06edafe488db5e449ba6fa82799aee32d64f6c3ad5414801e0" => :high_sierra
|
|
||||||
sha256 "df733b44cbe6c34e66ff762aca3dfbe958e315551ace602a395400ed2b900616" => :sierra
|
|
||||||
sha256 "b9d96a42fd003b241e6562598c44da8956446624199278c71e49c53df74fe4a4" => :el_capitan
|
|
||||||
end
|
|
||||||
|
|
||||||
devel do
|
|
||||||
url "https://www.python.org/ftp/python/3.7.0/Python-3.7.0b1.tar.xz"
|
|
||||||
sha256 "2bee6320443ab475ecc9ee8b36e96230787eb12cdb336e3079dceef23039b970"
|
|
||||||
end
|
|
||||||
|
|
||||||
option "with-tcl-tk", "Use Homebrew's Tk instead of macOS Tk (has optional Cocoa and threads support)"
|
|
||||||
option "with-quicktest", "Run `make quicktest` after the build"
|
|
||||||
option "with-sphinx-doc", "Build HTML documentation"
|
|
||||||
|
|
||||||
deprecated_option "quicktest" => "with-quicktest"
|
|
||||||
deprecated_option "with-brewed-tk" => "with-tcl-tk"
|
|
||||||
|
|
||||||
depends_on "pkg-config" => :build
|
|
||||||
depends_on "readline" => :recommended
|
|
||||||
depends_on "sqlite" => :recommended
|
|
||||||
depends_on "gdbm" => :recommended
|
|
||||||
depends_on "openssl"
|
|
||||||
depends_on "xz" => :recommended # for the lzma module added in 3.3
|
|
||||||
depends_on "tcl-tk" => :optional
|
|
||||||
depends_on "sphinx-doc" => [:build, :optional]
|
|
||||||
|
|
||||||
skip_clean "bin/pip3", "bin/pip-3.4", "bin/pip-3.5", "bin/pip-3.6"
|
|
||||||
skip_clean "bin/easy_install3", "bin/easy_install-3.4", "bin/easy_install-3.5", "bin/easy_install-3.6"
|
|
||||||
|
|
||||||
resource "setuptools" do
|
|
||||||
url "https://files.pythonhosted.org/packages/a4/c8/9a7a47f683d54d83f648d37c3e180317f80dc126a304c45dc6663246233a/setuptools-36.5.0.zip"
|
|
||||||
sha256 "ce2007c1cea3359870b80657d634253a0765b0c7dc5a988d77ba803fc86f2c64"
|
|
||||||
end
|
|
||||||
|
|
||||||
resource "pip" do
|
|
||||||
url "https://files.pythonhosted.org/packages/11/b6/abcb525026a4be042b486df43905d6893fb04f05aac21c32c638e939e447/pip-9.0.1.tar.gz"
|
|
||||||
sha256 "09f243e1a7b461f654c26a725fa373211bb7ff17a9300058b205c61658ca940d"
|
|
||||||
end
|
|
||||||
|
|
||||||
resource "wheel" do
|
|
||||||
url "https://files.pythonhosted.org/packages/fa/b4/f9886517624a4dcb81a1d766f68034344b7565db69f13d52697222daeb72/wheel-0.30.0.tar.gz"
|
|
||||||
sha256 "9515fe0a94e823fd90b08d22de45d7bde57c90edce705b22f5e1ecf7e1b653c8"
|
|
||||||
end
|
|
||||||
|
|
||||||
fails_with :clang do
|
|
||||||
build 425
|
|
||||||
cause "https://bugs.python.org/issue24844"
|
|
||||||
end
|
|
||||||
|
|
||||||
# Homebrew's tcl-tk is built in a standard unix fashion (due to link errors)
|
|
||||||
# so we have to stop python from searching for frameworks and linking against
|
|
||||||
# X11.
|
|
||||||
patch :DATA if build.with? "tcl-tk"
|
|
||||||
|
|
||||||
# setuptools remembers the build flags python is built with and uses them to
|
|
||||||
# build packages later. Xcode-only systems need different flags.
|
|
||||||
pour_bottle? do
|
|
||||||
reason <<~EOS
|
|
||||||
The bottle needs the Apple Command Line Tools to be installed.
|
|
||||||
You can install them, if desired, with:
|
|
||||||
xcode-select --install
|
|
||||||
EOS
|
|
||||||
satisfy { MacOS::CLT.installed? }
|
|
||||||
end
|
|
||||||
|
|
||||||
def install
|
|
||||||
ENV.permit_weak_imports
|
|
||||||
|
|
||||||
# Unset these so that installing pip and setuptools puts them where we want
|
|
||||||
# and not into some other Python the user has installed.
|
|
||||||
ENV["PYTHONHOME"] = nil
|
|
||||||
ENV["PYTHONPATH"] = nil
|
|
||||||
|
|
||||||
xy = (buildpath/"configure.ac").read.slice(/PYTHON_VERSION, (3\.\d)/, 1)
|
|
||||||
lib_cellar = prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}"
|
|
||||||
|
|
||||||
args = %W[
|
|
||||||
--prefix=#{prefix}
|
|
||||||
--enable-ipv6
|
|
||||||
--datarootdir=#{share}
|
|
||||||
--datadir=#{share}
|
|
||||||
--enable-framework=#{frameworks}
|
|
||||||
--without-ensurepip
|
|
||||||
--with-dtrace
|
|
||||||
]
|
|
||||||
|
|
||||||
args << "--without-gcc" if ENV.compiler == :clang
|
|
||||||
args << "--enable-loadable-sqlite-extensions" if build.with?("sqlite")
|
|
||||||
|
|
||||||
cflags = []
|
|
||||||
ldflags = []
|
|
||||||
cppflags = []
|
|
||||||
|
|
||||||
unless MacOS::CLT.installed?
|
|
||||||
# Help Python's build system (setuptools/pip) to build things on Xcode-only systems
|
|
||||||
# The setup.py looks at "-isysroot" to get the sysroot (and not at --sysroot)
|
|
||||||
cflags << "-isysroot #{MacOS.sdk_path}"
|
|
||||||
ldflags << "-isysroot #{MacOS.sdk_path}"
|
|
||||||
cppflags << "-I#{MacOS.sdk_path}/usr/include" # find zlib
|
|
||||||
# For the Xlib.h, Python needs this header dir with the system Tk
|
|
||||||
if build.without? "tcl-tk"
|
|
||||||
cflags << "-I#{MacOS.sdk_path}/System/Library/Frameworks/Tk.framework/Versions/8.5/Headers"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
# Avoid linking to libgcc https://mail.python.org/pipermail/python-dev/2012-February/116205.html
|
|
||||||
args << "MACOSX_DEPLOYMENT_TARGET=#{MacOS.version}"
|
|
||||||
|
|
||||||
# We want our readline! This is just to outsmart the detection code,
|
|
||||||
# superenv makes cc always find includes/libs!
|
|
||||||
inreplace "setup.py",
|
|
||||||
"do_readline = self.compiler.find_library_file(lib_dirs, 'readline')",
|
|
||||||
"do_readline = '#{Formula["readline"].opt_lib}/libhistory.dylib'"
|
|
||||||
|
|
||||||
if build.stable?
|
|
||||||
inreplace "setup.py", "/usr/local/ssl", Formula["openssl"].opt_prefix
|
|
||||||
else
|
|
||||||
args << "--with-openssl=#{Formula["openssl"].opt_prefix}"
|
|
||||||
end
|
|
||||||
|
|
||||||
if build.with? "sqlite"
|
|
||||||
inreplace "setup.py" do |s|
|
|
||||||
s.gsub! "sqlite_setup_debug = False", "sqlite_setup_debug = True"
|
|
||||||
s.gsub! "for d_ in inc_dirs + sqlite_inc_paths:",
|
|
||||||
"for d_ in ['#{Formula["sqlite"].opt_include}']:"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Allow python modules to use ctypes.find_library to find homebrew's stuff
|
|
||||||
# even if homebrew is not a /usr/local/lib. Try this with:
|
|
||||||
# `brew install enchant && pip install pyenchant`
|
|
||||||
inreplace "./Lib/ctypes/macholib/dyld.py" do |f|
|
|
||||||
f.gsub! "DEFAULT_LIBRARY_FALLBACK = [", "DEFAULT_LIBRARY_FALLBACK = [ '#{HOMEBREW_PREFIX}/lib',"
|
|
||||||
f.gsub! "DEFAULT_FRAMEWORK_FALLBACK = [", "DEFAULT_FRAMEWORK_FALLBACK = [ '#{HOMEBREW_PREFIX}/Frameworks',"
|
|
||||||
end
|
|
||||||
|
|
||||||
if build.with? "tcl-tk"
|
|
||||||
tcl_tk = Formula["tcl-tk"].opt_prefix
|
|
||||||
cppflags << "-I#{tcl_tk}/include"
|
|
||||||
ldflags << "-L#{tcl_tk}/lib"
|
|
||||||
end
|
|
||||||
|
|
||||||
args << "CFLAGS=#{cflags.join(" ")}" unless cflags.empty?
|
|
||||||
args << "LDFLAGS=#{ldflags.join(" ")}" unless ldflags.empty?
|
|
||||||
args << "CPPFLAGS=#{cppflags.join(" ")}" unless cppflags.empty?
|
|
||||||
|
|
||||||
system "./configure", *args
|
|
||||||
|
|
||||||
system "make"
|
|
||||||
if build.with?("quicktest")
|
|
||||||
system "make", "quicktest", "TESTPYTHONOPTS=-s", "TESTOPTS=-j#{ENV.make_jobs} -w"
|
|
||||||
end
|
|
||||||
|
|
||||||
ENV.deparallelize do
|
|
||||||
# Tell Python not to install into /Applications (default for framework builds)
|
|
||||||
system "make", "install", "PYTHONAPPSDIR=#{prefix}"
|
|
||||||
system "make", "frameworkinstallextras", "PYTHONAPPSDIR=#{pkgshare}"
|
|
||||||
end
|
|
||||||
|
|
||||||
# Any .app get a " 3" attached, so it does not conflict with python 2.x.
|
|
||||||
Dir.glob("#{prefix}/*.app") { |app| mv app, app.sub(/\.app$/, " 3.app") }
|
|
||||||
|
|
||||||
# Prevent third-party packages from building against fragile Cellar paths
|
|
||||||
inreplace Dir[lib_cellar/"**/_sysconfigdata_m_darwin_darwin.py",
|
|
||||||
lib_cellar/"config*/Makefile",
|
|
||||||
frameworks/"Python.framework/Versions/3*/lib/pkgconfig/python-3.?.pc"],
|
|
||||||
prefix, opt_prefix
|
|
||||||
|
|
||||||
# Help third-party packages find the Python framework
|
|
||||||
inreplace Dir[lib_cellar/"config*/Makefile"],
|
|
||||||
/^LINKFORSHARED=(.*)PYTHONFRAMEWORKDIR(.*)/,
|
|
||||||
"LINKFORSHARED=\\1PYTHONFRAMEWORKINSTALLDIR\\2"
|
|
||||||
|
|
||||||
# Fix for https://github.com/Homebrew/homebrew-core/issues/21212
|
|
||||||
inreplace Dir[lib_cellar/"**/_sysconfigdata_m_darwin_darwin.py"],
|
|
||||||
%r{('LINKFORSHARED': .*?)'(Python.framework/Versions/3.\d+/Python)'}m,
|
|
||||||
"\\1'#{opt_prefix}/Frameworks/\\2'"
|
|
||||||
|
|
||||||
# A fix, because python and python3 both want to install Python.framework
|
|
||||||
# and therefore we can't link both into HOMEBREW_PREFIX/Frameworks
|
|
||||||
# https://github.com/Homebrew/homebrew/issues/15943
|
|
||||||
["Headers", "Python", "Resources"].each { |f| rm(prefix/"Frameworks/Python.framework/#{f}") }
|
|
||||||
rm prefix/"Frameworks/Python.framework/Versions/Current"
|
|
||||||
|
|
||||||
# Symlink the pkgconfig files into HOMEBREW_PREFIX so they're accessible.
|
|
||||||
(lib/"pkgconfig").install_symlink Dir["#{frameworks}/Python.framework/Versions/#{xy}/lib/pkgconfig/*"]
|
|
||||||
|
|
||||||
# Remove 2to3 because python2 also installs it
|
|
||||||
rm bin/"2to3"
|
|
||||||
|
|
||||||
# Remove the site-packages that Python created in its Cellar.
|
|
||||||
(prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}/site-packages").rmtree
|
|
||||||
|
|
||||||
%w[setuptools pip wheel].each do |r|
|
|
||||||
(libexec/r).install resource(r)
|
|
||||||
end
|
|
||||||
|
|
||||||
if build.with? "sphinx-doc"
|
|
||||||
cd "Doc" do
|
|
||||||
system "make", "html"
|
|
||||||
doc.install Dir["build/html/*"]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def post_install
|
|
||||||
ENV.delete "PYTHONPATH"
|
|
||||||
|
|
||||||
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
|
||||||
site_packages = HOMEBREW_PREFIX/"lib/python#{xy}/site-packages"
|
|
||||||
site_packages_cellar = prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}/site-packages"
|
|
||||||
|
|
||||||
# Fix up the site-packages so that user-installed Python software survives
|
|
||||||
# minor updates, such as going from 3.3.2 to 3.3.3:
|
|
||||||
|
|
||||||
# Create a site-packages in HOMEBREW_PREFIX/lib/python#{xy}/site-packages
|
|
||||||
site_packages.mkpath
|
|
||||||
|
|
||||||
# Symlink the prefix site-packages into the cellar.
|
|
||||||
site_packages_cellar.unlink if site_packages_cellar.exist?
|
|
||||||
site_packages_cellar.parent.install_symlink site_packages
|
|
||||||
|
|
||||||
# Write our sitecustomize.py
|
|
||||||
rm_rf Dir["#{site_packages}/sitecustomize.py[co]"]
|
|
||||||
(site_packages/"sitecustomize.py").atomic_write(sitecustomize)
|
|
||||||
|
|
||||||
# Remove old setuptools installations that may still fly around and be
|
|
||||||
# listed in the easy_install.pth. This can break setuptools build with
|
|
||||||
# zipimport.ZipImportError: bad local file header
|
|
||||||
# setuptools-0.9.8-py3.3.egg
|
|
||||||
rm_rf Dir["#{site_packages}/setuptools*"]
|
|
||||||
rm_rf Dir["#{site_packages}/distribute*"]
|
|
||||||
rm_rf Dir["#{site_packages}/pip[-_.][0-9]*", "#{site_packages}/pip"]
|
|
||||||
|
|
||||||
%w[setuptools pip wheel].each do |pkg|
|
|
||||||
(libexec/pkg).cd do
|
|
||||||
system bin/"python3", "-s", "setup.py", "--no-user-cfg", "install",
|
|
||||||
"--force", "--verbose", "--install-scripts=#{bin}",
|
|
||||||
"--install-lib=#{site_packages}",
|
|
||||||
"--single-version-externally-managed",
|
|
||||||
"--record=installed.txt"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
rm_rf [bin/"pip", bin/"easy_install"]
|
|
||||||
mv bin/"wheel", bin/"wheel3"
|
|
||||||
|
|
||||||
# post_install happens after link
|
|
||||||
%W[pip3 pip#{xy} easy_install-#{xy} wheel3].each do |e|
|
|
||||||
(HOMEBREW_PREFIX/"bin").install_symlink bin/e
|
|
||||||
end
|
|
||||||
|
|
||||||
# Help distutils find brewed stuff when building extensions
|
|
||||||
include_dirs = [HOMEBREW_PREFIX/"include", Formula["openssl"].opt_include]
|
|
||||||
library_dirs = [HOMEBREW_PREFIX/"lib", Formula["openssl"].opt_lib]
|
|
||||||
|
|
||||||
if build.with? "sqlite"
|
|
||||||
include_dirs << Formula["sqlite"].opt_include
|
|
||||||
library_dirs << Formula["sqlite"].opt_lib
|
|
||||||
end
|
|
||||||
|
|
||||||
if build.with? "tcl-tk"
|
|
||||||
include_dirs << Formula["tcl-tk"].opt_include
|
|
||||||
library_dirs << Formula["tcl-tk"].opt_lib
|
|
||||||
end
|
|
||||||
|
|
||||||
cfg = prefix/"Frameworks/Python.framework/Versions/#{xy}/lib/python#{xy}/distutils/distutils.cfg"
|
|
||||||
|
|
||||||
cfg.atomic_write <<~EOS
|
|
||||||
[install]
|
|
||||||
prefix=#{HOMEBREW_PREFIX}
|
|
||||||
|
|
||||||
[build_ext]
|
|
||||||
include_dirs=#{include_dirs.join ":"}
|
|
||||||
library_dirs=#{library_dirs.join ":"}
|
|
||||||
EOS
|
|
||||||
end
|
|
||||||
|
|
||||||
def sitecustomize
|
|
||||||
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
|
||||||
|
|
||||||
<<~EOS
|
|
||||||
# This file is created by Homebrew and is executed on each python startup.
|
|
||||||
# Don't print from here, or else python command line scripts may fail!
|
|
||||||
# <https://docs.brew.sh/Homebrew-and-Python>
|
|
||||||
import re
|
|
||||||
import os
|
|
||||||
import sys
|
|
||||||
|
|
||||||
if sys.version_info[0] != 3:
|
|
||||||
# This can only happen if the user has set the PYTHONPATH for 3.x and run Python 2.x or vice versa.
|
|
||||||
# Every Python looks at the PYTHONPATH variable and we can't fix it here in sitecustomize.py,
|
|
||||||
# because the PYTHONPATH is evaluated after the sitecustomize.py. Many modules (e.g. PyQt4) are
|
|
||||||
# built only for a specific version of Python and will fail with cryptic error messages.
|
|
||||||
# In the end this means: Don't set the PYTHONPATH permanently if you use different Python versions.
|
|
||||||
exit('Your PYTHONPATH points to a site-packages dir for Python 3.x but you are running Python ' +
|
|
||||||
str(sys.version_info[0]) + '.x!\\n PYTHONPATH is currently: "' + str(os.environ['PYTHONPATH']) + '"\\n' +
|
|
||||||
' You should `unset PYTHONPATH` to fix this.')
|
|
||||||
|
|
||||||
# Only do this for a brewed python:
|
|
||||||
if os.path.realpath(sys.executable).startswith('#{rack}'):
|
|
||||||
# Shuffle /Library site-packages to the end of sys.path
|
|
||||||
library_site = '/Library/Python/#{xy}/site-packages'
|
|
||||||
library_packages = [p for p in sys.path if p.startswith(library_site)]
|
|
||||||
sys.path = [p for p in sys.path if not p.startswith(library_site)]
|
|
||||||
# .pth files have already been processed so don't use addsitedir
|
|
||||||
sys.path.extend(library_packages)
|
|
||||||
|
|
||||||
# the Cellar site-packages is a symlink to the HOMEBREW_PREFIX
|
|
||||||
# site_packages; prefer the shorter paths
|
|
||||||
long_prefix = re.compile(r'#{rack}/[0-9\._abrc]+/Frameworks/Python\.framework/Versions/#{xy}/lib/python#{xy}/site-packages')
|
|
||||||
sys.path = [long_prefix.sub('#{HOMEBREW_PREFIX/"lib/python#{xy}/site-packages"}', p) for p in sys.path]
|
|
||||||
|
|
||||||
# Set the sys.executable to use the opt_prefix
|
|
||||||
sys.executable = '#{opt_bin}/python#{xy}'
|
|
||||||
EOS
|
|
||||||
end
|
|
||||||
|
|
||||||
def caveats
|
|
||||||
if prefix.exist?
|
|
||||||
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
|
||||||
else
|
|
||||||
xy = version.to_s.slice(/(3\.\d)/) || "3.6"
|
|
||||||
end
|
|
||||||
text = <<~EOS
|
|
||||||
Pip, setuptools, and wheel have been installed. To update them
|
|
||||||
pip3 install --upgrade pip setuptools wheel
|
|
||||||
|
|
||||||
You can install Python packages with
|
|
||||||
pip3 install <package>
|
|
||||||
|
|
||||||
They will install into the site-package directory
|
|
||||||
#{HOMEBREW_PREFIX/"lib/python#{xy}/site-packages"}
|
|
||||||
|
|
||||||
See: https://docs.brew.sh/Homebrew-and-Python
|
|
||||||
EOS
|
|
||||||
|
|
||||||
# Tk warning only for 10.6
|
|
||||||
tk_caveats = <<~EOS
|
|
||||||
|
|
||||||
Apple's Tcl/Tk is not recommended for use with Python on Mac OS X 10.6.
|
|
||||||
For more information see: https://www.python.org/download/mac/tcltk/
|
|
||||||
EOS
|
|
||||||
|
|
||||||
text += tk_caveats unless MacOS.version >= :lion
|
|
||||||
text
|
|
||||||
end
|
|
||||||
|
|
||||||
test do
|
|
||||||
xy = (prefix/"Frameworks/Python.framework/Versions").children.first.basename.to_s
|
|
||||||
# Check if sqlite is ok, because we build with --enable-loadable-sqlite-extensions
|
|
||||||
# and it can occur that building sqlite silently fails if OSX's sqlite is used.
|
|
||||||
system "#{bin}/python#{xy}", "-c", "import sqlite3"
|
|
||||||
# Check if some other modules import. Then the linked libs are working.
|
|
||||||
system "#{bin}/python#{xy}", "-c", "import tkinter; root = tkinter.Tk()"
|
|
||||||
system "#{bin}/python#{xy}", "-c", "import _gdbm"
|
|
||||||
system bin/"pip3", "list"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
__END__
|
|
||||||
diff --git a/setup.py b/setup.py
|
|
||||||
index 2779658..902d0eb 100644
|
|
||||||
--- a/setup.py
|
|
||||||
+++ b/setup.py
|
|
||||||
@@ -1699,9 +1699,6 @@ class PyBuildExt(build_ext):
|
|
||||||
# Rather than complicate the code below, detecting and building
|
|
||||||
# AquaTk is a separate method. Only one Tkinter will be built on
|
|
||||||
# Darwin - either AquaTk, if it is found, or X11 based Tk.
|
|
||||||
- if (host_platform == 'darwin' and
|
|
||||||
- self.detect_tkinter_darwin(inc_dirs, lib_dirs)):
|
|
||||||
- return
|
|
||||||
|
|
||||||
# Assume we haven't found any of the libraries or include files
|
|
||||||
# The versions with dots are used on Unix, and the versions without
|
|
||||||
@@ -1747,22 +1744,6 @@ class PyBuildExt(build_ext):
|
|
||||||
if dir not in include_dirs:
|
|
||||||
include_dirs.append(dir)
|
|
||||||
|
|
||||||
- # Check for various platform-specific directories
|
|
||||||
- if host_platform == 'sunos5':
|
|
||||||
- include_dirs.append('/usr/openwin/include')
|
|
||||||
- added_lib_dirs.append('/usr/openwin/lib')
|
|
||||||
- elif os.path.exists('/usr/X11R6/include'):
|
|
||||||
- include_dirs.append('/usr/X11R6/include')
|
|
||||||
- added_lib_dirs.append('/usr/X11R6/lib64')
|
|
||||||
- added_lib_dirs.append('/usr/X11R6/lib')
|
|
||||||
- elif os.path.exists('/usr/X11R5/include'):
|
|
||||||
- include_dirs.append('/usr/X11R5/include')
|
|
||||||
- added_lib_dirs.append('/usr/X11R5/lib')
|
|
||||||
- else:
|
|
||||||
- # Assume default location for X11
|
|
||||||
- include_dirs.append('/usr/X11/include')
|
|
||||||
- added_lib_dirs.append('/usr/X11/lib')
|
|
||||||
-
|
|
||||||
# If Cygwin, then verify that X is installed before proceeding
|
|
||||||
if host_platform == 'cygwin':
|
|
||||||
x11_inc = find_file('X11/Xlib.h', [], include_dirs)
|
|
||||||
@@ -1786,10 +1767,6 @@ class PyBuildExt(build_ext):
|
|
||||||
if host_platform in ['aix3', 'aix4']:
|
|
||||||
libs.append('ld')
|
|
||||||
|
|
||||||
- # Finally, link with the X11 libraries (not appropriate on cygwin)
|
|
||||||
- if host_platform != "cygwin":
|
|
||||||
- libs.append('X11')
|
|
||||||
-
|
|
||||||
ext = Extension('_tkinter', ['_tkinter.c', 'tkappinit.c'],
|
|
||||||
define_macros=[('WITH_APPINIT', 1)] + defs,
|
|
||||||
include_dirs = include_dirs,
|
|
|
@ -143,6 +143,7 @@
|
||||||
"protobuf250": "protobuf@2.5",
|
"protobuf250": "protobuf@2.5",
|
||||||
"protobuf260": "protobuf@2.6",
|
"protobuf260": "protobuf@2.6",
|
||||||
"pyqt5": "pyqt",
|
"pyqt5": "pyqt",
|
||||||
|
"python3": "python",
|
||||||
"qt5": "qt",
|
"qt5": "qt",
|
||||||
"qt55": "qt@5.5",
|
"qt55": "qt@5.5",
|
||||||
"racket": "minimal-racket",
|
"racket": "minimal-racket",
|
||||||
|
|
Loading…
Reference in a new issue