PKGBUILDs/extra/mysql-workbench/PKGBUILD

214 lines
8.4 KiB
Bash
Raw Normal View History

2015-10-26 18:28:25 +00:00
# Maintainer: Christian Hesse <mail@eworm.de>
# Contributor: Alexandre Boily <alexandreboily@gmail.com>
# Contributor: Illarion Kovalchuk <illarion.kovalchuk@gmail.com>
# Contributor: totoloco <totoloco at gmail _dot_com>
# Contributor: Ionut Biru <ibiru@archlinux.org>
# ALARM: Kevin Mihelich <kevin@archlinuxarm.org>
2024-05-15 00:39:32 +00:00
# - add -fsigned-char to CXXFLAGS
2015-10-26 18:28:25 +00:00
2016-10-21 18:26:59 +00:00
highmem=1
2024-05-15 00:39:32 +00:00
buildarch=8
2016-10-21 18:26:59 +00:00
2015-10-26 18:28:25 +00:00
pkgname=mysql-workbench
2024-07-03 12:12:11 +00:00
pkgver=8.0.38
2024-09-17 13:14:13 +00:00
pkgrel=6
2024-07-23 14:22:34 +00:00
_mysql_version=8.4.2
2024-05-14 23:43:33 +00:00
_connector_version=8.4.0
2024-08-21 23:49:30 +00:00
_gdal_version=3.9.2
2022-04-26 12:56:50 +00:00
_boost_version=1.77.0
2022-04-21 01:09:20 +00:00
# bump the antlr4 version as required, this is to match the jar file name
2024-08-21 23:49:30 +00:00
_antlr4_version=4.13.2
2015-10-26 18:28:25 +00:00
pkgdesc='A cross-platform, visual database design tool developed by MySQL'
2017-11-17 23:37:18 +00:00
arch=('x86_64')
2015-10-26 18:28:25 +00:00
url='https://www.mysql.com/products/workbench/'
license=('GPL2')
2024-08-21 23:49:30 +00:00
depends=('antlr4-runtime' 'libantlr4-runtime.so'
'atkmm' 'libatkmm-1.6.so'
'at-spi2-core' 'libatk-1.0.so'
'cairo' 'libcairo.so'
'curl' 'libcurl.so'
'desktop-file-utils'
'expat' 'libexpat.so'
'freetype2'
'gcc-libs'
'gdk-pixbuf2' 'libgdk_pixbuf-2.0.so'
'giflib' 'libgif.so'
'glib2' 'libgio-2.0.so' 'libglib-2.0.so' 'libgmodule-2.0.so' 'libgobject-2.0.so'
'glibc'
'gtk3' 'libgdk-3.so' 'libgtk-3.so'
'gtkmm3' 'libgtkmm-3.0.so' #'libgdkmm-3.0.so'
'hicolor-icon-theme'
'json-c' 'libjson-c.so'
'libaio'
'libarchive' 'libarchive.so'
'libgl' 'libGLX.so' 'libOpenGL.so'
2024-09-17 13:14:13 +00:00
'libjpeg-turbo' 'libjpeg.so'
2024-08-21 23:49:30 +00:00
'libpng' 'libpng16.so'
'libsecret' 'libsecret-1.so'
'libssh' 'libssh.so'
'libtiff' 'libtiff.so'
'libx11'
'libxml2' 'libxml2.so'
'libzip' 'libzip.so'
'lz4' 'liblz4.so'
'ncurses' 'libncursesw.so'
'openssl' 'libcrypto.so' 'libssl.so'
'pango' 'libpango-1.0.so' 'libpangocairo-1.0.so'
'pcre2' 'libpcre2-8.so'
'proj' #'libproj.so'
'python'
'rapidjson'
'sqlite' 'libsqlite3.so'
'unixodbc' #'libodbc.so'
'vsqlite++' #'libvsqlitepp.so'
'xz' 'liblzma.so'
'zlib' 'libz.so'
'zstd' 'libzstd.so')
2022-04-21 01:09:20 +00:00
makedepends=('cmake' 'boost' 'mesa' 'swig' 'java-runtime' 'imagemagick'
2023-05-03 19:15:48 +00:00
"antlr4=${_antlr4_version}" "antlr4-runtime=${_antlr4_version}")
2024-01-17 01:24:14 +00:00
validpgpkeys=('BCA43417C3B485DD128EC6D4B7B3B788A8D3785C') # MySQL Release Engineering <mysql-build@oss.oracle.com>
2016-11-22 01:17:41 +00:00
source=("https://cdn.mysql.com/Downloads/MySQLGUITools/mysql-workbench-community-${pkgver}-src.tar.gz"{,.asc}
"https://cdn.mysql.com/Downloads/MySQL-${_mysql_version%.*}/mysql-${_mysql_version}.tar.gz"{,.asc}
2018-07-30 13:50:44 +00:00
"https://cdn.mysql.com/Downloads/Connector-C++/mysql-connector-c++-${_connector_version}-src.tar.gz"{,.asc}
2019-10-14 11:09:53 +00:00
"https://download.osgeo.org/gdal/${_gdal_version}/gdal-${_gdal_version}.tar.xz"
2016-01-20 14:39:07 +00:00
"https://downloads.sourceforge.net/project/boost/boost/${_boost_version}/boost_${_boost_version//./_}.tar.bz2"
2015-10-26 18:28:25 +00:00
'0001-mysql-workbench-no-check-for-updates.patch'
2017-02-09 01:21:13 +00:00
'0002-disable-unsupported-operating-system-warning.patch'
2015-10-26 18:28:25 +00:00
'arch_linux_profile.xml')
2024-07-03 12:12:11 +00:00
sha256sums=('5b646c03684845468d44ad10e6937560e0db122c3a1c4ddc7de8ac3dd51c60f6'
2015-10-26 18:28:25 +00:00
'SKIP'
2024-07-23 14:22:34 +00:00
'5657a78dc86bf0bf2227e0b05f8de5a2c447a816a112ffa26fa70083bcbe9814'
2016-01-20 14:39:07 +00:00
'SKIP'
2024-05-14 23:43:33 +00:00
'540b3d3b4d20ecf9f900bf55bba870718e50672f54fa2cdb124adf385796ce8b'
2016-01-20 14:39:07 +00:00
'SKIP'
2024-08-21 23:49:30 +00:00
'bfbcc9f087f012c36151c20c79f8eac9529e1e5298fbded79cd5a1365f0b113a'
2022-04-26 12:56:50 +00:00
'fc9f85fc030e233142908241af7a846e60630aa7388de9a5fafb1f3a26840854'
2018-07-30 13:50:44 +00:00
'cdf687f23bc6e8d52dbee9fa02b23d755e80f88476f0fc2e7c4c71cdfed3792f'
'2d0f6dcf38f22e49ef7ab9de0230484f1ffac41b7ac40feaf5ef4538ae2f7a18'
2022-01-18 13:36:28 +00:00
'd816164098c90c432b4fe590708c14f95ab137abfe16ad1b7d498b2e83c0e265')
2015-10-26 18:28:25 +00:00
prepare() {
cd "${srcdir}/mysql-workbench-community-${pkgver}-src/"
# Disable 'Help' -> 'Check for Updates'
# Updates are provided via Arch Linux packages
patch -Np1 < "${srcdir}"/0001-mysql-workbench-no-check-for-updates.patch
2017-02-09 01:21:13 +00:00
# disable unsupported operating system warning
patch -Np1 < "${srcdir}"/0002-disable-unsupported-operating-system-warning.patch
2021-07-20 13:03:10 +00:00
# remove '-Werror'
sed -i '/^\s*set/s| -Werror||' CMakeLists.txt
2017-07-20 12:32:44 +00:00
2024-07-03 12:12:11 +00:00
# work around crashes on query:
# disable LTO (link time optimization) for libsqlparser.so
# TODO: drop when fixed!
sed -i '/target_compile_options/s|PRIVATE|PRIVATE -fno-lto|' library/sql.parser/source/CMakeLists.txt
2018-07-30 23:23:10 +00:00
2020-10-20 14:53:46 +00:00
# be happy with more recent antlr
2023-05-09 23:10:55 +00:00
sed -i "/set(ANTLR_JAR_FILENAME/s/4.11.1/${_antlr4_version}/" CMakeLists.txt
2015-10-26 18:28:25 +00:00
}
build() {
2016-01-20 14:39:07 +00:00
# Build mysql
2018-07-30 13:50:44 +00:00
mkdir "${srcdir}/mysql-${_mysql_version}-build"
cd "${srcdir}/mysql-${_mysql_version}-build"
2018-10-17 12:27:06 +00:00
echo "Configure mysql..."
2018-07-30 13:50:44 +00:00
cmake "${srcdir}/mysql-${_mysql_version}" \
2017-07-20 12:32:44 +00:00
-DWITHOUT_SERVER=ON \
2016-01-20 14:39:07 +00:00
-DBUILD_CONFIG=mysql_release \
-DCMAKE_INSTALL_PREFIX=/usr \
-DSYSCONFDIR=/etc/mysql \
-DMYSQL_DATADIR=/var/lib/mysql \
-DWITH_BOOST="${srcdir}/boost_${_boost_version//./_}"
2018-10-17 12:27:06 +00:00
echo "Build mysql..."
2018-07-30 13:50:44 +00:00
make
2018-10-17 12:27:06 +00:00
echo "Install mysql..."
2016-01-20 14:39:07 +00:00
make DESTDIR="${srcdir}/install-bundle/" install
# Build mysql-connector-c++
2018-07-30 13:50:44 +00:00
mkdir "${srcdir}/mysql-connector-c++-${_connector_version}-src-build"
cd "${srcdir}/mysql-connector-c++-${_connector_version}-src-build"
2018-10-17 12:27:06 +00:00
echo "Configure mysql-connector-c++..."
2018-07-30 13:50:44 +00:00
cmake "${srcdir}/mysql-connector-c++-${_connector_version}-src" \
2016-01-20 14:39:07 +00:00
-Wno-dev \
-DCMAKE_INSTALL_PREFIX=/usr \
-DCMAKE_BUILD_TYPE=Release \
2018-07-30 13:50:44 +00:00
-DINSTALL_LIB_DIR=lib \
2016-01-20 14:39:07 +00:00
-DMYSQL_DIR="${srcdir}/install-bundle/" \
2018-07-30 13:50:44 +00:00
-DMYSQL_CONFIG_EXECUTABLE="${srcdir}/install-bundle/usr/bin/mysql_config" \
-DWITH_JDBC=ON
2018-10-17 12:27:06 +00:00
echo "Build mysql-connector-c++..."
2018-07-30 13:50:44 +00:00
make
2018-10-17 12:27:06 +00:00
echo "Install mysql-connector-c++..."
2016-01-20 14:39:07 +00:00
make DESTDIR="${srcdir}/install-bundle/" install
# Build gdal
2023-01-17 14:22:40 +00:00
cd "${srcdir}/"
2018-10-17 12:27:06 +00:00
echo "Configure gdal..."
2023-01-17 14:22:40 +00:00
cmake -B build-gdal -S "${srcdir}/gdal-${_gdal_version}" \
-DCMAKE_INSTALL_PREFIX='/usr' \
-DGDAL_USE_JASPER='OFF' \
2024-01-17 01:24:14 +00:00
-DGDAL_USE_MYSQL='OFF' \
-DBUILD_CSHARP_BINDINGS='FALSE' \
-DBUILD_JAVA_BINDINGS='FALSE' \
-DBUILD_PYTHON_BINDINGS='FALSE'
2018-10-17 12:27:06 +00:00
echo "Build gdal..."
2023-01-17 14:22:40 +00:00
make LD_LIBRARY_PATH="${srcdir}/install-bundle/usr/lib/" -C build-gdal
2018-10-17 12:27:06 +00:00
echo "Install gdal..."
2023-01-17 14:22:40 +00:00
make LD_LIBRARY_PATH="${srcdir}/install-bundle/usr/lib/" DESTDIR="${srcdir}/install-bundle/" -C build-gdal install
ln -s '.' "${srcdir}/install-bundle/usr/include/gdal"
2018-07-30 13:50:44 +00:00
2016-01-20 14:39:07 +00:00
# Build MySQL Workbench itself with bundled libs
2018-07-30 13:50:44 +00:00
mkdir "${srcdir}/mysql-workbench-community-${pkgver}-src-build"
cd "${srcdir}/mysql-workbench-community-${pkgver}-src-build"
2018-10-17 12:27:06 +00:00
echo "Configure mysql-workbench..."
2018-07-30 13:50:44 +00:00
cmake "${srcdir}/mysql-workbench-community-${pkgver}-src" \
-Wno-dev \
2015-10-26 18:28:25 +00:00
-DCMAKE_INSTALL_PREFIX:PATH=/usr \
2024-07-03 12:12:11 +00:00
-DCMAKE_CXX_FLAGS="$CXXFLAGS -fsigned-char" \
2016-01-20 14:39:07 +00:00
-DCMAKE_BUILD_TYPE=Release \
-DMySQL_CONFIG_PATH="${srcdir}/install-bundle/usr/bin/mysql_config" \
2017-02-09 01:21:13 +00:00
-DMySQLCppConn_LIBRARY="${srcdir}/install-bundle/usr/lib/libmysqlcppconn.so" \
2018-07-30 13:50:44 +00:00
-DMySQLCppConn_INCLUDE_DIR="${srcdir}/install-bundle/usr/include/jdbc" \
2016-01-20 14:39:07 +00:00
-DGDAL_INCLUDE_DIR="${srcdir}/install-bundle/usr/include" \
-DGDAL_LIBRARY="${srcdir}/install-bundle/usr/lib/libgdal.so" \
2023-04-18 12:44:08 +00:00
-DUNIXODBC_CONFIG_PATH='/usr/bin/odbc_config' \
-DUSE_BUNDLED_MYSQLDUMP=1 \
2023-05-03 19:15:48 +00:00
-DWITH_ANTLR_JAR="/usr/share/java/antlr-${_antlr4_version}-complete.jar"
2018-10-17 12:27:06 +00:00
echo "Build mysql-workbench..."
2015-10-26 18:28:25 +00:00
make
}
package() {
2018-08-23 12:34:38 +00:00
# install bundled libraries
for LIBRARY in $(find "${srcdir}/install-bundle/usr/lib/" -type f -regex '.*/lib\(gdal\|mysql\(client\|cppconn\)\)\.so\..*'); do
BASENAME="$(basename "${LIBRARY}")"
SONAME="$(readelf -d "${LIBRARY}" | grep -Po '(?<=(Library soname: \[)).*(?=\])')"
install -D -m0755 "${LIBRARY}" "${pkgdir}"/usr/lib/mysql-workbench/"${BASENAME}"
ln -s "${BASENAME}" "${pkgdir}"/usr/lib/mysql-workbench/"${SONAME}"
2016-01-20 14:39:07 +00:00
done
2018-08-23 12:34:38 +00:00
# install bundled mysql and mysqldump
2016-01-20 14:39:07 +00:00
install -m0755 "${srcdir}/install-bundle/usr/bin/mysql"{,dump} "${pkgdir}"/usr/lib/mysql-workbench/
# install MySQL Workbench itself
2018-07-30 13:50:44 +00:00
cd "${srcdir}/mysql-workbench-community-${pkgver}-src-build"
2015-10-26 18:28:25 +00:00
make DESTDIR="${pkgdir}" install
# icons
for SIZE in 16 24 32 48 64 96 128; do
2018-10-17 12:27:06 +00:00
# set modify/create for reproducible builds
2024-07-03 12:12:11 +00:00
magick \
2018-07-30 13:50:44 +00:00
"${srcdir}/mysql-workbench-community-${pkgver}-src/images/icons/MySQLWorkbench-128.png" \
2024-07-03 12:12:11 +00:00
-scale ${SIZE} +set date:create +set date:modify \
2018-07-30 13:50:44 +00:00
"${srcdir}/mysql-workbench.png"
install -D -m0644 "${srcdir}/mysql-workbench.png" "${pkgdir}/usr/share/icons/hicolor/${SIZE}x${SIZE}/apps/mysql-workbench.png"
2015-10-26 18:28:25 +00:00
done
install -D -m 0644 "${srcdir}"/arch_linux_profile.xml \
2016-01-20 14:39:07 +00:00
"${pkgdir}"/usr/share/mysql-workbench/mysql.profiles/Arch_Linux_\(MariaDB\).xml
2015-10-26 18:28:25 +00:00
}