2009-10-15 08:07:12 +00:00
|
|
|
require 'formula'
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2011-03-10 05:11:03 +00:00
|
|
|
class Postgresql < Formula
|
2010-04-04 18:09:09 +00:00
|
|
|
homepage 'http://www.postgresql.org/'
|
2012-09-24 12:59:34 +00:00
|
|
|
url 'http://ftp.postgresql.org/pub/source/v9.2.1/postgresql-9.2.1.tar.bz2'
|
|
|
|
sha1 'cea9601b3acd1484fd98441b49a15ea1c42057ec'
|
2009-10-29 19:47:57 +00:00
|
|
|
|
2009-10-05 20:27:37 +00:00
|
|
|
depends_on 'readline'
|
2012-09-05 04:04:01 +00:00
|
|
|
depends_on 'libxml2' if MacOS.version == :leopard # Leopard libxml is too old
|
2012-08-19 23:34:59 +00:00
|
|
|
depends_on 'ossp-uuid' unless build.include? 'without-ossp-uuid'
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2012-08-13 20:42:59 +00:00
|
|
|
option '32-bit'
|
|
|
|
option 'without-ossp-uuid', 'Build without OSSP uuid'
|
|
|
|
option 'no-python', 'Build without Python support'
|
|
|
|
option 'no-perl', 'Build without Perl support'
|
|
|
|
option 'enable-dtrace', 'Build with DTrace support'
|
2010-03-29 19:46:53 +00:00
|
|
|
|
2012-07-31 01:39:51 +00:00
|
|
|
# Fix PL/Python build: https://github.com/mxcl/homebrew/issues/11162
|
|
|
|
# Fix uuid-ossp build issues: http://archives.postgresql.org/pgsql-general/2012-07/msg00654.php
|
2012-05-07 20:54:28 +00:00
|
|
|
def patches
|
|
|
|
DATA
|
|
|
|
end
|
2012-06-10 20:51:31 +00:00
|
|
|
|
2009-09-01 01:22:29 +00:00
|
|
|
def install
|
2012-09-05 04:04:01 +00:00
|
|
|
ENV.libxml2 if MacOS.version >= :snow_leopard
|
2010-05-26 18:49:40 +00:00
|
|
|
|
2010-04-07 05:58:35 +00:00
|
|
|
args = ["--disable-debug",
|
|
|
|
"--prefix=#{prefix}",
|
2012-02-08 05:47:54 +00:00
|
|
|
"--datadir=#{share}/#{name}",
|
|
|
|
"--docdir=#{doc}",
|
2010-04-07 05:58:35 +00:00
|
|
|
"--enable-thread-safety",
|
|
|
|
"--with-bonjour",
|
|
|
|
"--with-gssapi",
|
|
|
|
"--with-krb5",
|
|
|
|
"--with-openssl",
|
2012-02-08 05:47:54 +00:00
|
|
|
"--with-libxml",
|
2012-05-12 03:51:37 +00:00
|
|
|
"--with-libxslt"]
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2012-08-13 20:42:59 +00:00
|
|
|
args << "--with-ossp-uuid" unless build.include? 'without-ossp-uuid'
|
|
|
|
args << "--with-python" unless build.include? 'no-python'
|
|
|
|
args << "--with-perl" unless build.include? 'no-perl'
|
|
|
|
args << "--enable-dtrace" if build.include? 'enable-dtrace'
|
2010-03-29 19:46:53 +00:00
|
|
|
|
2012-08-21 02:06:38 +00:00
|
|
|
unless build.include? 'without-ossp-uuid'
|
|
|
|
ENV.append 'CFLAGS', `uuid-config --cflags`.strip
|
|
|
|
ENV.append 'LDFLAGS', `uuid-config --ldflags`.strip
|
|
|
|
ENV.append 'LIBS', `uuid-config --libs`.strip
|
|
|
|
end
|
2010-05-26 18:49:40 +00:00
|
|
|
|
2012-08-13 20:42:59 +00:00
|
|
|
if not build.build_32_bit? and MacOS.prefer_64_bit? and not build.include? 'no-python'
|
2010-04-07 05:58:35 +00:00
|
|
|
args << "ARCHFLAGS='-arch x86_64'"
|
2010-07-28 05:28:55 +00:00
|
|
|
check_python_arch
|
2010-03-29 19:46:53 +00:00
|
|
|
end
|
2009-10-02 22:46:27 +00:00
|
|
|
|
2012-08-13 20:42:59 +00:00
|
|
|
if build.build_32_bit?
|
2012-02-08 05:47:54 +00:00
|
|
|
ENV.append 'CFLAGS', '-arch i386'
|
|
|
|
ENV.append 'LDFLAGS', '-arch i386'
|
|
|
|
end
|
2012-02-04 06:04:59 +00:00
|
|
|
|
2010-04-07 05:58:35 +00:00
|
|
|
system "./configure", *args
|
2011-09-26 17:59:53 +00:00
|
|
|
system "make install-world"
|
2010-01-13 05:15:58 +00:00
|
|
|
end
|
|
|
|
|
2010-07-28 05:28:55 +00:00
|
|
|
def check_python_arch
|
|
|
|
# On 64-bit systems, we need to look for a 32-bit Framework Python.
|
|
|
|
# The configure script prefers this Python version, and if it doesn't
|
|
|
|
# have 64-bit support then linking will fail.
|
|
|
|
framework_python = Pathname.new "/Library/Frameworks/Python.framework/Versions/Current/Python"
|
|
|
|
return unless framework_python.exist?
|
|
|
|
unless (archs_for_command framework_python).include? :x86_64
|
|
|
|
opoo "Detected a framework Python that does not have 64-bit support in:"
|
|
|
|
puts <<-EOS.undent
|
|
|
|
#{framework_python}
|
|
|
|
|
|
|
|
The configure script seems to prefer this version of Python over any others,
|
|
|
|
so you may experience linker problems as described in:
|
|
|
|
http://osdir.com/ml/pgsql-general/2009-09/msg00160.html
|
|
|
|
|
|
|
|
To fix this issue, you may need to either delete the version of Python
|
|
|
|
shown above, or move it out of the way before brewing PostgreSQL.
|
|
|
|
|
|
|
|
Note that a framework Python in /Library/Frameworks/Python.framework is
|
2012-01-04 06:05:05 +00:00
|
|
|
the "MacPython" version, and not the system-provided version which is in:
|
2010-07-28 05:28:55 +00:00
|
|
|
/System/Library/Frameworks/Python.framework
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-01-13 05:15:58 +00:00
|
|
|
def caveats
|
2010-07-28 05:28:55 +00:00
|
|
|
s = <<-EOS
|
2011-09-26 17:59:53 +00:00
|
|
|
# Build Notes
|
|
|
|
|
2010-12-30 14:34:40 +00:00
|
|
|
If builds of PostgreSQL 9 are failing and you have version 8.x installed,
|
2010-10-31 05:02:59 +00:00
|
|
|
you may need to remove the previous version first. See:
|
2010-11-10 18:16:28 +00:00
|
|
|
https://github.com/mxcl/homebrew/issues/issue/2510
|
2010-10-31 05:02:59 +00:00
|
|
|
|
2010-04-14 16:43:06 +00:00
|
|
|
To build plpython against a specific Python, set PYTHON prior to brewing:
|
|
|
|
PYTHON=/usr/local/bin/python brew install postgresql
|
|
|
|
See:
|
2012-09-10 15:13:48 +00:00
|
|
|
http://www.postgresql.org/docs/9.2/static/install-procedure.html
|
2010-04-14 16:43:06 +00:00
|
|
|
|
2011-09-26 17:59:53 +00:00
|
|
|
# Create/Upgrade a Database
|
2010-04-14 16:43:06 +00:00
|
|
|
|
2009-10-01 04:49:34 +00:00
|
|
|
If this is your first install, create a database with:
|
2012-08-13 11:37:27 +00:00
|
|
|
initdb #{var}/postgres -E utf8
|
2009-09-26 05:49:03 +00:00
|
|
|
|
2012-09-10 15:13:48 +00:00
|
|
|
To migrate existing data from a previous major version (pre-9.2) of PostgreSQL, see:
|
|
|
|
http://www.postgresql.org/docs/9.2/static/upgrading.html
|
2011-09-26 17:59:53 +00:00
|
|
|
|
|
|
|
# Start/Stop PostgreSQL
|
|
|
|
|
2010-07-25 18:18:19 +00:00
|
|
|
If this is your first install, automatically load on login with:
|
2011-06-04 04:04:27 +00:00
|
|
|
mkdir -p ~/Library/LaunchAgents
|
2011-12-31 05:56:52 +00:00
|
|
|
cp #{plist_path} ~/Library/LaunchAgents/
|
|
|
|
launchctl load -w ~/Library/LaunchAgents/#{plist_path.basename}
|
2010-07-25 18:18:19 +00:00
|
|
|
|
2012-02-04 14:57:53 +00:00
|
|
|
If this is an upgrade and you already have the #{plist_path.basename} loaded:
|
2011-12-31 05:56:52 +00:00
|
|
|
launchctl unload -w ~/Library/LaunchAgents/#{plist_path.basename}
|
|
|
|
cp #{plist_path} ~/Library/LaunchAgents/
|
|
|
|
launchctl load -w ~/Library/LaunchAgents/#{plist_path.basename}
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2009-10-01 04:49:34 +00:00
|
|
|
Or start manually with:
|
2011-06-04 04:04:27 +00:00
|
|
|
pg_ctl -D #{var}/postgres -l #{var}/postgres/server.log start
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2009-10-01 04:49:34 +00:00
|
|
|
And stop with:
|
2011-06-04 04:04:27 +00:00
|
|
|
pg_ctl -D #{var}/postgres stop -s -m fast
|
|
|
|
|
2011-12-13 02:50:28 +00:00
|
|
|
# Loading Extensions
|
|
|
|
|
|
|
|
By default, Homebrew builds all available Contrib extensions. To see a list of all
|
|
|
|
available extensions, from the psql command line, run:
|
|
|
|
SELECT * FROM pg_available_extensions;
|
|
|
|
|
|
|
|
To load any of the extension names, navigate to the desired database and run:
|
|
|
|
CREATE EXTENSION [extension name];
|
|
|
|
|
|
|
|
For instance, to load the tablefunc extension in the current database, run:
|
|
|
|
CREATE EXTENSION tablefunc;
|
|
|
|
|
|
|
|
For more information on the CREATE EXTENSION command, see:
|
2012-09-10 15:13:48 +00:00
|
|
|
http://www.postgresql.org/docs/9.2/static/sql-createextension.html
|
2011-12-13 02:50:28 +00:00
|
|
|
For more information on extensions, see:
|
2012-09-10 15:13:48 +00:00
|
|
|
http://www.postgresql.org/docs/9.2/static/contrib.html
|
2011-12-13 02:50:28 +00:00
|
|
|
|
2011-09-26 17:59:53 +00:00
|
|
|
# Other
|
2011-06-04 04:04:27 +00:00
|
|
|
|
|
|
|
Some machines may require provisioning of shared memory:
|
2012-09-10 15:13:48 +00:00
|
|
|
http://www.postgresql.org/docs/9.2/static/kernel-resources.html#SYSVIPC
|
2010-01-13 05:15:58 +00:00
|
|
|
EOS
|
2010-05-26 18:49:40 +00:00
|
|
|
|
2011-03-18 17:30:47 +00:00
|
|
|
if MacOS.prefer_64_bit? then
|
2010-07-28 05:28:55 +00:00
|
|
|
s << <<-EOS
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2012-02-08 05:47:54 +00:00
|
|
|
To install postgresql (and ossp-uuid) in 32-bit mode:
|
2012-02-04 06:04:59 +00:00
|
|
|
brew install postgresql --32-bit
|
|
|
|
|
2010-01-13 05:15:58 +00:00
|
|
|
If you want to install the postgres gem, including ARCHFLAGS is recommended:
|
2010-10-07 07:23:44 +00:00
|
|
|
env ARCHFLAGS="-arch x86_64" gem install pg
|
2009-09-01 01:22:29 +00:00
|
|
|
|
2009-10-01 04:49:34 +00:00
|
|
|
To install gems without sudo, see the Homebrew wiki.
|
2010-01-13 05:15:58 +00:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
2010-07-28 05:28:55 +00:00
|
|
|
return s
|
2009-09-01 01:22:29 +00:00
|
|
|
end
|
2009-10-01 04:49:34 +00:00
|
|
|
|
|
|
|
def startup_plist
|
|
|
|
return <<-EOPLIST
|
|
|
|
<?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>
|
2011-12-31 05:56:52 +00:00
|
|
|
<string>#{plist_name}</string>
|
2009-10-01 04:49:34 +00:00
|
|
|
<key>ProgramArguments</key>
|
|
|
|
<array>
|
2011-12-31 22:13:31 +00:00
|
|
|
<string>#{HOMEBREW_PREFIX}/bin/postgres</string>
|
2009-10-01 04:49:34 +00:00
|
|
|
<string>-D</string>
|
2010-03-13 06:44:50 +00:00
|
|
|
<string>#{var}/postgres</string>
|
2009-10-01 04:49:34 +00:00
|
|
|
<string>-r</string>
|
2010-03-13 06:44:50 +00:00
|
|
|
<string>#{var}/postgres/server.log</string>
|
2009-10-01 04:49:34 +00:00
|
|
|
</array>
|
|
|
|
<key>RunAtLoad</key>
|
|
|
|
<true/>
|
|
|
|
<key>UserName</key>
|
2010-01-16 15:48:56 +00:00
|
|
|
<string>#{`whoami`.chomp}</string>
|
2009-10-01 04:49:34 +00:00
|
|
|
<key>WorkingDirectory</key>
|
|
|
|
<string>#{HOMEBREW_PREFIX}</string>
|
2011-08-24 02:00:12 +00:00
|
|
|
<key>StandardErrorPath</key>
|
|
|
|
<string>#{var}/postgres/server.log</string>
|
2009-10-01 04:49:34 +00:00
|
|
|
</dict>
|
|
|
|
</plist>
|
|
|
|
EOPLIST
|
|
|
|
end
|
2009-09-01 01:22:29 +00:00
|
|
|
end
|
2012-05-07 20:54:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
__END__
|
2012-07-27 06:07:46 +00:00
|
|
|
--- a/src/pl/plpython/Makefile 2011-09-23 08:03:52.000000000 +1000
|
|
|
|
+++ b/src/pl/plpython/Makefile 2011-10-26 21:43:40.000000000 +1100
|
|
|
|
@@ -24,8 +24,6 @@
|
2012-05-07 20:54:28 +00:00
|
|
|
# Darwin (OS X) has its own ideas about how to do this.
|
|
|
|
ifeq ($(PORTNAME), darwin)
|
|
|
|
shared_libpython = yes
|
|
|
|
-override python_libspec = -framework Python
|
2012-07-27 06:07:46 +00:00
|
|
|
-override python_additional_libs =
|
2012-05-07 20:54:28 +00:00
|
|
|
endif
|
|
|
|
|
2012-07-27 06:07:46 +00:00
|
|
|
# If we don't have a shared library and the platform doesn't allow it
|
2012-07-31 01:39:51 +00:00
|
|
|
--- a/contrib/uuid-ossp/uuid-ossp.c 2012-07-30 18:34:53.000000000 -0700
|
|
|
|
+++ b/contrib/uuid-ossp/uuid-ossp.c 2012-07-30 18:35:03.000000000 -0700
|
|
|
|
@@ -9,6 +9,8 @@
|
|
|
|
*-------------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
+#define _XOPEN_SOURCE
|
|
|
|
+
|
|
|
|
#include "postgres.h"
|
|
|
|
#include "fmgr.h"
|
|
|
|
#include "utils/builtins.h"
|