gnu: libdbi-drivers: Adapt to multiple-output MariaDB.

* gnu/packages/databases.scm (mariadb/fixed-install-db): New public variable.
(libdbi-drivers)[inputs]: Add MARIADB:DEV and MARIADB:LIB.  Remove MARIADB.
[native-inputs]: Add MARIADB/FIXED-INSTALL-DB.
[arguments]: Adjust accordingly.
This commit is contained in:
Marius Bakke 2019-12-18 22:20:07 +01:00
parent ab7010af1f
commit 9077cf68ec
No known key found for this signature in database
GPG key ID: A2A06DF2A33A54FA

View file

@ -17,7 +17,7 @@
;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org> ;;; Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
;;; Copyright © 2016 Andy Patterson <ajpatter@uwaterloo.ca> ;;; Copyright © 2016 Andy Patterson <ajpatter@uwaterloo.ca>
;;; Copyright © 2016 Danny Milosavljevic <dannym+a@scratchpost.org> ;;; Copyright © 2016 Danny Milosavljevic <dannym+a@scratchpost.org>
;;; Copyright © 2016, 2017, 2018 Marius Bakke <mbakke@fastmail.com> ;;; Copyright © 2016, 2017, 2018, 2019 Marius Bakke <mbakke@fastmail.com>
;;; Copyright © 2017, 2018 Julien Lepiller <julien@lepiller.eu> ;;; Copyright © 2017, 2018 Julien Lepiller <julien@lepiller.eu>
;;; Copyright © 2017 Thomas Danckaert <post@thomasdanckaert.be> ;;; Copyright © 2017 Thomas Danckaert <post@thomasdanckaert.be>
;;; Copyright © 2017 Jelle Licht <jlicht@fsfe.org> ;;; Copyright © 2017 Jelle Licht <jlicht@fsfe.org>
@ -125,6 +125,7 @@ (define-module (gnu packages databases)
#:use-module (guix build-system ruby) #:use-module (guix build-system ruby)
#:use-module (guix build-system cmake) #:use-module (guix build-system cmake)
#:use-module (guix build-system scons) #:use-module (guix build-system scons)
#:use-module (guix build-system trivial)
#:use-module ((guix build utils) #:hide (which)) #:use-module ((guix build utils) #:hide (which))
#:use-module (guix utils) #:use-module (guix utils)
#:use-module (srfi srfi-1) #:use-module (srfi srfi-1)
@ -899,6 +900,33 @@ (define-public mariadb
as a drop-in replacement of MySQL.") as a drop-in replacement of MySQL.")
(license license:gpl2))) (license license:gpl2)))
;; TODO: mysql_install_db is broken in MariaDB. This package is here as
;; a workaround for packages that need it. Merge with 'mariadb' in the next
;; rebuild cycle.
(define-public mariadb/fixed-install-db
(hidden-package
(package/inherit
mariadb
(name "mariadb-fixed")
(native-inputs '())
(inputs
`(("mariadb" ,mariadb)
("mariadb:lib" ,mariadb "lib")))
(outputs '("out"))
(build-system trivial-build-system)
(arguments
`(#:modules ((guix build utils))
#:builder
(begin
(use-modules ((guix build utils)))
(let ((out (assoc-ref %outputs "out")))
(copy-recursively (assoc-ref %build-inputs "mariadb") out)
(substitute* (string-append out "/bin/mysql_install_db")
(("\\$basedir/share/mysql")
(string-append (assoc-ref %build-inputs "mariadb:lib")
"/share/mysql")))
#t)))))))
;; Don't forget to update the other postgresql packages when upgrading this one. ;; Don't forget to update the other postgresql packages when upgrading this one.
(define-public postgresql (define-public postgresql
(package (package
@ -3233,25 +3261,29 @@ (define-public libdbi-drivers
"0m680h8cc4428xin4p733azysamzgzcmv4psjvraykrsaz6ymlj3")))) "0m680h8cc4428xin4p733azysamzgzcmv4psjvraykrsaz6ymlj3"))))
(build-system gnu-build-system) (build-system gnu-build-system)
(native-inputs (native-inputs
`(("inetutils" ,inetutils) `(;; For tests.
("glibc-locales" ,glibc-locales))) ("inetutils" ,inetutils)
("glibc-locales" ,glibc-locales)
("mariadb" ,mariadb/fixed-install-db)))
(inputs (inputs
`(("libdbi" ,libdbi) `(("libdbi" ,libdbi)
("mysql" ,mariadb) ("mariadb:dev" ,mariadb "dev")
("mariadb:lib" ,mariadb "lib")
("postgresql" ,postgresql) ("postgresql" ,postgresql)
("sqlite" ,sqlite))) ("sqlite" ,sqlite)))
(arguments (arguments
`(#:configure-flags `(#:configure-flags
(let ((libdbi (assoc-ref %build-inputs "libdbi")) (let ((libdbi (assoc-ref %build-inputs "libdbi"))
(mysql (assoc-ref %build-inputs "mysql")) (mysql:inc (assoc-ref %build-inputs "mariadb:dev"))
(mysql:lib (assoc-ref %build-inputs "mariadb:lib"))
(postgresql (assoc-ref %build-inputs "postgresql")) (postgresql (assoc-ref %build-inputs "postgresql"))
(sqlite (assoc-ref %build-inputs "sqlite"))) (sqlite (assoc-ref %build-inputs "sqlite")))
(list "--disable-docs" (list "--disable-docs"
(string-append "--with-dbi-incdir=" libdbi "/include") (string-append "--with-dbi-incdir=" libdbi "/include")
(string-append "--with-dbi-libdir=" libdbi "/lib") (string-append "--with-dbi-libdir=" libdbi "/lib")
"--with-mysql" "--with-mysql"
(string-append "--with-mysql-incdir=" mysql "/include/mysql") (string-append "--with-mysql-incdir=" mysql:inc "/include/mysql")
(string-append "--with-mysql-libdir=" mysql "/lib") (string-append "--with-mysql-libdir=" mysql:lib "/lib")
"--with-pgsql" "--with-pgsql"
(string-append "--with-pgsql-incdir=" postgresql "/include") (string-append "--with-pgsql-incdir=" postgresql "/include")
(string-append "--with-pgsql-libdir=" postgresql "/lib") (string-append "--with-pgsql-libdir=" postgresql "/lib")
@ -3265,7 +3297,7 @@ (define-public libdbi-drivers
(substitute* "tests/test_mysql.sh" (substitute* "tests/test_mysql.sh"
(("^MYMYSQLD=.*") (("^MYMYSQLD=.*")
(string-append "MYMYSQLD=" (string-append "MYMYSQLD="
(assoc-ref inputs "mysql") (assoc-ref inputs "mariadb")
"/bin/mysqld"))) "/bin/mysqld")))
#t)) #t))
(add-after 'install 'remove-empty-directories (add-after 'install 'remove-empty-directories