2 # Copyright (C) 2006 OpenWrt.org
4 # This is free software, licensed under the GNU General Public License v2.
5 # See /LICENSE for more information.
9 include $(TOPDIR)/rules.mk
15 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2
17 http://ftp7.us.postgresql.org/pub/postgresql/source/v$(PKG_VERSION) \
18 http://ftp8.us.postgresql.org/pub/postgresql/source/v$(PKG_VERSION) \
19 http://ftp9.us.postgresql.org/pub/postgresql/source/v$(PKG_VERSION) \
20 http://ftp.be.postgresql.org/postgresql/source/v$(PKG_VERSION) \
21 ftp://ftp-archives.postgresql.org/pub/source/v$(PKG_VERSION)
22 PKG_MD5SUM:=0ae4bd9620e84d3e08dcf923808d14d0
24 PKG_BUILD_DEPENDS:=libnotimpl
26 include $(INCLUDE_DIR)/package.mk
31 DEPENDS:=+zlib +libreadline +libncurses
32 TITLE:=PostgreSQL client library
33 URL:=http://www.postgresql.org/
37 define Package/libpq/description
38 PostgreSQL client library.
41 define Package/pgsql-cli
45 TITLE:=Command Line Interface (CLI) to PostgreSQL databases
46 URL:=http://www.postgresql.org/
50 define Package/pgsql-cli/description
51 Command Line Interface (CLI) to PostgreSQL databases.
54 define Package/pgsql-server
58 TITLE:=PostgreSQL databases Server
59 URL:=http://www.postgresql.org/
63 define Package/pgsql-server/description
64 PostgreSQL databases Server.
67 # Need a native ecpg ,pg_config, and zic for build
68 define Build/Configure
69 (cd $(PKG_BUILD_DIR); rm -f config.cache; \
74 --datadir=/usr/share \
75 --includedir=/usr/include \
76 --infodir=/usr/share/info \
78 --libexecdir=/usr/lib \
79 --localstatedir=/var \
80 --mandir=/usr/share/man \
84 $(DISABLE_LARGEFILE) \
87 --disable-integer-datetimes \
97 --without-rendezvous \
103 $(MAKE) -C $(PKG_BUILD_DIR)/src/interfaces/ecpg/preproc CC="$(HOSTCC)" CFLAGS+="-I../../libpq"
104 mv $(PKG_BUILD_DIR)/src/interfaces/ecpg/preproc/ecpg \
105 $(PKG_BUILD_DIR)/src/interfaces/ecpg/preproc/ecpg.host
106 $(MAKE) -C $(PKG_BUILD_DIR)/src/timezone CC="$(HOSTCC)"
107 mv $(PKG_BUILD_DIR)/src/timezone/zic $(PKG_BUILD_DIR)/src/timezone/zic.host
108 $(MAKE) -C $(PKG_BUILD_DIR)/src/bin/pg_config CC="$(HOSTCC)"
109 mv $(PKG_BUILD_DIR)/src/bin/pg_config/pg_config \
110 $(PKG_BUILD_DIR)/src/bin/pg_config/pg_config.host
111 $(MAKE) -C $(PKG_BUILD_DIR) distclean
113 (cd $(PKG_BUILD_DIR); rm -f config.cache; \
114 $(TARGET_CONFIGURE_OPTS) \
115 CFLAGS="$(TARGET_CFLAGS)" \
116 CPPFLAGS="$$$$CPPFLAGS $(TARGET_CPPFLAGS)" \
117 LDFLAGS="$(TARGET_LDFLAGS)" \
120 --target=$(GNU_TARGET_NAME) \
121 --host=$(GNU_TARGET_NAME) \
122 --build=$(GNU_HOST_NAME) \
123 --program-prefix="" \
124 --program-suffix="" \
128 --datadir=/usr/share \
129 --includedir=/usr/include \
130 --infodir=/usr/share/info \
132 --libexecdir=/usr/lib \
133 --localstatedir=/var \
134 --mandir=/usr/share/man \
135 --sbindir=/usr/sbin \
138 $(DISABLE_LARGEFILE) \
141 --disable-integer-datetimes \
150 --without-rendezvous \
155 $(if $(CONFIG_TARGET_avr32),--disable-spinlocks) \
157 $(SED) 's@ECPG = ../../preproc/ecpg@ECPG = ../../preproc/ecpg.host@' $(PKG_BUILD_DIR)/src/interfaces/ecpg/test/Makefile.regress
158 $(SED) 's@\./zic -d@./zic.host -d@' $(PKG_BUILD_DIR)/src/timezone/Makefile
159 # note: unclear if this is needed yet, commenting out for the moment
160 #$(SED) 's@US/Eastern@America/New_York@' $(PKG_BUILD_DIR)/src/timezone/Makefile
163 TARGET_CFLAGS += $(FPIC)
166 $(MAKE) -C "$(PKG_BUILD_DIR)" \
167 DESTDIR="$(PKG_INSTALL_DIR)" \
171 define Package/libpq/install
172 $(INSTALL_DIR) $(1)/usr/lib
173 $(CP) $(PKG_INSTALL_DIR)/usr/lib/libpq.so.* $(1)/usr/lib/
176 define Package/pgsql-cli/install
177 $(INSTALL_DIR) $(1)/usr/bin
178 $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/psql $(1)/usr/bin/
181 define Package/pgsql-server/install
182 $(INSTALL_DIR) $(1)/usr/bin
183 $(INSTALL_DIR) $(1)/usr/share/postgresql
184 $(INSTALL_DIR) $(1)/usr/lib
185 $(INSTALL_DIR) $(1)/etc/init.d
186 $(INSTALL_DIR) $(1)/etc/config
188 $(PKG_INSTALL_DIR)/usr/bin/postgres \
189 $(PKG_INSTALL_DIR)/usr/bin/dropdb \
190 $(PKG_INSTALL_DIR)/usr/bin/clusterdb \
191 $(PKG_INSTALL_DIR)/usr/bin/createdb \
192 $(PKG_INSTALL_DIR)/usr/bin/createlang \
193 $(PKG_INSTALL_DIR)/usr/bin/createuser \
194 $(PKG_INSTALL_DIR)/usr/bin/droplang \
195 $(PKG_INSTALL_DIR)/usr/bin/dropuser \
196 $(PKG_INSTALL_DIR)/usr/bin/initdb \
197 $(PKG_INSTALL_DIR)/usr/bin/ipcclean \
198 $(PKG_INSTALL_DIR)/usr/bin/pg_config \
199 $(PKG_INSTALL_DIR)/usr/bin/pg_controldata \
200 $(PKG_INSTALL_DIR)/usr/bin/pg_ctl \
201 $(PKG_INSTALL_DIR)/usr/bin/pg_dump \
202 $(PKG_INSTALL_DIR)/usr/bin/pg_dumpall \
203 $(PKG_INSTALL_DIR)/usr/bin/pg_restore \
204 $(PKG_INSTALL_DIR)/usr/bin/pg_resetxlog \
205 $(PKG_INSTALL_DIR)/usr/bin/reindexdb \
206 $(PKG_INSTALL_DIR)/usr/bin/vacuumdb \
208 ln -sf postgres $(1)/usr/bin/postmaster
210 $(INSTALL_BIN) ./files/postgresql.init $(1)/etc/init.d/postgresql
213 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgres.bki \
214 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgres.description \
215 $(PKG_INSTALL_DIR)/usr/share/postgresql/conversion_create.sql \
216 $(PKG_INSTALL_DIR)/usr/share/postgresql/information_schema.sql \
217 $(PKG_INSTALL_DIR)/usr/share/postgresql/pg_hba.conf.sample \
218 $(PKG_INSTALL_DIR)/usr/share/postgresql/pg_ident.conf.sample \
219 $(PKG_INSTALL_DIR)/usr/share/postgresql/pg_service.conf.sample \
220 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgresql.conf.sample \
221 $(PKG_INSTALL_DIR)/usr/share/postgresql/sql_features.txt \
222 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgres.shdescription \
223 $(PKG_INSTALL_DIR)/usr/share/postgresql/psqlrc.sample \
224 $(PKG_INSTALL_DIR)/usr/share/postgresql/recovery.conf.sample \
225 $(PKG_INSTALL_DIR)/usr/share/postgresql/system_views.sql \
226 $(PKG_INSTALL_DIR)/usr/share/postgresql/snowball_create.sql \
227 $(1)/usr/share/postgresql
229 $(INSTALL_DATA) ./files/postgresql.config $(1)/etc/config/postgresql
232 $(PKG_INSTALL_DIR)/usr/share/postgresql/timezone \
233 $(PKG_INSTALL_DIR)/usr/share/postgresql/timezonesets \
234 $(1)/usr/share/postgresql
237 $(PKG_INSTALL_DIR)/usr/lib/postgresql \
241 define Package/pgsql-server/postinst
243 grep -q '^postgres:' /etc/passwd && exit 0
245 if [ -e /bin/addgroup ]; then
246 /bin/addgroup postgres
249 if [ -e /bin/adduser ]; then
250 /bin/adduser -h /tmp -H -g 'PostgreSQL administrator' -s /bin/ash -D -H -G postgres postgres
255 if [ -z "$${RG}" -o -z "$${RU}" ]; then
256 echo "Could not find user utils, you will need to create the postgres user by hand"
260 if [ "$${RG}" != "0" -o "$${RU}" != "0" ]; then
261 echo "Failed to created postgres user"
266 define Build/InstallDev
267 mkdir -p $(1)/usr/bin
268 $(INSTALL_BIN) $(PKG_BUILD_DIR)/src/bin/pg_config/pg_config.host $(1)/usr/bin/pg_config
269 mkdir -p $(1)/usr/include
270 $(CP) $(PKG_INSTALL_DIR)/usr/include/libpq $(1)/usr/include/
271 $(CP) $(PKG_INSTALL_DIR)/usr/include/libpq-fe.h $(1)/usr/include/
272 $(CP) $(PKG_INSTALL_DIR)/usr/include/pg_config.h $(1)/usr/include/
273 $(CP) $(PKG_INSTALL_DIR)/usr/include/postgres_ext.h $(1)/usr/include/
274 $(CP) $(PKG_INSTALL_DIR)/usr/include/postgresql $(1)/usr/include/
275 mkdir -p $(1)/usr/lib
276 $(CP) $(PKG_INSTALL_DIR)/usr/lib/libpq.{a,so*} $(1)/usr/lib/
277 $(CP) $(PKG_BUILD_DIR)/src/interfaces/ecpg/preproc/ecpg.host $(1)/usr/bin/ecpg
278 $(CP) $(PKG_BUILD_DIR)/src/timezone/zic.host $(1)/usr/bin/zic
281 $(eval $(call BuildPackage,libpq))
282 $(eval $(call BuildPackage,pgsql-cli))
283 $(eval $(call BuildPackage,pgsql-server))