2012-12-27 22:11:42 +01:00
# Created by: Marc G. Fournier <scrappy@FreeBSD.org>
1999-08-25 07:28:01 +02:00
# $FreeBSD$
1998-04-21 23:52:10 +02:00
2003-12-04 16:24:57 +01:00
PORTNAME ?= postgresql
2014-07-30 20:21:47 +02:00
DISTVERSION ?= 8.4.22
2014-11-12 10:53:41 +01:00
PORTREVISION ?= 1
2002-02-19 09:23:22 +01:00
CATEGORIES ?= databases
2012-10-16 19:28:22 +02:00
MASTER_SITES = PGSQL
2008-01-22 15:08:48 +01:00
MASTER_SITE_SUBDIR = source/v${ DISTVERSION }
2013-10-15 19:17:05 +02:00
PKGNAMESUFFIX ?= ${ DISTVERSION : R : S /.// } ${ COMPONENT }
1997-10-03 16:13:36 +02:00
2012-03-04 18:19:59 +01:00
MAINTAINER ?= pgsql@FreeBSD.org
2008-02-04 18:12:32 +01:00
COMMENT ?= The most advanced open-source database available anywhere
1997-04-10 21:15:12 +02:00
2013-10-12 02:59:50 +02:00
CONFLICTS ?= ${ PORTNAME } [ ^${ PORTVERSION : R : R } ] ?-client* \
${ PORTNAME } ${ COMPONENT } -[ ^${ PORTVERSION : R : R } ] .* \
${ PORTNAME } 8[ ^${ PORTVERSION : R : E } ] -client* \
${ PORTNAME } ${ COMPONENT } -8.[ ^${ PORTVERSION : R : E } ] .*
2004-11-23 20:15:12 +01:00
2008-01-22 15:08:48 +01:00
WRKSRC = ${ WRKDIR } /postgresql-${ DISTVERSION }
2001-04-21 13:34:34 +02:00
DIST_SUBDIR = postgresql
2000-12-11 04:22:07 +01:00
2014-06-09 23:57:43 +02:00
ICU_PATCHFILE ?= pg-8421-icu-2014-06-09.diff.gz
2012-01-25 22:12:33 +01:00
2012-01-30 19:39:57 +01:00
UNIQUENAME ?= ${ PORTNAME } ${ DISTVERSION : R : S /.// }
2005-02-19 13:07:46 +01:00
2013-10-10 02:09:35 +02:00
PKGINSTALL ?= ${ PKGDIR } /pkg-install${ COMPONENT }
2014-07-30 20:21:47 +02:00
USES += tar:bzip2
2013-07-07 02:15:47 +02:00
. i f ! d e f i n e d ( N O _ B U I L D )
USES += gmake
2012-03-05 21:10:22 +01:00
GNU_CONFIGURE = yes
2004-11-23 20:15:12 +01:00
. e n d i f
1997-10-05 00:43:26 +02:00
2012-12-27 22:11:42 +01:00
PG_USER = pgsql
PG_GROUP = pgsql
PG_UID = 70
2008-01-07 14:51:57 +01:00
2010-10-07 08:58:10 +02:00
LDFLAGS += -L${ LOCALBASE } /lib
INCLUDES += -I${ LOCALBASE } /include
CONFIGURE_ARGS += --with-libraries= ${ PREFIX } /lib \
--with-includes= ${ PREFIX } /include \
2009-07-08 00:30:06 +02:00
--enable-thread-safety
2011-09-24 00:26:39 +02:00
CONFIGURE_ENV += INCLUDES = " ${ INCLUDES } " \
2007-03-18 17:23:18 +01:00
PTHREAD_CFLAGS = " ${ PTHREAD_CFLAGS } " \
2011-11-30 19:49:31 +01:00
PTHREAD_LIBS = " ${ PTHREAD_LIBS } " \
2012-01-25 22:12:33 +01:00
LDFLAGS_SL = " ${ LDFLAGS_SL } "
2014-11-12 10:53:41 +01:00
CFLAGS += ${ PTHREAD_CFLAGS }
LDFLAGS += ${ PTHREAD_LIBS }
2002-02-19 09:23:22 +01:00
2013-10-10 02:09:35 +02:00
PLIST = ${ PKGDIR } /pkg-plist${ COMPONENT }
1997-10-05 00:43:26 +02:00
2010-10-07 08:58:10 +02:00
BUILD_DIRS ?= src/timezone src/backend src/backend/utils/mb/conversion_procs \
2009-07-08 00:30:06 +02:00
src/backend/snowball src/bin/initdb src/bin/pg_ctl \
2007-11-01 08:10:04 +01:00
src/bin/pg_controldata src/bin/pg_resetxlog src/pl
2006-12-06 17:50:34 +01:00
2004-11-23 20:15:12 +01:00
INSTALL_DIRS ?= ${ BUILD_DIRS }
2002-02-19 09:23:22 +01:00
2004-11-23 20:15:12 +01:00
. i f ! d e f i n e d ( C L I E N T _ O N L Y ) & & ! d e f i n e d ( S L A V E _ O N L Y )
SERVER_ONLY = yes
2013-10-10 02:09:35 +02:00
COMPONENT = -server
2006-12-06 17:50:34 +01:00
USE_RC_SUBR = postgresql
2014-08-25 19:53:26 +02:00
USES += pgsql:${ DISTVERSION : C /([0-9][0-9]* \. [0-9][0-9]*).*/ \1 /g }
2011-11-02 19:09:16 +01:00
USERS = ${ PG_USER }
GROUPS = ${ PG_GROUP }
2011-04-19 01:34:27 +02:00
SUB_FILES += 502.pgsql
2003-12-04 13:00:49 +01:00
. e n d i f
2004-11-23 20:15:12 +01:00
. i f ! d e f i n e d ( S L A V E _ O N L Y )
2012-10-16 19:28:22 +02:00
OPTIONS_DEFINE += NLS
NLS_DESC = Use internationalized messages
OPTIONS_DEFAULT += NLS
2005-01-31 01:36:16 +01:00
. e n d i f
2008-01-07 14:51:57 +01:00
. i f ! d e f i n e d ( C L I E N T _ O N L Y )
MAKE_ENV = PATH = ${ PREFIX } /bin:${ PATH }
CONFIGURE_ENV += PATH = ${ PREFIX } /bin:${ PATH }
. e n d i f
2004-11-23 20:15:12 +01:00
. i f ! d e f i n e d ( S L A V E _ O N L Y )
2012-01-25 22:12:33 +01:00
. if ${DISTVERSION : R } == 8.4
2012-10-16 19:28:22 +02:00
OPTIONS_DEFINE += DTRACE GSSAPI
DTRACE_DESC = Build with DTrace probes ( server only)
GSSAPI_DESC = Build with GSSAPI support
OPTIONS_DEFAULT += INTDATE
. e n d i f
2012-01-25 22:12:33 +01:00
. if ${DISTVERSION : R } == 8.4 | | ${DISTVERSION :R } == 8.3
2012-10-16 19:28:22 +02:00
OPTIONS_DEFINE += XML TZDATA
XML_DESC = Build with XML data type ( server)
TZDATA_DESC = Use internal timezone database ( server)
OPTIONS_DEFAULT += XML TZDATA
2012-01-25 22:12:33 +01:00
. e n d i f
. i f ! e m p t y ( I C U _ P A T C H F I L E )
# See http://people.freebsd.org/~girgen/postgresql-icu/README.html for more info
2012-10-16 19:28:22 +02:00
OPTIONS_DEFINE += ICU
2012-01-25 22:12:33 +01:00
. e n d i f
2012-10-16 19:28:22 +02:00
OPTIONS_DEFINE += PAM LDAP OPTIMIZED_CFLAGS DEBUG KRB5
OPTIONS_SINGLE = KRB5
OPTIONS_SINGLE_KRB5 = MIT_KRB5 HEIMDAL_KRB5
KRB5_DESC = Build with kerberos provider support
2004-11-23 20:15:12 +01:00
Upgrade PostgreSQL to 8.0.2. Here's the brief release note:
Over the past several weeks, Tom Lane has been working on replacing
our old Cache Management Alorithm (ARC) with a new, patent free one
(2Q).
In order to reduce the number of 8.x deployments out there that are
using the old manager, we have just released 8.0.2, and encourage
adminstrators to upgrade at their earliest convience.
For those already running 8.x on your production servers, please
note that this upgrade does *NOT* require a dump restore, but due to
a bump in the major version number for the client library (libpq),
it *WILL* require all client applications to be recompiled at the
same time.
For full release info, see
http://www.postgresql.org/docs/8.0/static/release.html#RELEASE-8-0-2
Apart from the upgrade, three new config options are added:
A patch (experimental) for supporting proper collation
of utf-8 encoded locales, using IBM's ICU package (devel/icu). See
http://people.freebsd.org/~girgen/postgresql-icu/README.html for more
info.
An optional patch written by Evgen Potemkin, which allows
PostgreSQL to make hierarchical queries à la Oracle [1].
An option is added that allows the use of 64 bit ints to
store dates [2].
PR: ports/79165 [1], ports/76999 [2]
Submitted by: Marcos Tischer Vallim [1], Christian Ullrich [2]
Approved by: ade, seanc (implicit)
2005-04-14 01:15:49 +02:00
# See http://www.freebsd.org/cgi/query-pr.cgi?pr=ports/76999 for more info
# (requires dump/restore if modified.)
2012-10-16 19:28:22 +02:00
OPTIONS_DEFINE += INTDATE SSL
OPTIONS_DEFAULT += SSL
2011-09-25 21:40:10 +02:00
. e n d i f # !SLAVE_ONLY
Upgrade PostgreSQL to 8.0.2. Here's the brief release note:
Over the past several weeks, Tom Lane has been working on replacing
our old Cache Management Alorithm (ARC) with a new, patent free one
(2Q).
In order to reduce the number of 8.x deployments out there that are
using the old manager, we have just released 8.0.2, and encourage
adminstrators to upgrade at their earliest convience.
For those already running 8.x on your production servers, please
note that this upgrade does *NOT* require a dump restore, but due to
a bump in the major version number for the client library (libpq),
it *WILL* require all client applications to be recompiled at the
same time.
For full release info, see
http://www.postgresql.org/docs/8.0/static/release.html#RELEASE-8-0-2
Apart from the upgrade, three new config options are added:
A patch (experimental) for supporting proper collation
of utf-8 encoded locales, using IBM's ICU package (devel/icu). See
http://people.freebsd.org/~girgen/postgresql-icu/README.html for more
info.
An optional patch written by Evgen Potemkin, which allows
PostgreSQL to make hierarchical queries à la Oracle [1].
An option is added that allows the use of 64 bit ints to
store dates [2].
PR: ports/79165 [1], ports/76999 [2]
Submitted by: Marcos Tischer Vallim [1], Christian Ullrich [2]
Approved by: ade, seanc (implicit)
2005-04-14 01:15:49 +02:00
2012-10-16 19:28:22 +02:00
ICU_DESC = Use ICU for unicode collation ( server)
PAM_DESC = Build with PAM support ( server only)
LDAP_DESC = Build with LDAP authentication support
2013-04-28 16:00:02 +02:00
MIT_KRB5_DESC = Build with MIT kerberos support
2012-12-06 17:40:35 +01:00
HEIMDAL_KRB5_DESC = Builds with Heimdal kerberos
2012-10-16 19:28:22 +02:00
OPTIMIZED_CFLAGS_DESC = Builds with compiler optimizations ( -O3)
DEBUG_DESC = Builds with debugging symbols
INTDATE_DESC = Builds with 64-bit date/time type ( server)
SSL_DESC = Build with OpenSSL support
2013-04-28 20:15:06 +02:00
. i n c l u d e < b s d . p o r t . o p t i o n s . m k >
2011-10-21 22:36:06 +02:00
2012-10-16 19:28:22 +02:00
.if ${PORT_OPTIONS : MSSL }
2011-10-21 22:36:06 +02:00
USE_OPENSSL = yes
CONFIGURE_ARGS += --with-openssl
. e n d i f
2011-09-25 20:09:06 +02:00
2011-09-25 21:40:10 +02:00
. i f ! d e f i n e d ( S L A V E _ O N L Y )
2012-10-16 19:28:22 +02:00
. if ( defined(SERVER_ONLY) && ${PORT_OPTIONS : MICU } ) | | make (makesum )
2010-12-04 08:34:27 +01:00
USE_AUTOTOOLS = autoconf
2010-02-03 16:09:08 +01:00
CONFIGURE_ARGS += --with-icu
The PostgreSQL Global Development Group has released an important
update to all supported versions of the PostgreSQL database system,
which includes minor versions 9.3.3, 9.2.7, 9.1.12, 9.0.16, and
8.4.20. This update contains fixes for multiple security issues, as
well as several fixes for replication and data integrity issues. All
users are urged to update their installations at the earliest
opportunity, especially those using binary replication or running a
high-security application.
This update fixes CVE-2014-0060, in which PostgreSQL did not properly
enforce the WITH ADMIN OPTION permission for ROLE management. Before
this fix, any member of a ROLE was able to grant others access to the
same ROLE regardless if the member was given the WITH ADMIN OPTION
permission. It also fixes multiple privilege escalation issues,
including: CVE-2014-0061, CVE-2014-0062, CVE-2014-0063, CVE-2014-0064,
CVE-2014-0065, and CVE-2014-0066. More information on these issues can
be found on our security page and the security issue detail wiki page.
Security: CVE-2014-0060,CVE-2014-0061,CVE-2014-0062,CVE-2014-0063
CVE-2014-0064,CVE-2014-0065,CVE-2014-0066,CVE-2014-0067
2014-02-20 19:11:37 +01:00
PATCH_SITES += http://people.freebsd.org/~girgen/postgresql-icu/:icu
2012-01-25 22:12:33 +01:00
PATCHFILES += ${ ICU_PATCHFILE } :icu
2013-12-11 19:08:52 +01:00
LIB_DEPENDS += libicudata.so:${ PORTSDIR } /devel/icu
2010-02-03 16:09:08 +01:00
. e n d i f
2011-10-21 22:36:06 +02:00
. e n d i f # !SLAVE_ONLY
. i f ! d e f i n e d ( S L A V E _ O N L Y )
Upgrade PostgreSQL to 8.0.2. Here's the brief release note:
Over the past several weeks, Tom Lane has been working on replacing
our old Cache Management Alorithm (ARC) with a new, patent free one
(2Q).
In order to reduce the number of 8.x deployments out there that are
using the old manager, we have just released 8.0.2, and encourage
adminstrators to upgrade at their earliest convience.
For those already running 8.x on your production servers, please
note that this upgrade does *NOT* require a dump restore, but due to
a bump in the major version number for the client library (libpq),
it *WILL* require all client applications to be recompiled at the
same time.
For full release info, see
http://www.postgresql.org/docs/8.0/static/release.html#RELEASE-8-0-2
Apart from the upgrade, three new config options are added:
A patch (experimental) for supporting proper collation
of utf-8 encoded locales, using IBM's ICU package (devel/icu). See
http://people.freebsd.org/~girgen/postgresql-icu/README.html for more
info.
An optional patch written by Evgen Potemkin, which allows
PostgreSQL to make hierarchical queries à la Oracle [1].
An option is added that allows the use of 64 bit ints to
store dates [2].
PR: ports/79165 [1], ports/76999 [2]
Submitted by: Marcos Tischer Vallim [1], Christian Ullrich [2]
Approved by: ade, seanc (implicit)
2005-04-14 01:15:49 +02:00
PATCH_DIST_STRIP = -p1
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MDTRACE }
2011-11-30 19:49:31 +01:00
CONFIGURE_ARGS += --enable-dtrace
LDFLAGS += -lelf
. i f $ { O S V E R S I O N } < 9 0 0 0 2 1
2012-03-05 21:10:22 +01:00
IGNORE = need userland DTrace support found in FreeBSD 9.0
2011-11-30 19:49:31 +01:00
. e n d i f
. e n d i f
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MPAM }
2005-02-03 10:30:27 +01:00
CONFIGURE_ARGS += --with-pam
2004-11-23 20:15:12 +01:00
. e n d i f
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MLDAP }
2007-02-06 16:53:24 +01:00
CONFIGURE_ARGS += --with-ldap
2012-03-05 21:10:22 +01:00
USE_OPENLDAP = yes
2007-02-06 16:53:24 +01:00
. e n d i f
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MXML }
2008-01-22 15:08:48 +01:00
CONFIGURE_ARGS += --with-libxml
2013-12-11 19:08:52 +01:00
LIB_DEPENDS += libxml2.so:${ PORTSDIR } /textproc/libxml2
2008-01-22 15:08:48 +01:00
. e n d i f
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MTZDATA }
2008-01-22 15:08:48 +01:00
PLIST_SUB += TZDATA = ""
. e l s e
CONFIGURE_ARGS += --with-system-tzdata= /usr/share/zoneinfo
PLIST_SUB += TZDATA = "@comment "
. e n d i f
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MINTDATE }
2012-01-25 22:12:33 +01:00
CONFIGURE_ARGS += --enable-integer-datetimes
2012-10-16 19:28:22 +02:00
. e l s e
CONFIGURE_ARGS += --disable-integer-datetimes
Upgrade PostgreSQL to 8.0.2. Here's the brief release note:
Over the past several weeks, Tom Lane has been working on replacing
our old Cache Management Alorithm (ARC) with a new, patent free one
(2Q).
In order to reduce the number of 8.x deployments out there that are
using the old manager, we have just released 8.0.2, and encourage
adminstrators to upgrade at their earliest convience.
For those already running 8.x on your production servers, please
note that this upgrade does *NOT* require a dump restore, but due to
a bump in the major version number for the client library (libpq),
it *WILL* require all client applications to be recompiled at the
same time.
For full release info, see
http://www.postgresql.org/docs/8.0/static/release.html#RELEASE-8-0-2
Apart from the upgrade, three new config options are added:
A patch (experimental) for supporting proper collation
of utf-8 encoded locales, using IBM's ICU package (devel/icu). See
http://people.freebsd.org/~girgen/postgresql-icu/README.html for more
info.
An optional patch written by Evgen Potemkin, which allows
PostgreSQL to make hierarchical queries à la Oracle [1].
An option is added that allows the use of 64 bit ints to
store dates [2].
PR: ports/79165 [1], ports/76999 [2]
Submitted by: Marcos Tischer Vallim [1], Christian Ullrich [2]
Approved by: ade, seanc (implicit)
2005-04-14 01:15:49 +02:00
. e n d i f
2013-04-26 17:10:57 +02:00
. if ${PORT_OPTIONS : MNLS }
2002-02-19 09:23:22 +01:00
CONFIGURE_ARGS += --enable-nls
PLIST_SUB += GETTEXT = ""
2013-04-26 17:10:57 +02:00
USES += gettext
2004-11-23 20:15:12 +01:00
. e l s e
2003-01-04 02:10:15 +01:00
CONFIGURE_ARGS += --disable-nls
2002-02-19 09:23:22 +01:00
PLIST_SUB += GETTEXT = "@comment "
2004-11-23 20:15:12 +01:00
. e n d i f
2002-02-19 09:23:22 +01:00
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MOPTIMIZED_CFLAGS }
2003-12-04 13:00:49 +01:00
CFLAGS += -O3 -funroll-loops
2004-11-23 20:15:12 +01:00
. e n d i f
2003-01-04 02:10:15 +01:00
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MDEBUG }
2005-02-03 10:30:27 +01:00
CONFIGURE_ARGS += --enable-debug
2003-02-06 21:46:51 +01:00
INSTALL_TARGET = install
2004-11-23 20:15:12 +01:00
. e l s e
2003-01-04 02:10:15 +01:00
INSTALL_TARGET = install-strip
2004-11-23 20:15:12 +01:00
. e n d i f
2003-01-04 02:10:15 +01:00
2012-10-16 19:28:22 +02:00
.if ${PORT_OPTIONS : MGSSAPI }
2010-10-07 08:58:10 +02:00
CONFIGURE_ARGS += --with-gssapi
2012-10-16 19:28:22 +02:00
.if empty(PORT_OPTIONS : MMIT_KRB 5) && empty (PORT_OPTIONS :MHEIMDAL_KRB 5)
2011-09-25 20:09:06 +02:00
# Kerberos libraries will pull the proper GSSAPI library
# via linker dependencies, but otherwise we must specify
# it explicitely: ld --as-needed is used for compilation,
# so configure's -lgssapi_krb5 won't go.
LDFLAGS += -lgssapi
2011-11-30 19:49:31 +01:00
LDFLAGS_SL += -lgssapi
2011-05-18 00:26:08 +02:00
. e n d i f
2011-04-27 15:28:51 +02:00
. e l s e
CONFIGURE_ARGS += --without-gssapi
2010-10-07 08:58:10 +02:00
. e n d i f
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MMIT_KRB 5}
2005-11-15 00:59:26 +01:00
. i f e x i s t s ( / u s r / l i b / l i b k r b 5 . s o ) | | e x i s t s ( / u s r / b i n / k r b 5 - c o n f i g )
2012-01-25 22:12:33 +01:00
IGNORE = requires that you remove heimdal' s /usr/bin/krb5-config and /usr/lib/libkrb5.so*, and set NO_KERBEROS = true in /etc/src.conf to build successfully with MIT-KRB
Welcome to PostgreSQL 8.1.
The new release includes performance improvements and advanced SQL
features which will support bigger data warehouses, higher-volume
transaction processing, and more complex distributed enterprise
software.
Major new features in this release include:
Roles:
PostgreSQL now supports database roles, which simplify the
management of large numbers of users with complex
overlapping database rights.
IN/OUT Parameters:
PostgreSQL functions now support IN, OUT and INOUT
parameters, which substantially improves support of complex
business logic for J2EE and .NET applications.
Two-Phase Commit (2PC):
Long in demand for WAN applications and heterogeneous data
centers using PostgreSQL, this feature allows
ACID-compliant transactions across widely separated
servers.
Some Performance Enhancements found in this release include:
Improved Multiprocessor (SMP) Performance:
The buffer manager for 8.1 has been enhanced to scale almost
linearly with the number of processors, leading to significant
performance gains on 8-way, 16-way, dual-core, and multi-core
CPU servers.
Bitmap Scan:
Indexes will be dynamically converted to bitmaps in memory when
appropriate, giving up to twenty times faster index performance
on complex queries against very large tables.
Table Partitioning:
The query planner is now able to avoid scanning whole sections
of a large table using a technique known as Constraint
Exclusion.
Shared Row Locking:
PostgreSQL's "better than row-level locking" now supports even
higher levels of concurrency through the addition of shared
row locks for foreign keys.
For a more complete listing of changes in this release, please see the
Release Notes visible at:
http://www.postgresql.org/docs/current/static/release.html#RELEASE-8-1
2005-11-10 03:23:38 +01:00
. e n d i f
2005-11-15 00:59:26 +01:00
# Allow defining a home built MIT Kerberos by setting KRB5_HOME
. i f d e f i n e d ( K R B 5 _ H O M E ) & & e x i s t s ( $ { K R B 5 _ H O M E } / l i b / l i b g s s a p i _ k r b 5 . a ) & & e x i s t s ( $ { K R B 5 _ H O M E } / b i n / k r b 5 - c o n f i g )
CONFIGURE_ARGS += --with-krb5
. e l s e
2013-12-11 19:08:52 +01:00
LIB_DEPENDS += libkrb5.so.3:${ PORTSDIR } /security/krb5
2005-11-15 00:59:26 +01:00
CONFIGURE_ARGS += --with-krb5
. e n d i f
2004-11-23 20:15:12 +01:00
. e n d i f
2003-01-04 02:10:15 +01:00
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MHEIMDAL_KRB 5}
2005-11-15 00:59:26 +01:00
# Allow defining a home built Heimdal Kerberos by setting HEIMDAL_HOME
. i f d e f i n e d ( H E I M D A L _ H O M E ) & & e x i s t s ( $ { H E I M D A L _ H O M E } / l i b / l i b g s s a p i . a ) & & e x i s t s ( $ { H E I M D A L _ H O M E } / b i n / k r b 5 - c o n f i g )
CONFIGURE_ARGS += --with-krb5
. e l s e
# Postgresql apps will not link properly when libpq is linked with base heimdal in /usr,
# so we always use the heimdal port. See
Welcome to PostgreSQL 8.1.
The new release includes performance improvements and advanced SQL
features which will support bigger data warehouses, higher-volume
transaction processing, and more complex distributed enterprise
software.
Major new features in this release include:
Roles:
PostgreSQL now supports database roles, which simplify the
management of large numbers of users with complex
overlapping database rights.
IN/OUT Parameters:
PostgreSQL functions now support IN, OUT and INOUT
parameters, which substantially improves support of complex
business logic for J2EE and .NET applications.
Two-Phase Commit (2PC):
Long in demand for WAN applications and heterogeneous data
centers using PostgreSQL, this feature allows
ACID-compliant transactions across widely separated
servers.
Some Performance Enhancements found in this release include:
Improved Multiprocessor (SMP) Performance:
The buffer manager for 8.1 has been enhanced to scale almost
linearly with the number of processors, leading to significant
performance gains on 8-way, 16-way, dual-core, and multi-core
CPU servers.
Bitmap Scan:
Indexes will be dynamically converted to bitmaps in memory when
appropriate, giving up to twenty times faster index performance
on complex queries against very large tables.
Table Partitioning:
The query planner is now able to avoid scanning whole sections
of a large table using a technique known as Constraint
Exclusion.
Shared Row Locking:
PostgreSQL's "better than row-level locking" now supports even
higher levels of concurrency through the addition of shared
row locks for foreign keys.
For a more complete listing of changes in this release, please see the
Release Notes visible at:
http://www.postgresql.org/docs/current/static/release.html#RELEASE-8-1
2005-11-10 03:23:38 +01:00
# http://lists.freebsd.org/pipermail/freebsd-stable/2005-October/018809.html
2013-12-11 19:08:52 +01:00
LIB_DEPENDS += libkrb5.so.26:${ PORTSDIR } /security/heimdal
2005-11-15 00:59:26 +01:00
CONFIGURE_ARGS += --with-krb5
. e n d i f
2004-11-23 20:15:12 +01:00
. e n d i f
2003-01-04 02:10:15 +01:00
2004-11-23 20:15:12 +01:00
. e n d i f # !SLAVE_ONLY
2012-03-05 21:10:22 +01:00
PLIST_SUB += PG_USER = ${ PG_USER } \
PG_GROUP = ${ PG_GROUP }
SUB_LIST += PG_GROUP = ${ PG_GROUP } \
PG_USER = ${ PG_USER } \
PG_UID = ${ PG_UID }
2011-10-19 20:21:25 +02:00
2013-04-28 20:15:06 +02:00
# For testing files in FILESDIR
. i n c l u d e < b s d . p o r t . p r e . m k >
2004-11-23 20:15:12 +01:00
. i f ! d e f i n e d ( N O _ B U I L D )
2012-01-25 22:12:33 +01:00
. i f ! t a r g e t ( p r e - b u i l d )
pre-build :
2012-08-19 17:24:30 +02:00
. i f d e f i n e d ( S E R V E R _ O N L Y )
@${ SH } ${ PKGINSTALL } ${ PORTNAME } PRE-INSTALL
. e n d i f
2014-06-25 00:34:27 +02:00
@ cd ${ WRKSRC } /src/backend && ${ SETENV } ${ MAKE_ENV } ${ MAKE_CMD } symlinks
2012-01-25 22:12:33 +01:00
. e n d i f
2012-03-05 21:10:22 +01:00
2012-01-25 22:12:33 +01:00
do-build :
2004-11-23 20:15:12 +01:00
@ for dir in ${ BUILD_DIRS } ; do \
2014-06-25 00:34:27 +02:00
cd ${ WRKSRC } /$$ { dir} && ${ SETENV } ${ MAKE_ENV } ${ MAKE_CMD } ; \
2004-11-23 20:15:12 +01:00
done
2013-10-10 02:09:35 +02:00
. i f e x i s t s ( $ { F I L E S D I R } / p k g - m e s s a g e $ { C O M P O N E N T } . i n )
SUB_FILES += pkg-message${ COMPONENT }
PKGMESSAGE = ${ WRKSRC } /pkg-message${ COMPONENT }
2004-11-23 20:15:12 +01:00
. e n d i f
2013-10-10 02:09:35 +02:00
. i f e x i s t s ( $ { F I L E S D I R } / p k g - i n s t a l l $ { C O M P O N E N T } . i n )
SUB_FILES += pkg-install${ COMPONENT }
2012-03-05 21:10:22 +01:00
PLIST_SUB += PG_USER = ${ PG_USER }
2011-04-19 01:34:27 +02:00
. e n d i f
2011-08-15 16:52:31 +02:00
. e n d i f
2004-11-23 20:15:12 +01:00
. i f ! d e f i n e d ( N O _ B U I L D )
2010-01-04 21:29:37 +01:00
post-patch :
2012-10-16 19:28:22 +02:00
. if ${PORT_OPTIONS : MICU }
2010-10-06 12:56:57 +02:00
@${ REINPLACE_CMD } -E -e \
2010-12-09 17:10:19 +01:00
" s|^(m4_if.*)2.6[0-9](.*Autoconf version )2.6[0-9]|\1 ${ AUTOCONF_VERSION } \2 ${ AUTOCONF_VERSION } |g " \
2010-10-06 12:56:57 +02:00
${ WRKSRC } /configure.in
2010-10-07 08:58:10 +02:00
. e n d i f
2010-01-04 21:29:37 +01:00
2004-11-23 20:15:12 +01:00
do-install :
@for dir in ${ INSTALL_DIRS } ; do \
cd ${ WRKSRC } /$$ { dir} && \
2014-06-25 00:34:27 +02:00
${ SETENV } ${ MAKE_ENV } ${ MAKE_CMD } ${ MAKE_ARGS } ${ INSTALL_TARGET } ; \
2004-11-23 20:15:12 +01:00
done
. i f d e f i n e d ( S E R V E R _ O N L Y )
2014-02-26 18:24:35 +01:00
@ ${ MKDIR } ${ STAGEDIR } ${ PREFIX } /share/postgresql ; \
${ MKDIR } ${ STAGEDIR } ${ PREFIX } /etc/periodic/daily ; \
2011-04-19 01:34:27 +02:00
${ INSTALL_SCRIPT } ${ WRKDIR } /502.pgsql \
2014-02-26 18:24:35 +01:00
${ STAGEDIR } ${ PREFIX } /etc/periodic/daily
${ MKDIR } ${ STAGEDIR } ${ PREFIX } /${ PG_USER }
2004-11-23 20:15:12 +01:00
. e n d i f # SERVER_ONLY
2005-05-11 02:40:15 +02:00
. i f d e f i n e d ( C L I E N T _ O N L Y )
2014-06-25 00:34:27 +02:00
@ cd ${ WRKSRC } /src && ${ SETENV } ${ MAKE_ENV } ${ MAKE_CMD } ${ MAKE_ARGS } install-local
2005-05-11 02:40:15 +02:00
. e n d i f
2004-11-23 20:15:12 +01:00
@ if [ -r ${ PKGMESSAGE } ] ; then \
2014-02-26 18:24:35 +01:00
${ MKDIR } ${ STAGEDIR } ${ DOCSDIR } ; \
${ INSTALL_DATA } ${ PKGMESSAGE } ${ STAGEDIR } ${ DOCSDIR } /README${ COMPONENT } ; \
2004-11-23 20:15:12 +01:00
fi
. e n d i f # !NO_BUILD
1997-04-09 17:30:55 +02:00
2008-01-22 15:08:48 +01:00
. i f d e f i n e d ( S E R V E R _ O N L Y )
2003-02-06 21:46:51 +01:00
check :
@if [ ` id -u` != 0 ] ; then \
${ ECHO } "Running postgresql regressions tests" ; \
2014-06-25 00:34:27 +02:00
cd ${ WRKSRC } ; ${ MAKE_CMD } check ; \
2003-02-06 21:46:51 +01:00
else \
${ ECHO } "You cannot run regression tests when postgresql is built as user root." ; \
${ ECHO } "Clean and rebuild the port as a regular user to run the tests." ; \
fi
. e n d i f
2013-04-28 16:00:02 +02:00
. i n c l u d e < b s d . p o r t . p o s t . m k >