update python (#156)

pull/154/head
ruki 4 years ago committed by GitHub
parent d0e262d93c
commit eedc587cbf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 1
      packages/m/meson/xmake.lua
  2. 117
      packages/p/python/xmake.lua
  3. 106
      packages/p/python2/xmake.lua
  4. 4
      scripts/packages.lua
  5. 4
      scripts/test.lua

@ -6,6 +6,7 @@ package("meson")
add_urls("https://github.com/mesonbuild/meson/releases/download/$(version)/meson-$(version).tar.gz",
"https://github.com/mesonbuild/meson.git")
add_versions("0.56.0", "291dd38ff1cd55fcfca8fc985181dd39be0d3e5826e5f0013bf867be40117213")
add_versions("0.50.1", "f68f56d60c80a77df8fc08fa1016bc5831605d4717b622c96212573271e14ecc")
add_deps("ninja", "python 3.x", {kind = "binary"})

@ -4,24 +4,35 @@ package("python")
set_description("The python programming language.")
if is_host("windows") then
if os.arch() == "x64" then
add_urls("https://cdn.jsdelivr.net/gh/xmake-mirror/python-releases@$(version)/python-$(version).win64.tar.gz",
"https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win64.tar.gz",
"https://gitlab.com/xmake-mirror/python-releases/-/raw/$(version)/python-$(version).win64.tar.gz")
add_versions("2.7.15", "c81c4604b4176ff26be8d37cf48a2582e71a5e8f475b531c2e5d032a39511acb")
add_versions("3.7.0", "8acd395e64d09b6b33ef78e199ffa48a8fd48f32d4d90d575e72448939a0e4c5")
else
add_urls("https://cdn.jsdelivr.net/gh/xmake-mirror/python-releases@$(version)/python-$(version).win32.tar.gz",
"https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win32.tar.gz",
if is_arch("x86", "i386") or os.arch() == "x86" then
add_urls("https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win32.tar.gz",
"https://gitlab.com/xmake-mirror/python-releases/-/raw/$(version)/python-$(version).win32.tar.gz")
add_versions("2.7.15", "4a7be2b440b74776662daaeb6bb6c5574bb6d0f4ddc0ad03ce63571ab2353303")
add_versions("2.7.18", "9efaf273aa2e7d23fa22efa2936619ec91cf9ee189f707e375f9063fadeabcd6")
add_versions("3.7.0", "6f6dfd3df4b15157a12d06685a6dda450478ca118aa8832f0033093b9ca6329f")
add_versions("3.8.1", "f4fe3eeec4ee50260382a8221b1bebf919b6635a499341abe128986ae76f17e3")
add_versions("3.8.5", "9d1b901a508b3a6745aa225596d98a1aaa39cf8e9b9f79b5ded7192d4503a5aa")
else
add_urls("https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win64.tar.gz",
"https://gitlab.com/xmake-mirror/python-releases/-/raw/$(version)/python-$(version).win64.tar.gz")
add_versions("2.7.15", "c81c4604b4176ff26be8d37cf48a2582e71a5e8f475b531c2e5d032a39511acb")
add_versions("2.7.18", "0e1adec089c4358b4ff1cd392c8bd7c975e0bf7c279aee91e7aaa04c00fb2c10")
add_versions("3.7.0", "8acd395e64d09b6b33ef78e199ffa48a8fd48f32d4d90d575e72448939a0e4c5")
add_versions("3.8.1", "9b7666a3d39a5b8405b0706fc042390b7ecfd0f75b948c7d2be012598b11163e")
add_versions("3.8.5", "585f71093dd1303140f2e97700581456fe38e3ec47922bcb4ad3c76ee8ee2433")
end
else
set_urls("https://www.python.org/ftp/python/$(version)/Python-$(version).tgz",
"https://github.com/xmake-mirror/cpython/releases/download/v$(version)/Python-$(version).tgz")
add_versions("2.7.15", "18617d1f15a380a919d517630a9cd85ce17ea602f9bbdc58ddc672df4b0239db")
add_versions("2.7.18", "da3080e3b488f648a3d7a4560ddee895284c3380b11d6de75edb986526b9a814")
add_versions("3.7.0", "85bb9feb6863e04fb1700b018d9d42d1caac178559ffa453d7e6a436e259fd0d")
add_versions("3.8.1", "c7cfa39a43b994621b245e029769e9126caa2a93571cee2e743b213cceac35fb")
add_versions("3.8.5", "015115023c382eb6ab83d512762fe3c5502fa0c6c52ffebc4831c4e1a06ffc49")
end
if not is_plat(os.host()) then
set_kind("binary")
end
if is_host("macosx", "linux") then
@ -32,54 +43,32 @@ package("python")
add_syslinks("util", "pthread", "dl")
end
add_resources("3.7.0", "setuptools", "https://files.pythonhosted.org/packages/c2/f7/c7b501b783e5a74cf1768bc174ee4fb0a8a6ee5af6afa92274ff964703e0/setuptools-40.8.0.zip", "6e4eec90337e849ade7103723b9a99631c1f0d19990d6e8412dc42f5ae8b304d")
add_resources("3.7.0", "pip", "https://files.pythonhosted.org/packages/36/fa/51ca4d57392e2f69397cd6e5af23da2a8d37884a605f9e3f2d3bfdc48397/pip-19.0.3.tar.gz", "6e6f197a1abfb45118dbb878b5c859a0edbdd33fd250100bc015b67fded4b9f2")
add_resources("3.7.0", "wheel", "https://files.pythonhosted.org/packages/b7/cf/1ea0f5b3ce55cacde1e84cdde6cee1ebaff51bd9a3e6c7ba4082199af6f6/wheel-0.33.1.tar.gz", "66a8fd76f28977bb664b098372daef2b27f60dc4d1688cfab7b37a09448f0e9d")
add_resources("2.7.15", "setuptools", "https://files.pythonhosted.org/packages/c2/f7/c7b501b783e5a74cf1768bc174ee4fb0a8a6ee5af6afa92274ff964703e0/setuptools-40.8.0.zip", "6e4eec90337e849ade7103723b9a99631c1f0d19990d6e8412dc42f5ae8b304d")
add_resources("2.7.15", "pip", "https://files.pythonhosted.org/packages/36/fa/51ca4d57392e2f69397cd6e5af23da2a8d37884a605f9e3f2d3bfdc48397/pip-19.0.3.tar.gz", "6e6f197a1abfb45118dbb878b5c859a0edbdd33fd250100bc015b67fded4b9f2")
add_resources("2.7.15", "wheel", "https://files.pythonhosted.org/packages/b7/cf/1ea0f5b3ce55cacde1e84cdde6cee1ebaff51bd9a3e6c7ba4082199af6f6/wheel-0.33.1.tar.gz", "66a8fd76f28977bb664b098372daef2b27f60dc4d1688cfab7b37a09448f0e9d")
on_load("@windows", "@msys", "@cygwin", function (package)
on_load(function (package)
-- set includedirs
package:add("includedirs", "include")
-- add PATH
-- set python environments
local PYTHONPATH = package:installdir("Lib", "site-packages")
package:addenv("PYTHONPATH", PYTHONPATH)
package:addenv("PATH", "bin")
end)
on_load("@macosx", "@linux", function (package)
-- set includedirs
local version = package:version()
if package:is_plat("windows") then
package:add("includedirs", "include")
elseif version:ge("3.0") then
package:add("includedirs", ("include/python%d.%dm"):format(version:major(), version:minor()))
local pyver = ("python%d.%d"):format(version:major(), version:minor())
if version:ge("3.0") and version:le("3.8") then
package:add("includedirs", path.join("include", pyver .. "m"))
else
package:add("includedirs", ("include/python%d.%d"):format(version:major(), version:minor()))
package:add("includedirs", path.join("include", pyver))
end
-- define install_resources()
package:data_set("install_resources", function()
-- imports
import("lib.detect.find_file")
-- set python environments
local envs = {}
if is_host("windows") and version:ge("3.0") then
envs.PYTHONPATH = package:installdir("Lib", "site-packages")
else
envs.PYTHONPATH = package:installdir("lib", "python" .. version:major() .. "." .. version:minor(), "site-packages")
end
package:addenv("PYTHONPATH", envs.PYTHONPATH)
-- install resources
local python = path.join(package:installdir("bin"), "python" .. (is_host("windows") and ".exe" or ""))
for _, name in ipairs({"setuptools", "pip", "wheel"}) do
local resourcedir = assert(package:resourcedir(name), "resource(%s): not found!", name)
local setupfile = assert(find_file("setup.py", path.join(resourcedir, "*")), "resource(%s): setup.py not found!", name)
local oldir = os.cd(path.directory(setupfile))
os.vrunv(python, {"setup.py", "install", "--prefix=" .. package:installdir()}, {envs = envs})
os.cd(oldir)
end
end)
-- set python environments
local PYTHONPATH = package:installdir("lib", pyver, "site-packages")
package:addenv("PYTHONPATH", PYTHONPATH)
package:addenv("PATH", "bin")
end)
on_install("@windows", "@msys", "@cygwin", function (package)
@ -90,15 +79,17 @@ package("python")
end
os.mv("*.exe", package:installdir("bin"))
os.mv("*.dll", package:installdir("bin"))
os.mv("Lib", package:installdir())
os.mv("libs/*", package:installdir("lib"))
os.cp("*", package:installdir())
package:data("install_resources")()
os.cp("*|libs", package:installdir())
local python = path.join(package:installdir("bin"), "python.exe")
os.vrunv(python, {"-m", "pip", "install", "wheel"})
end)
on_install("@macosx", "@linux", function (package)
-- init configs
local configs = {"--enable-ipv6", "--without-ensurepip"}
local configs = {"--enable-ipv6", "--with-ensurepip"}
table.insert(configs, "--datadir=" .. package:installdir("share"))
table.insert(configs, "--datarootdir=" .. package:installdir("share"))
@ -119,8 +110,16 @@ package("python")
local cflags = {}
local ldflags = {}
if package:is_plat("macosx") then
local xcode_dir = get_config("xcode")
local xcode_dir = get_config("xcode")
local xcode_sdkver = get_config("xcode_sdkver") or get_config("xcode_sdkver_macosx")
if not xcode_dir or not xcode_sdkver then
-- maybe on cross platform, we need find xcode envs manually
local xcode = import("detect.sdks.find_xcode")(nil, {force = true, plat = package:plat(), arch = package:arch()})
if xcode then
xcode_dir = xcode.sdkdir
xcode_sdkver = xcode.sdkver
end
end
if xcode_dir and xcode_sdkver then
-- help Python's build system (setuptools/pip) to build things on SDK-based systems
-- the setup.py looks at "-isysroot" to get the sysroot (and not at --sysroot)
@ -136,6 +135,12 @@ package("python")
-- avoid linking to libgcc https://mail.python.org/pipermail/python-dev/2012-February/116205.html
local target_minver = get_config("target_minver") or get_config("target_minver_macosx")
if not target_minver then
local macos_ver = macos.version()
if macos_ver then
target_minver = macos_ver:major() .. "." .. macos_ver:minor()
end
end
if target_minver then
table.insert(configs, "MACOSX_DEPLOYMENT_TARGET=" .. target_minver)
end
@ -156,8 +161,9 @@ package("python")
os.cp(path.join(package:installdir("bin"), "python3-config"), path.join(package:installdir("bin"), "python-config"))
end
-- install resources
package:data("install_resources")()
-- install wheel
local python = path.join(package:installdir("bin"), "python")
os.vrunv(python, {"-m", "pip", "install", "wheel"})
end)
on_test(function (package)
@ -168,4 +174,7 @@ package("python")
if package:kind() ~= "binary" then
assert(package:has_cfuncs("PyModule_New", {includes = "Python.h"}))
end
if is_host("windows") and package:version():ge("3.8.0") then
os.vrun("py -3 -c \"import sys\"")
end
end)

@ -4,18 +4,18 @@ package("python2")
set_description("The python programming language.")
if is_host("windows") then
if os.arch() == "x64" then
add_urls("https://cdn.jsdelivr.net/gh/xmake-mirror/python-releases@$(version)/python-$(version).win64.tar.gz",
"https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win64.tar.gz",
"https://gitlab.com/xmake-mirror/python-releases/-/raw/$(version)/python-$(version).win64.tar.gz")
add_versions("2.7.15", "c81c4604b4176ff26be8d37cf48a2582e71a5e8f475b531c2e5d032a39511acb")
add_versions("2.7.18", "a51d27c9f64cd28415ea0a8fdcb2ffda113ce61267f5f05c9af7fd00e27c9376")
else
if is_arch("x86", "i386") or os.arch() == "x86" then
add_urls("https://cdn.jsdelivr.net/gh/xmake-mirror/python-releases@$(version)/python-$(version).win32.tar.gz",
"https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win32.tar.gz",
"https://gitlab.com/xmake-mirror/python-releases/-/raw/$(version)/python-$(version).win32.tar.gz")
add_versions("2.7.15", "4a7be2b440b74776662daaeb6bb6c5574bb6d0f4ddc0ad03ce63571ab2353303")
add_versions("2.7.18", "e80770ae6a10e8bccb56b378cb75a1c28c2762926205923b2fd51ce266e4baad")
add_versions("2.7.18", "9efaf273aa2e7d23fa22efa2936619ec91cf9ee189f707e375f9063fadeabcd6")
else
add_urls("https://cdn.jsdelivr.net/gh/xmake-mirror/python-releases@$(version)/python-$(version).win64.tar.gz",
"https://github.com/xmake-mirror/python-releases/raw/$(version)/python-$(version).win64.tar.gz",
"https://gitlab.com/xmake-mirror/python-releases/-/raw/$(version)/python-$(version).win64.tar.gz")
add_versions("2.7.15", "c81c4604b4176ff26be8d37cf48a2582e71a5e8f475b531c2e5d032a39511acb")
add_versions("2.7.18", "0e1adec089c4358b4ff1cd392c8bd7c975e0bf7c279aee91e7aaa04c00fb2c10")
end
else
set_urls("https://www.python.org/ftp/python/$(version)/Python-$(version).tgz",
@ -24,7 +24,7 @@ package("python2")
add_versions("2.7.18", "da3080e3b488f648a3d7a4560ddee895284c3380b11d6de75edb986526b9a814")
end
if not is_plat(os.host()) or not is_arch(os.arch()) then
if not is_plat(os.host()) then
set_kind("binary")
end
@ -36,70 +36,71 @@ package("python2")
add_syslinks("util", "pthread", "dl")
end
add_resources("2.7.x", "setuptools", "https://files.pythonhosted.org/packages/b2/40/4e00501c204b457f10fe410da0c97537214b2265247bc9a5bc6edd55b9e4/setuptools-44.1.1.zip", "c67aa55db532a0dadc4d2e20ba9961cbd3ccc84d544e9029699822542b5a476b")
add_resources("2.7.x", "pip", "https://files.pythonhosted.org/packages/0b/f5/be8e741434a4bf4ce5dbc235aa28ed0666178ea8986ddc10d035023744e6/pip-20.2.4.tar.gz", "85c99a857ea0fb0aedf23833d9be5c40cf253fe24443f0829c7b472e23c364a1")
add_resources("2.7.x", "wheel", "https://files.pythonhosted.org/packages/59/b0/11710a598e1e148fb7cbf9220fd2a0b82c98e94efbdecb299cb25e7f0b39/wheel-0.33.6.tar.gz", "10c9da68765315ed98850f8e048347c3eb06dd81822dc2ab1d4fde9dc9702646")
on_load("@windows", "@msys", "@cygwin", function (package)
on_load(function (package)
-- set includedirs
package:add("includedirs", "include")
-- add PATH
-- set python environments
local PYTHONPATH = package:installdir("Lib", "site-packages")
package:addenv("PYTHONPATH", PYTHONPATH)
package:addenv("PATH", "bin")
package:addenv("PATH", "Scripts")
end)
on_load("@macosx", "@linux", function (package)
-- set includedirs
local version = package:version()
local pyver = ("python%d.%d"):format(version:major(), version:minor())
if package:is_plat("windows") then
package:add("includedirs", "include")
else
package:add("includedirs", path.join("include", pyver))
end
package:add("includedirs", path.join("include", pyver))
-- set python environments
local envs = {}
envs.PYTHONPATH = package:installdir("lib", pyver, "site-packages")
package:addenv("PYTHONPATH", envs.PYTHONPATH)
-- define install_resources()
package:data_set("install_resources", function()
-- imports
import("lib.detect.find_file")
-- install resources
local python = path.join(package:installdir("bin"), "python" .. (is_host("windows") and ".exe" or ""))
for _, name in ipairs({"setuptools", "pip", "wheel"}) do
local resourcedir = assert(package:resourcedir(name), "resource(%s): not found!", name)
local setupfile = assert(find_file("setup.py", path.join(resourcedir, "*")), "resource(%s): setup.py not found!", name)
local oldir = os.cd(path.directory(setupfile))
os.vrunv(python, {"setup.py", "install", "--prefix=" .. package:installdir()}, {envs = envs})
os.cd(oldir)
end
end)
local PYTHONPATH = package:installdir("lib", pyver, "site-packages")
package:addenv("PYTHONPATH", PYTHONPATH)
package:addenv("PATH", "bin")
end)
on_install("@windows", "@msys", "@cygwin", function (package)
os.cp("python.exe", path.join(package:installdir("bin"), "python2.exe"))
os.mv("*.exe", package:installdir("bin"))
os.mv("*.dll", package:installdir("bin"))
os.mv("Lib", package:installdir())
os.mv("libs/*", package:installdir("lib"))
os.cp("*|libs", package:installdir())
package:data("install_resources")()
local python = path.join(package:installdir("bin"), "python.exe")
os.vrunv(python, {"-m", "pip", "install", "wheel"})
end)
on_install("@macosx", "@linux", function (package)
-- init configs
local configs = {"--enable-ipv6", "--without-ensurepip"}
local configs = {"--enable-ipv6", "--with-ensurepip"}
table.insert(configs, "--datadir=" .. package:installdir("share"))
table.insert(configs, "--datarootdir=" .. package:installdir("share"))
-- add openssl libs path for detecting
local openssl_dir = package:dep("openssl"):installdir()
io.gsub("setup.py", "/usr/local/ssl", openssl_dir)
-- allow python modules to use ctypes.find_library to find xmake's stuff
if is_host("macosx") then
io.gsub("Lib/ctypes/macholib/dyld.py", "DEFAULT_LIBRARY_FALLBACK = %[", format("DEFAULT_LIBRARY_FALLBACK = [ '%s/lib',", package:installdir()))
end
-- add flags
local cflags = {}
local ldflags = {}
if package:is_plat("macosx") then
local xcode_dir = get_config("xcode")
local xcode_dir = get_config("xcode")
local xcode_sdkver = get_config("xcode_sdkver") or get_config("xcode_sdkver_macosx")
if not xcode_dir or not xcode_sdkver then
-- maybe on cross platform, we need find xcode envs manually
local xcode = import("detect.sdks.find_xcode")(nil, {force = true, plat = package:plat(), arch = package:arch()})
if xcode then
xcode_dir = xcode.sdkdir
xcode_sdkver = xcode.sdkver
end
end
if xcode_dir and xcode_sdkver then
-- help Python's build system (setuptools/pip) to build things on SDK-based systems
-- the setup.py looks at "-isysroot" to get the sysroot (and not at --sysroot)
@ -115,6 +116,12 @@ package("python2")
-- avoid linking to libgcc https://mail.python.org/pipermail/python-dev/2012-February/116205.html
local target_minver = get_config("target_minver") or get_config("target_minver_macosx")
if not target_minver then
local macos_ver = macos.version()
if macos_ver then
target_minver = macos_ver:major() .. "." .. macos_ver:minor()
end
end
if target_minver then
table.insert(configs, "MACOSX_DEPLOYMENT_TARGET=" .. target_minver)
end
@ -126,19 +133,14 @@ package("python2")
table.insert(configs, "LDFLAGS=" .. table.concat(ldflags, " "))
end
-- add openssl libs path for detecting
io.gsub("setup.py", "/usr/local/ssl", package:dep("openssl"):installdir())
-- allow python modules to use ctypes.find_library to find xmake's stuff
if is_host("macosx") then
io.gsub("Lib/ctypes/macholib/dyld.py", "DEFAULT_LIBRARY_FALLBACK = %[", format("DEFAULT_LIBRARY_FALLBACK = [ '%s/lib',", package:installdir()))
end
-- unset these so that installing pip and setuptools puts them where we want
-- and not into some other Python the user has installed.
import("package.tools.autoconf").configure(package, configs, {envs = {PYTHONHOME = "", PYTHONPATH = ""}})
os.vrunv("make", {"install", "-j4", "PYTHONAPPSDIR=" .. package:installdir()})
package:data("install_resources")()
-- install wheel
local python = path.join(package:installdir("bin"), "python")
os.vrunv(python, {"-m", "pip", "install", "wheel"})
end)
on_test(function (package)

@ -37,9 +37,9 @@ function _is_supported(instance, plat, arch, opt)
return ""
end)
if _pattern:trim() == "" and opt and opt.onlyhost then
_pattern = os.host()
_pattern = os.subhost()
end
if not _pattern:startswith("__") and (not hosts_spec or hosts[os.host() .. '|' .. os.arch()] or hosts[os.host()])
if not _pattern:startswith("__") and (not hosts_spec or hosts[os.subhost() .. '|' .. os.subarch()] or hosts[os.subhost()])
and (_pattern:trim() == "" or (plat .. '|' .. arch):find('^' .. _pattern .. '$') or plat:find('^' .. _pattern .. '$')) then
result = _script
break

@ -89,7 +89,7 @@ end
function _package_is_supported(argv, packagename)
local packages = get_packages()
if packages then
local plat = argv.plat or os.host()
local plat = argv.plat or os.subhost()
local packages_plat = packages[plat]
for _, package in ipairs(packages_plat) do
if package and packagename:split("%s+")[1] == package.name then
@ -132,7 +132,7 @@ function main(...)
end
end
if #packages == 0 then
print("no testable packages on %s!", argv.plat or os.host())
print("no testable packages on %s!", argv.plat or os.subhost())
return
end

Loading…
Cancel
Save