Просмотр исходного кода

update python (#976)

* update python

* fix python

* improve fetch

* fix python envs

* add missing line
Hoildkv 3 лет назад
Родитель
Сommit
213331f704
2 измененных файлов с 38 добавлено и 39 удалено
  1. 2 0
      packages/p/python-launcher/xmake.lua
  2. 36 39
      packages/p/python/xmake.lua

+ 2 - 0
packages/p/python-launcher/xmake.lua

@@ -7,9 +7,11 @@ package("python-launcher")
     if is_arch("x86", "i386") or os.arch() == "x86" then
         add_urls("https://github.com/xmake-mirror/python-windows/releases/download/$(version)/python-launcher-$(version).win32.zip")
         add_versions("3.9.6", "73d712aaca09d7ada78bcf26dfc3346f655b4b1fed5b459133ce564b9c5f5663")
+        add_versions("3.9.10", "36f445e1569f4b0647080c7603c9a5f635f131b7f2ee5bf29d6c02e38d235b34")
     else
         add_urls("https://github.com/xmake-mirror/python-windows/releases/download/$(version)/python-launcher-$(version).win64.zip")
         add_versions("3.9.6", "fc2a54f47f07a193265cb844c0e1b165682c71a1655e92eb3c44f25bacc84b8a")
+        add_versions("3.9.10", "70df88a455fe2c87c62c0817decb7f54f198ff31ade093ce4d8ecc8cfd452b3f")
     end
 
     on_install("@windows", "@msys", "@cygwin", function (package)

+ 36 - 39
packages/p/python/xmake.lua

@@ -11,6 +11,7 @@ package("python")
             add_versions("3.8.10", "f520d2880578df076e3df53bf9e147b81b5328db02d8d873670a651fa076be50")
             add_versions("3.9.5", "ce0bfe8ced874d8d74a6cf6a98f13f5afee27cffbaf2d1ee0f09d3a027fab299")
             add_versions("3.9.6", "2918246384dfb233bd8f8c2bcf6aa3688e6834e84ab204f7c962147c468f8d12")
+            add_versions("3.9.10", "e2c8e6b792748289ac27ef8462478022c96e24c99c4c3eb97d3afe510d9db646")
         else
             add_urls("https://github.com/xmake-mirror/python-windows/releases/download/$(version)/python-$(version).win64.zip")
             add_versions("2.7.18", "6680835ed5b818e2c041c7033bea47ace17f6f3b73b0d6efb6ded8598a266754")
@@ -18,6 +19,7 @@ package("python")
             add_versions("3.8.10", "acf35048274404dd415e190bf5b928fae3b03d8bb5dfbfa504f9a183361468bd")
             add_versions("3.9.5", "3265059edac21bf4c46fac13553a5d78417e7aa209eceeffd0250aa1dd8d6fdf")
             add_versions("3.9.6", "57ccd1b1b5fbc62882bd2a6f47df6e830ba39af741acf0a1d2f161eef4e87f2e")
+            add_versions("3.9.10", "4cee67e2a529fe363e34f0da57f8e5c3fc036913dc838b17389b2319ead0927e")
         end
     else
         set_urls("https://www.python.org/ftp/python/$(version)/Python-$(version).tgz",
@@ -27,6 +29,7 @@ package("python")
         add_versions("3.8.10", "b37ac74d2cbad2590e7cd0dd2b3826c29afe89a734090a87bf8c03c45066cb65")
         add_versions("3.9.5", "e0fbd5b6e1ee242524430dee3c91baf4cbbaba4a72dd1674b90fda87b713c7ab")
         add_versions("3.9.6", "d0a35182e19e416fc8eae25a3dcd4d02d4997333e4ad1f2eee6010aadc3fe866")
+        add_versions("3.9.10", "1aa9c0702edbae8f6a2c95f70a49da8420aaa76b7889d3419c186bfc8c0e571e")
     end
 
     if not is_plat(os.host()) then
@@ -73,7 +76,7 @@ package("python")
     end)
 
     on_fetch(function (package, opt)
-        if opt.system then
+        if opt.system and package:is_binary() then
             local result = package:find_tool("python3", opt)
             if not result then
                 result = package:find_tool("python", opt)
@@ -94,7 +97,7 @@ package("python")
         os.cp("libs/*", package:installdir("lib"))
         os.cp("*", package:installdir())
         local python = path.join(package:installdir("bin"), "python.exe")
-        os.vrunv(python, {"-m", "pip", "install", "-U", "pip"})
+        os.vrunv(python, {"-m", "pip", "install", "--upgrade", "--force-reinstall", "pip"})
         os.vrunv(python, {"-m", "pip", "install", "wheel"})
     end)
 
@@ -105,9 +108,6 @@ package("python")
         table.insert(configs, "--datadir=" .. package:installdir("share"))
         table.insert(configs, "--datarootdir=" .. package:installdir("share"))
         table.insert(configs, "--enable-shared=" .. (package:config("shared") and "yes" or "no"))
-        if package:is_plat("linux") and package:config("pic") ~= false then
-            table.insert(configs, "--with-pic")
-        end
 
         -- add openssl libs path for detecting
         local openssl_dir
@@ -136,7 +136,7 @@ package("python")
         end
 
         -- add flags for macOS
-        local cflags = {}
+        local cppflags = {}
         local ldflags = {}
         if package:is_plat("macosx") then
 
@@ -179,13 +179,13 @@ package("python")
                 -- 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)
                 local xcode_sdkdir = xcode_dir .. "/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX" .. xcode_sdkver .. ".sdk"
-                table.insert(cflags, "-isysroot " .. xcode_sdkdir)
-                table.insert(cflags, "-I" .. path.join(xcode_sdkdir, "/usr/include"))
+                table.insert(cppflags, "-isysroot " .. xcode_sdkdir)
+                table.insert(cppflags, "-I" .. path.join(xcode_sdkdir, "/usr/include"))
                 table.insert(ldflags, "-isysroot " .. xcode_sdkdir)
 
                 -- for the Xlib.h, Python needs this header dir with the system Tk
                 -- yep, this needs the absolute path where zlib needed a path relative to the SDK.
-                table.insert(cflags, "-I" .. path.join(xcode_sdkdir, "/System/Library/Frameworks/Tk.framework/Versions/8.5/Headers"))
+                table.insert(cppflags, "-I" .. path.join(xcode_sdkdir, "/System/Library/Frameworks/Tk.framework/Versions/8.5/Headers"))
             end
 
             -- avoid linking to libgcc https://mail.python.org/pipermail/python-dev/2012-February/116205.html
@@ -193,38 +193,27 @@ package("python")
                 table.insert(configs, "MACOSX_DEPLOYMENT_TARGET=" .. target_minver)
             end
         end
-        if #cflags > 0 then
-            table.insert(configs, "CFLAGS=" .. table.concat(cflags, " "))
-        end
-        if #ldflags > 0 then
-            table.insert(configs, "LDFLAGS=" .. table.concat(ldflags, " "))
-        end
 
-        -- add zlib to fix `No module named 'zlib'`
-        local linkdirs = {}
-        local includedirs = {}
-        if package:is_plat("linux") then
-            local zlib = package:dep("zlib"):fetch({external = false})
-            if zlib then
-                table.join2(linkdirs, zlib.linkdirs)
-                table.join2(includedirs, zlib.includedirs)
-            end
-            -- add libffi to fix `No module named '_ctypes'`
-            local libffi = package:dep("libffi"):fetch({external = false})
-            if libffi then
-                table.join2(linkdirs, libffi.linkdirs)
-                table.join2(includedirs, libffi.includedirs)
+        -- add external path for zlib and libffi
+        for _, libname in ipairs({"zlib", "libffi"}) do
+            local lib = package:dep(libname)
+            if lib and not lib:is_system() then
+                local fetchinfo = lib:fetch({external = false})
+                if fetchinfo then
+                    for _, includedir in ipairs(fetchinfo.includedirs or fetchinfo.sysincludedirs) do
+                        table.insert(cppflags, "-I" .. includedir)
+                    end
+                    for _, linkdir in ipairs(fetchinfo.linkdirs) do
+                        table.insert(ldflags, "-L" .. linkdir)
+                    end
+                end
             end
         end
-        if #linkdirs > 0 and #includedirs > 0 then
-            io.replace("setup.py", "    def detect_modules(self):", format([[    def detect_modules(self):
-        linkdirs = ['%s']
-        includedirs = ['%s']
-        for includedir in includedirs:
-            add_dir_to_list(self.compiler.include_dirs, includedir)
-        for linkdir in linkdirs:
-            add_dir_to_list(self.compiler.library_dirs, linkdir)
-]], table.concat(linkdirs, "', '"), table.concat(includedirs, "', '")), {plain = true})
+        if #cppflags > 0 then
+            table.insert(configs, "CPPFLAGS=" .. table.concat(cppflags, " "))
+        end
+        if #ldflags > 0 then
+            table.insert(configs, "LDFLAGS=" .. table.concat(ldflags, " "))
         end
 
         -- unset these so that installing pip and setuptools puts them where we want
@@ -238,7 +227,15 @@ package("python")
 
         -- install wheel
         local python = path.join(package:installdir("bin"), "python")
-        os.vrunv(python, {"-m", "pip", "install", "wheel"})
+        local version = package:version()
+        local pyver = ("python%d.%d"):format(version:major(), version:minor())
+        local envs = {
+            PATH = package:installdir("bin"),
+            PYTHONPATH = package:installdir("lib", pyver, "site-packages"),
+            LD_LIBRARY_PATH = package:installdir("lib")
+        }
+        os.vrunv(python, {"-m", "pip", "install", "--upgrade", "--force-reinstall", "pip"}, {envs = envs})
+        os.vrunv(python, {"-m", "pip", "install", "wheel"}, {envs = envs})
     end)
 
     on_test(function (package)