diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 230 |
1 files changed, 230 insertions, 0 deletions
diff --git a/PKGBUILD b/PKGBUILD new file mode 100644 index 000000000000..1ad00cbc15eb --- /dev/null +++ b/PKGBUILD @@ -0,0 +1,230 @@ +# Maintainer: Daniel Bermond < yahoo-com: danielbermond > + +pkgname=wine-staging-git +pkgver=1.9.6.r34.g96fddf8+wine.1.9.6.r144.g4315cae +pkgrel=1 +pkgdesc="A compatibility layer for running Windows programs (staging branch, Git version)" +arch=('i686' 'x86_64') +url="https://github.com/wine-compholio/wine-staging/" +license=('LGPL') +_depends=( + 'attr' 'lib32-attr' + 'fontconfig' 'lib32-fontconfig' + 'lcms2' 'lib32-lcms2' + 'libxml2' 'lib32-libxml2' + 'libxcursor' 'lib32-libxcursor' + 'libxrandr' 'lib32-libxrandr' + 'libxdamage' 'lib32-libxdamage' + 'libxi' 'lib32-libxi' + 'gettext' 'lib32-gettext' + 'freetype2' 'lib32-freetype2' + 'glu' 'lib32-glu' + 'libsm' 'lib32-libsm' + 'gcc-libs' 'lib32-gcc-libs' + 'libpcap' 'lib32-libpcap' + 'desktop-file-utils' +) +makedepends=('git' 'autoconf' 'ncurses' 'bison' 'perl' 'fontforge' 'flex' + 'gcc>=4.5.0-2' 'gcc-multilib>=4.5.0-2' + 'giflib' 'lib32-giflib' + 'libpng' 'lib32-libpng' + 'gnutls' 'lib32-gnutls' + 'libxinerama' 'lib32-libxinerama' + 'libxcomposite' 'lib32-libxcomposite' + 'libxmu' 'lib32-libxmu' + 'libxxf86vm' 'lib32-libxxf86vm' + 'libldap' 'lib32-libldap' + 'mpg123' 'lib32-mpg123' + 'openal' 'lib32-openal' + 'v4l-utils' 'lib32-v4l-utils' + 'alsa-lib' 'lib32-alsa-lib' + 'libxcomposite' 'lib32-libxcomposite' + 'mesa' 'lib32-mesa' + 'libgl' 'lib32-libgl' + 'libcl' 'lib32-libcl' + 'libxslt' 'lib32-libxslt' + 'libpulse' 'lib32-libpulse' + 'libva' 'lib32-libva' + 'gtk3' 'lib32-gtk3' + 'gst-plugins-base-libs' 'lib32-gst-plugins-base-libs' + 'samba' + 'opencl-headers' +) +optdepends=( + 'giflib' 'lib32-giflib' + 'libpng' 'lib32-libpng' + 'libldap' 'lib32-libldap' + 'gnutls' 'lib32-gnutls' + 'mpg123' 'lib32-mpg123' + 'openal' 'lib32-openal' + 'v4l-utils' 'lib32-v4l-utils' + 'libpulse' 'lib32-libpulse' + 'alsa-plugins' 'lib32-alsa-plugins' + 'alsa-lib' 'lib32-alsa-lib' + 'libjpeg-turbo' 'lib32-libjpeg-turbo' + 'libxcomposite' 'lib32-libxcomposite' + 'libxinerama' 'lib32-libxinerama' + 'ncurses' 'lib32-ncurses' + 'libcl' 'lib32-libcl' + 'libxslt' 'lib32-libxslt' + 'libva' 'lib32-libva' + 'gtk3' 'lib32-gtk3' + 'gst-plugins-base-libs' 'lib32-gst-plugins-base-libs' + 'cups' 'dosbox' + 'samba' +) +options=('staticlibs') +install=wine-staging.install +source=(wine-git::'git://source.winehq.org/git/wine.git' + "$pkgname"::'git+https://github.com/wine-compholio/wine-staging.git' + '30-win32-aliases.conf') +sha256sums=('SKIP' + 'SKIP' + '9901a5ee619f24662b241672a7358364617227937d5f6d3126f70528ee5111e7') + +if [ "$CARCH" = "i686" ]; then + # Strip lib32 etc. on i686 + _depends=(${_depends[@]/*32-*/}) + makedepends=(${makedepends[@]/*32-*/} ${_depends[@]}) + makedepends=(${makedepends[@]/*-multilib*/}) + optdepends=(${optdepends[@]/*32-*/}) + provides=( + "wine=$(echo ${pkgver} | grep -o '+.*' | cut -c7-)" + "wine-staging=$(echo ${pkgver} | grep -o '.*+' | sed 's/.\{1\}$//')" + 'wine-git' + ) + conflicts=('wine' 'wine-staging' 'wine-git') +else + makedepends=(${makedepends[@]} ${_depends[@]}) + provides=( + "wine=$(echo ${pkgver} | grep -o '+.*' | cut -c7-)" + "wine-wow64=$(echo ${pkgver} | grep -o '+.*' | cut -c7-)" + "wine-staging=$(echo ${pkgver} | grep -o '.*+' | sed 's/.\{1\}$//')" + 'wine-git' + ) + conflicts=('wine' 'wine-wow64' 'wine-staging' 'wine-git') +fi + +pkgver() { + cd "${srcdir}" + + printf "%s+%s" \ + "$(cd ${pkgname} && git describe --long \ + | sed 's/\([^-]*-g\)/r\1/;s/-/./g' \ + | sed -e "s/latest.release/$(git tag \ + | sort -hr \ + | head -1 \ + | cut -c2-)/g")" \ + "$(cd wine-git && git describe --long | sed 's/\([^-]*-g\)/r\1/;s/-/./g')" +} + +prepare() { + cd "$srcdir/wine-git" + + msg2 "Cleaning the wine source code tree..." + + # Restore the wine tree to its git origin state, without wine-staging patches + #+(necessary for reapllying wine-staging patches in succedent builds, + #+otherwise the patches will fail to be reapplied) + git reset --hard HEAD # Restore tracked files + git clean -d -x -f # Delete untracked files +} + +build() { + cd "${srcdir}" + + # Delete old build dirs (from previous builds) and make new ones + rm --recursive --force "$pkgname"-{32,64}-build + mkdir --parents "$pkgname"-32-build + + # Apply all wine-staging patches + msg2 "Applying wine-staging patches..." + ./"$pkgname"/patches/patchinstall.sh DESTDIR="${srcdir}/wine-git" --all + + + # Build wine 64-bit + #+(according to the wine wiki this 64-bit/32-bit building order is mandatory) + + if [ "$CARCH" = "x86_64" ]; then + msg2 "Building Wine-64..." + + mkdir --parents "$pkgname"-64-build + cd "$pkgname"-64-build + + ../wine-git/configure \ + --prefix=/usr \ + --libdir=/usr/lib \ + --with-x \ + --with-gstreamer \ + --enable-win64 \ + --with-xattr + + make + + _wine32opts=( + --libdir=/usr/lib32 + --with-wine64="${srcdir}/${pkgname}-64-build" + ) + + export PKG_CONFIG_PATH="/usr/lib32/pkgconfig" + + fi + + + # Build wine 32-bit + + msg2 "Building Wine-32..." + + cd "$srcdir"/"$pkgname"-32-build + + ../wine-git/configure \ + --prefix=/usr \ + --with-x \ + --with-gstreamer \ + --with-xattr \ + "${_wine32opts[@]}" + + make + +} + +package() { + depends=(${_depends[@]}) + + # Package wine 32-bit + #+(according to the wine wiki this reverse 32-bit/64-bit packaging order is important) + + msg2 "Packaging Wine-32..." + + cd "$srcdir"/"$pkgname"-32-build + + if [ "$CARCH" = "i686" ]; then + + make prefix="$pkgdir/usr" install + + else + + make prefix="${pkgdir}/usr" \ + libdir="${pkgdir}/usr/lib32" \ + dlldir="${pkgdir}/usr/lib32/wine" install + + + # Package wine 64-bit + + msg2 "Packaging Wine-64..." + + cd "$srcdir"/"$pkgname"-64-build + + make prefix="${pkgdir}/usr" \ + libdir="${pkgdir}/usr/lib" \ + dlldir="${pkgdir}/usr/lib/wine" install + + fi + + + # Font aliasing settings for Win32 applications + + install -d "$pkgdir"/etc/fonts/conf.{avail,d} + install -m644 "${srcdir}/30-win32-aliases.conf" "${pkgdir}/etc/fonts/conf.avail" + ln -s ../conf.avail/30-win32-aliases.conf "${pkgdir}/etc/fonts/conf.d/30-win32-aliases.conf" +} |