summarylogtreecommitdiffstats
diff options
context:
space:
mode:
authorTobias Kunze2021-10-07 17:50:41 +0200
committerTobias Kunze2021-10-07 17:50:41 +0200
commit22da2cdd9e5346b186b5e6206935033990f880ed (patch)
tree7fc80b8f9ea48d989f3e0c447b291712ecf230a6
downloadaur-22da2cdd9e5346b186b5e6206935033990f880ed.tar.gz
Initial commit
-rw-r--r--.SRCINFO30
-rw-r--r--.gitignore4
-rw-r--r--PKGBUILD88
3 files changed, 122 insertions, 0 deletions
diff --git a/.SRCINFO b/.SRCINFO
new file mode 100644
index 000000000000..0716f2a1d5cf
--- /dev/null
+++ b/.SRCINFO
@@ -0,0 +1,30 @@
+pkgbase = python311
+ pkgdesc = Major release 3.11 of the Python high-level programming language
+ pkgver = 3.11.0a1
+ pkgrel = 3
+ url = https://www.python.org/
+ arch = i686
+ arch = x86_64
+ license = custom
+ makedepends = bluez-libs
+ makedepends = mpdecimal
+ makedepends = gdb
+ depends = bzip2
+ depends = expat
+ depends = gdbm
+ depends = libffi
+ depends = libnsl
+ depends = libxcrypt
+ depends = openssl
+ depends = zlib
+ optdepends = sqlite
+ optdepends = mpdecimal: for decimal
+ optdepends = xz: for lzma
+ optdepends = tk: for tkinter
+ provides = python
+ source = https://www.python.org/ftp/python/3.11.0a1/Python-3.11.0a1.tar.xz
+ validpgpkeys = 0D96DF4D4110E5C43FBFB17F2D347EA6AA65421D
+ validpgpkeys = E3FF2839C048B25C084DEBE9B26995E310250568
+ sha256sums = c163bd09fdc80116dafe97bf7c40ff3f
+
+pkgname = python311
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 000000000000..cb72d4b96a04
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,4 @@
+pkg
+src
+*.tar.xz
+*.pkg.tar.zst
diff --git a/PKGBUILD b/PKGBUILD
new file mode 100644
index 000000000000..a3ea5f82a818
--- /dev/null
+++ b/PKGBUILD
@@ -0,0 +1,88 @@
+# Maintainer: Tobias Kunze <r@rixx.de>
+# Maintained at https://github.com/rixx/pkgbuilds, feel free to submit patches
+
+pkgname=python311
+pkgver=3.11.0a1
+pkgrel=3
+_pyver=3.11.0
+_pybasever=3.11
+_pymajver=3
+pkgdesc="Major release 3.11 of the Python high-level programming language"
+arch=('i686' 'x86_64')
+license=('custom')
+url="https://www.python.org/"
+depends=('bzip2' 'expat' 'gdbm' 'libffi' 'libnsl' 'libxcrypt' 'openssl' 'zlib')
+makedepends=('bluez-libs' 'mpdecimal' 'gdb')
+optdepends=('sqlite' 'mpdecimal: for decimal' 'xz: for lzma' 'tk: for tkinter')
+source=(https://www.python.org/ftp/python/${_pyver}/Python-${pkgver}.tar.xz)
+sha256sums=('966319daafa40f337e4d85a0b26fbdd919135c321eb3961a9b3d758abbc95376')
+validpgpkeys=(
+ '0D96DF4D4110E5C43FBFB17F2D347EA6AA65421D' # Ned Deily (Python release signing key) <nad@python.org>
+ 'E3FF2839C048B25C084DEBE9B26995E310250568' # Ɓukasz Langa (GPG langa.pl) <lukasz@langa.pl>
+)
+provides=('python')
+
+prepare() {
+ cd "${srcdir}/Python-${pkgver}"
+
+ # FS#23997
+ sed -i -e "s|^#.* /usr/local/bin/python|#!/usr/bin/python|" Lib/cgi.py
+
+ # Ensure that we are using the system copy of various libraries (expat, zlib and libffi),
+ # rather than copies shipped in the tarball
+ rm -rf Modules/expat
+ rm -rf Modules/zlib
+ rm -rf Modules/_ctypes/{darwin,libffi}*
+ rm -rf Modules/_decimal/libmpdec
+}
+
+build() {
+ cd "${srcdir}/Python-${pkgver}"
+
+ CFLAGS="${CFLAGS} -fno-semantic-interposition"
+ ./configure --prefix=/usr \
+ --enable-shared \
+ --with-computed-gotos \
+ --with-lto \
+ --enable-ipv6 \
+ --with-system-expat \
+ --with-dbmliborder=gdbm:ndbm \
+ --with-system-ffi \
+ --with-system-libmpdec \
+ --enable-loadable-sqlite-extensions \
+ --without-ensurepip \
+ --with-tzpath=/usr/share/zoneinfo
+
+ make EXTRA_CFLAGS="$CFLAGS"
+}
+
+package() {
+ cd "${srcdir}/Python-${pkgver}"
+ # altinstall: /usr/bin/pythonX.Y but not /usr/bin/python or /usr/bin/pythonX
+ make DESTDIR="${pkgdir}" altinstall maninstall
+
+ # Split tests
+ rm -r "$pkgdir"/usr/lib/python*/{test,ctypes/test,distutils/tests,idlelib/idle_test,lib2to3/tests,sqlite3/test,tkinter/test,unittest/test}
+
+ # Avoid conflicts with the main 'python' package.
+ rm -f "${pkgdir}/usr/lib/libpython${_pymajver}.so"
+ rm -f "${pkgdir}/usr/share/man/man1/python${_pymajver}.1"
+
+ # Fix FS#22552
+ ln -sf ../../libpython${_pybasever}m.so \
+ "${pkgdir}/usr/lib/python${_pybasever}/config-${_pybasever}-${CARCH}-linux-gnu/libpython${_pybasever}m.so"
+
+ # Fix pycairo build
+ ln -sf python${_pybasever}m-config "${pkgdir}/usr/bin/python${_pybasever}-config"
+
+ # Clean-up reference to build directory
+ sed -i "s|$srcdir/Python-${pkgver}:||" "$pkgdir/usr/lib/python${_pybasever}/config-${_pybasever}-${CARCH}-linux-gnu/Makefile"
+
+ # Add useful scripts FS#46146
+ install -dm755 "${pkgdir}"/usr/lib/python${_pybasever}/Tools/{i18n,scripts}
+ install -m755 Tools/i18n/{msgfmt,pygettext}.py "${pkgdir}"/usr/lib/python${_pybasever}/Tools/i18n/
+ install -m755 Tools/scripts/{README,*py} "${pkgdir}"/usr/lib/python${_pybasever}/Tools/scripts/
+
+ # License
+ install -Dm644 LICENSE "${pkgdir}/usr/share/licenses/${pkgname}/LICENSE"
+}