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
164 $(MAKE) -C "$(PKG_BUILD_DIR)" \
165 DESTDIR="$(PKG_INSTALL_DIR)" \
169 define Package/libpq/install
170 $(INSTALL_DIR) $(1)/usr/lib
171 $(CP) $(PKG_INSTALL_DIR)/usr/lib/libpq.so.* $(1)/usr/lib/
174 define Package/pgsql-cli/install
175 $(INSTALL_DIR) $(1)/usr/bin
176 $(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/psql $(1)/usr/bin/
179 define Package/pgsql-server/install
180 $(INSTALL_DIR) $(1)/usr/bin
181 $(INSTALL_DIR) $(1)/usr/share/postgresql
182 $(INSTALL_DIR) $(1)/usr/lib
183 $(INSTALL_DIR) $(1)/etc/init.d
184 $(INSTALL_DIR) $(1)/etc/config
186 $(PKG_INSTALL_DIR)/usr/bin/postgres \
187 $(PKG_INSTALL_DIR)/usr/bin/dropdb \
188 $(PKG_INSTALL_DIR)/usr/bin/clusterdb \
189 $(PKG_INSTALL_DIR)/usr/bin/createdb \
190 $(PKG_INSTALL_DIR)/usr/bin/createlang \
191 $(PKG_INSTALL_DIR)/usr/bin/createuser \
192 $(PKG_INSTALL_DIR)/usr/bin/droplang \
193 $(PKG_INSTALL_DIR)/usr/bin/dropuser \
194 $(PKG_INSTALL_DIR)/usr/bin/initdb \
195 $(PKG_INSTALL_DIR)/usr/bin/ipcclean \
196 $(PKG_INSTALL_DIR)/usr/bin/pg_config \
197 $(PKG_INSTALL_DIR)/usr/bin/pg_controldata \
198 $(PKG_INSTALL_DIR)/usr/bin/pg_ctl \
199 $(PKG_INSTALL_DIR)/usr/bin/pg_dump \
200 $(PKG_INSTALL_DIR)/usr/bin/pg_dumpall \
201 $(PKG_INSTALL_DIR)/usr/bin/pg_restore \
202 $(PKG_INSTALL_DIR)/usr/bin/pg_resetxlog \
203 $(PKG_INSTALL_DIR)/usr/bin/reindexdb \
204 $(PKG_INSTALL_DIR)/usr/bin/vacuumdb \
206 ln -sf postgres $(1)/usr/bin/postmaster
208 $(INSTALL_BIN) ./files/postgresql.init $(1)/etc/init.d/postgresql
211 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgres.bki \
212 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgres.description \
213 $(PKG_INSTALL_DIR)/usr/share/postgresql/conversion_create.sql \
214 $(PKG_INSTALL_DIR)/usr/share/postgresql/information_schema.sql \
215 $(PKG_INSTALL_DIR)/usr/share/postgresql/pg_hba.conf.sample \
216 $(PKG_INSTALL_DIR)/usr/share/postgresql/pg_ident.conf.sample \
217 $(PKG_INSTALL_DIR)/usr/share/postgresql/pg_service.conf.sample \
218 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgresql.conf.sample \
219 $(PKG_INSTALL_DIR)/usr/share/postgresql/sql_features.txt \
220 $(PKG_INSTALL_DIR)/usr/share/postgresql/postgres.shdescription \
221 $(PKG_INSTALL_DIR)/usr/share/postgresql/psqlrc.sample \
222 $(PKG_INSTALL_DIR)/usr/share/postgresql/recovery.conf.sample \
223 $(PKG_INSTALL_DIR)/usr/share/postgresql/system_views.sql \
224 $(PKG_INSTALL_DIR)/usr/share/postgresql/snowball_create.sql \
225 $(1)/usr/share/postgresql
227 $(INSTALL_DATA) ./files/postgresql.config $(1)/etc/config/postgresql
230 $(PKG_INSTALL_DIR)/usr/share/postgresql/timezone \
231 $(PKG_INSTALL_DIR)/usr/share/postgresql/timezonesets \
232 $(1)/usr/share/postgresql
235 $(PKG_INSTALL_DIR)/usr/lib/postgresql \
239 define Package/pgsql-server/postinst
241 grep -q '^postgres:' /etc/passwd && exit 0
243 if [ -e /bin/addgroup ]; then
244 /bin/addgroup postgres
247 if [ -e /bin/adduser ]; then
248 /bin/adduser -h /tmp -H -g 'PostgreSQL administrator' -s /bin/ash -D -H -G postgres postgres
253 if [ -z "$${RG}" -o -z "$${RU}" ]; then
254 echo "Could not find user utils, you will need to create the postgres user by hand"
258 if [ "$${RG}" != "0" -o "$${RU}" != "0" ]; then
259 echo "Failed to created postgres user"
264 define Build/InstallDev
265 mkdir -p $(1)/usr/bin
266 $(INSTALL_BIN) $(PKG_BUILD_DIR)/src/bin/pg_config/pg_config.host $(1)/usr/bin/pg_config
267 mkdir -p $(1)/usr/include
268 $(CP) $(PKG_INSTALL_DIR)/usr/include/libpq $(1)/usr/include/
269 $(CP) $(PKG_INSTALL_DIR)/usr/include/libpq-fe.h $(1)/usr/include/
270 $(CP) $(PKG_INSTALL_DIR)/usr/include/pg_config.h $(1)/usr/include/
271 $(CP) $(PKG_INSTALL_DIR)/usr/include/postgres_ext.h $(1)/usr/include/
272 $(CP) $(PKG_INSTALL_DIR)/usr/include/postgresql $(1)/usr/include/
273 mkdir -p $(1)/usr/lib
274 $(CP) $(PKG_INSTALL_DIR)/usr/lib/libpq.{a,so*} $(1)/usr/lib/
275 $(CP) $(PKG_BUILD_DIR)/src/interfaces/ecpg/preproc/ecpg.host $(1)/usr/bin/ecpg
276 $(CP) $(PKG_BUILD_DIR)/src/timezone/zic.host $(1)/usr/bin/zic
279 $(eval $(call BuildPackage,libpq))
280 $(eval $(call BuildPackage,pgsql-cli))
281 $(eval $(call BuildPackage,pgsql-server))