class Mariadb < Formula desc "Drop-in replacement for MySQL" homepage "https://mariadb.org/" url "http://ftp.osuosl.org/pub/mariadb/mariadb-10.1.17/source/mariadb-10.1.17.tar.gz" sha256 "4ca45ac5e34418761868115ebc8c068d511fed08e283b2cac52559d63ba4aab5" bottle do sha256 "770fdd503441836a6f716f098621f9575ef4e30aeb3eb3020dfc294cdfd08903" => :sierra sha256 "f8fbb42cfb4c1efcf0f57fb21440d71f873be288e757963e8589c7aaa45739ba" => :el_capitan sha256 "df2ed260b120b609d6d317bfbb18299ccd3eeb6806d835d0da66ac5c211c0218" => :yosemite sha256 "1325bdb202569d0619ee257edceb6c81a20f37f434650933f4b52cb73fd3659a" => :mavericks end devel do url "http://ftp.osuosl.org/pub/mariadb/mariadb-10.2.1/source/mariadb-10.2.1.tar.gz" sha256 "90b7a17f3372c92c12dff084b37fcca8c4cf8106f4dcabd35fadc8efbaa348a2" # upstream fix for compilation error # https://jira.mariadb.org/browse/MDEV-10322 patch :DATA end option :universal option "with-test", "Keep test when installing" option "with-bench", "Keep benchmark app when installing" option "with-embedded", "Build the embedded server" option "with-libedit", "Compile with editline wrapper instead of readline" option "with-archive-storage-engine", "Compile with the ARCHIVE storage engine enabled" option "with-blackhole-storage-engine", "Compile with the BLACKHOLE storage engine enabled" option "with-local-infile", "Build with local infile loading support" deprecated_option "enable-local-infile" => "with-local-infile" deprecated_option "with-tests" => "with-test" depends_on "cmake" => :build depends_on "pidof" unless MacOS.version >= :mountain_lion depends_on "openssl" conflicts_with "mysql", "mysql-cluster", "percona-server", :because => "mariadb, mysql, and percona install the same binaries." conflicts_with "mysql-connector-c", :because => "both install MySQL client libraries" conflicts_with "mytop", :because => "both install `mytop` binaries" conflicts_with "mariadb-connector-c", :because => "both install plugins" def install # Don't hard-code the libtool path. See: # https://github.com/Homebrew/homebrew/issues/20185 inreplace "cmake/libutils.cmake", "COMMAND /usr/bin/libtool -static -o ${TARGET_LOCATION}", "COMMAND libtool -static -o ${TARGET_LOCATION}" # Set basedir and ldata so that mysql_install_db can find the server # without needing an explicit path to be set. This can still # be overridden by calling --basedir= when calling. inreplace "scripts/mysql_install_db.sh" do |s| s.change_make_var! "basedir", "\"#{prefix}\"" s.change_make_var! "ldata", "\"#{var}/mysql\"" end # Build without compiler or CPU specific optimization flags to facilitate # compilation of gems and other software that queries `mysql-config`. ENV.minimal_optimization # -DINSTALL_* are relative to prefix args = %W[ . -DCMAKE_INSTALL_PREFIX=#{prefix} -DCMAKE_FIND_FRAMEWORK=LAST -DCMAKE_VERBOSE_MAKEFILE=ON -DMYSQL_DATADIR=#{var}/mysql -DINSTALL_INCLUDEDIR=include/mysql -DINSTALL_MANDIR=share/man -DINSTALL_DOCDIR=share/doc/#{name} -DINSTALL_INFODIR=share/info -DINSTALL_MYSQLSHAREDIR=share/mysql -DWITH_SSL=yes -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DINSTALL_SYSCONFDIR=#{etc} -DCOMPILATION_COMMENT=Homebrew ] # disable TokuDB, which is currently not supported on Mac OS X args << "-DPLUGIN_TOKUDB=NO" args << "-DWITH_UNIT_TESTS=OFF" if build.without? "test" # Build the embedded server args << "-DWITH_EMBEDDED_SERVER=ON" if build.with? "embedded" # Compile with readline unless libedit is explicitly chosen args << "-DWITH_READLINE=yes" if build.without? "libedit" # Compile with ARCHIVE engine enabled if chosen args << "-DPLUGIN_ARCHIVE=YES" if build.with? "archive-storage-engine" # Compile with BLACKHOLE engine enabled if chosen args << "-DPLUGIN_BLACKHOLE=YES" if build.with? "blackhole-storage-engine" # Make universal for binding to universal applications if build.universal? ENV.universal_binary args << "-DCMAKE_OSX_ARCHITECTURES=#{Hardware::CPU.universal_archs.as_cmake_arch_flags}" end # Build with local infile loading support args << "-DENABLED_LOCAL_INFILE=1" if build.with? "local-infile" system "cmake", *args system "make" system "make", "install" # Fix my.cnf to point to #{etc} instead of /etc (etc/"my.cnf.d").mkpath inreplace "#{etc}/my.cnf", "!includedir /etc/my.cnf.d", "!includedir #{etc}/my.cnf.d" touch etc/"my.cnf.d/.homebrew_dont_prune_me" # Don't create databases inside of the prefix! # See: https://github.com/Homebrew/homebrew/issues/4975 rm_rf prefix/"data" (prefix/"mysql-test").rmtree if build.without? "test" # save 121MB! (prefix/"sql-bench").rmtree if build.without? "bench" # Link the setup script into bin bin.install_symlink prefix/"scripts/mysql_install_db" # Fix up the control script and link into bin inreplace "#{prefix}/support-files/mysql.server" do |s| s.gsub!(/^(PATH=".*)(")/, "\\1:#{HOMEBREW_PREFIX}/bin\\2") # pidof can be replaced with pgrep from proctools on Mountain Lion s.gsub!(/pidof/, "pgrep") if MacOS.version >= :mountain_lion end bin.install_symlink prefix/"support-files/mysql.server" # Move sourced non-executable out of bin into libexec libexec.mkpath libexec.install "#{bin}/wsrep_sst_common" # Fix up references to wsrep_sst_common %W[ wsrep_sst_mysqldump wsrep_sst_rsync wsrep_sst_xtrabackup wsrep_sst_xtrabackup-v2 ].each do |f| inreplace "#{bin}/#{f}", "$(dirname $0)/wsrep_sst_common", "#{libexec}/wsrep_sst_common" end end def post_install # Make sure the var/mysql directory exists (var/"mysql").mkpath unless File.exist? "#{var}/mysql/mysql/user.frm" ENV["TMPDIR"] = nil system "#{bin}/mysql_install_db", "--verbose", "--user=#{ENV["USER"]}", "--basedir=#{prefix}", "--datadir=#{var}/mysql", "--tmpdir=/tmp" end end def caveats; <<-EOS.undent A "/etc/my.cnf" from another install may interfere with a Homebrew-built server starting up correctly. To connect: mysql -uroot EOS end plist_options :manual => "mysql.server start" def plist; <<-EOS.undent KeepAlive Label #{plist_name} ProgramArguments #{opt_bin}/mysqld_safe --bind-address=127.0.0.1 --datadir=#{var}/mysql RunAtLoad WorkingDirectory #{var} EOS end test do if build.with? "test" (prefix/"mysql-test").cd do system "./mysql-test-run.pl", "status" end else system bin/"mysqld", "--version" end end end __END__ diff --git a/storage/connect/jdbconn.cpp b/storage/connect/jdbconn.cpp index 9b47927..7c0582d 100644 --- a/storage/connect/jdbconn.cpp +++ b/storage/connect/jdbconn.cpp @@ -270,7 +270,7 @@ PQRYRES JDBCColumns(PGLOBAL g, char *db, char *table, char *colpat, return NULL; // Colpat cannot be null or empty for some drivers - cap->Pat = (colpat && *colpat) ? colpat : "%"; + cap->Pat = (colpat && *colpat) ? colpat : PlugDup(g, "%"); /************************************************************************/ /* Now get the results into blocks. */