Skip to content

Instantly share code, notes, and snippets.

@georgediaz88
Forked from gmanley/gist:894758
Created March 30, 2011 16:48
Show Gist options
  • Save georgediaz88/894782 to your computer and use it in GitHub Desktop.
Save georgediaz88/894782 to your computer and use it in GitHub Desktop.
require 'formula'
class Mysql < Formula
homepage 'http://dev.mysql.com/doc/refman/5.5/en/'
url 'http://ftp.sunet.se/pub/unix/databases/relational/mysql/Downloads/MySQL-5.5/mysql-5.5.10.tar.gz'
md5 'ee604aff531ff85abeb10cf332c1355a'
depends_on 'cmake' => :build
depends_on 'readline'
fails_with_llvm "https://github.com/mxcl/homebrew/issues/issue/144"
def options
[
['--with-tests', "Build with unit tests."],
['--with-embedded', "Build the embedded server."],
['--with-builtin-readline', "Use built-in readline."],
['--universal', "Make mysql a universal binary"]
]
end
def patches
DATA
end
def install
args = [
".",
"-DCMAKE_INSTALL_PREFIX='#{prefix}'",
"-DMYSQL_DATADIR='#{var}/mysql/data'",
"-DINSTALL_MANDIR='#{man}'",
"-DSYSCONFDIR='#{HOMEBREW_PREFIX}/etc'",
"-DWITH_SSL=yes",
"-DDEFAULT_CHARSET='utf8'",
"-DDEFAULT_COLLATION='utf8_general_ci'"
]
# To enable unit testing at build, we need to download the unit testing suite
args << "-DWITH_UNIT_TESTS=OFF" if not ARGV.include? '--with-tests'
args << "-DENABLE_DOWNLOADS=ON" if ARGV.include? '--with-tests'
# Confusingly, the following means "use built-in readline instead of homebrew readline"
args << "-DWITH_READLINE=ON" if ARGV.include? '--with-builtin-readline'
# Build the embedded server
args << "-DWITH_EMBEDDED_SERVER=ON" if ARGV.include? '--with-embedded'
# Make universal for bindings to universal applications
args << "-DCMAKE_OSX_ARCHITECTURES='ppc;i386'" if ARGV.include? '--universal'
system "cmake", *args
system "make"
system "make install"
(prefix+'com.mysql.mysqld.plist').write startup_plist
end
def caveats; <<-EOS.undent
Further set up instructions:
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Set up databases (also when updating) with:
unset TMPDIR
cd #{prefix}
scripts/mysql_install_db --datadir=#{var}/mysql/data --user=`whoami` --tmpdir=/tmp
Running the mysql_install_db command with the user and tmpdir option will
ensure that there is no issue creating your system databases.
Symlink the socket in #{var}/mysql.sock to the usual locations:
sudo ln -s #{var}/mysql.sock /tmp/mysql.sock
sudo chown `whoami` /tmp/mysql.sock
sudo mkdir -p /var/mysql/
sudo ln -s #{var}/mysql.sock /var/mysql/mysql.sock
sudo chown `whoami` /var/mysql/mysql.sock
If this is your first install, automatically load mysql on login with:
mkdir -p ~/Library/LaunchAgents
cp #{prefix}/com.mysql.mysqld.plist ~/Library/LaunchAgents/
launchctl load -w ~/Library/LaunchAgents/com.mysql.mysqld.plist
If this is an upgrade and you already have the com.mysql.mysqld.plist loaded:
launchctl unload -w ~/Library/LaunchAgents/com.mysql.mysqld.plist
cp #{prefix}/com.mysql.mysqld.plist ~/Library/LaunchAgents/
launchctl load -w ~/Library/LaunchAgents/com.mysql.mysqld.plist
Note on upgrading:
We overwrite any existing com.mysql.mysqld.plist in ~/Library/LaunchAgents
because previous versions of this formula created the plist with an erratic argument.
Or start manually with:
mysqld_safe &
Configuration:
You can create the configuration file my.cnf in #{etc} if you need to
change the default settings.
EOS
end
def startup_plist; <<-EOPLIST.undent
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>KeepAlive</key>
<true/>
<key>Label</key>
<string>com.mysql.mysqld</string>
<key>ProgramArguments</key>
<array>
<string>#{bin}/mysqld_safe</string>
<!-- For some reason launchd/mysql won't pick up datadir unless specified here -->
<string>--datadir=#{var}/mysql/data</string>
</array>
<key>RunAtLoad</key>
<true/>
<key>UserName</key>
<string>#{`whoami`.chomp}</string>
<key>WorkingDirectory</key>
<string>#{prefix}</string>
</dict>
</plist>
EOPLIST
end
end
__END__
--- old/scripts/mysqld_safe.sh 2009-09-02 04:10:39.000000000 -0400
+++ new/scripts/mysqld_safe.sh 2009-09-02 04:52:55.000000000 -0400
@@ -383,7 +383,7 @@
fi
USER_OPTION=""
-if test -w / -o "$USER" = "root"
+if test -w /sbin -o "$USER" = "root"
then
if test "$user" != "root" -o $SET_USER = 1
then
diff --git a/scripts/mysql_config.sh b/scripts/mysql_config.sh
index efc8254..8964b70 100644
--- a/scripts/mysql_config.sh
+++ b/scripts/mysql_config.sh
@@ -132,7 +132,8 @@ for remove in DDBUG_OFF DSAFEMALLOC USAFEMALLOC DSAFE_MUTEX \
DEXTRA_DEBUG DHAVE_purify O 'O[0-9]' 'xO[0-9]' 'W[-A-Za-z]*' \
'mtune=[-A-Za-z0-9]*' 'mcpu=[-A-Za-z0-9]*' 'march=[-A-Za-z0-9]*' \
Xa xstrconst "xc99=none" AC99 \
- unroll2 ip mp restrict
+ unroll2 ip mp restrict \
+ mmmx 'msse[0-9.]*' 'mfpmath=sse' w pipe 'fomit-frame-pointer' 'mmacosx-version-min=10.[0-9]'
do
# The first option we might strip will always have a space before it because
# we set -I$pkgincludedir as the first option
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment