Change postgresql to experimental coding style Make configure honor CPPFLAGS

SVN-Revision: 638
This commit is contained in:
Nicolas Thill 2005-04-14 06:04:34 +00:00
parent 13537f60aa
commit 1fffe9977a
3 changed files with 107 additions and 39 deletions

View File

@ -2,57 +2,107 @@
include $(TOPDIR)/rules.mk include $(TOPDIR)/rules.mk
PKG_NAME := postgresql PKG_NAME:=postgresql
PKG_VERSION := 7.4.6 PKG_VERSION:=7.4.6
PKG_RELEASE := 3 PKG_RELEASE:=3
PKG_MD5SUM := f0ea2b372a7bdaf2613e92176ebf5e0f PKG_MD5SUM:=f0ea2b372a7bdaf2613e92176ebf5e0f
PKG_SOURCE_SITE := \ PKG_SOURCE_URL:=\
ftp://ftp3.us.postgresql.org/pub/postgresql/source/v$(PKG_VERSION)/ \ ftp://ftp3.us.postgresql.org/pub/postgresql/source/v$(PKG_VERSION)/ \
ftp://ftp.br.postgresql.org/pub/PostgreSQL/source/v$(PKG_VERSION)/ \ ftp://ftp.br.postgresql.org/pub/PostgreSQL/source/v$(PKG_VERSION)/ \
ftp://ftp.au.postgresql.org/pub/postgresql/source/v$(PKG_VERSION)/ \ ftp://ftp.au.postgresql.org/pub/postgresql/source/v$(PKG_VERSION)/ \
ftp://ftp.tw.postgresql.org/pub/postgresql/source/v$(PKG_VERSION)/ \ ftp://ftp.tw.postgresql.org/pub/postgresql/source/v$(PKG_VERSION)/ \
http://nthill.free.fr/openwrt/sources/$(PKG_NAME)/ http://nthill.free.fr/openwrt/sources/$(PKG_NAME)/
PKG_SOURCE_FILE := $(PKG_NAME)-$(PKG_VERSION).tar.bz2 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2
PKG_SOURCE_CAT := bzcat PKG_CAT:=bzcat
PKG_SOURCE_DIR := $(PKG_NAME)-$(PKG_VERSION)
PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_SOURCE_DIR)
PKG_IPK := $(PACKAGE_DIR)/libpq_$(PKG_VERSION)-$(PKG_RELEASE)_$(ARCH).ipk
PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_VERSION)
$(DL_DIR)/$(PKG_SOURCE_FILE): IPKG_LIBPQ:=$(PACKAGE_DIR)/libpq_$(PKG_VERSION)-$(PKG_RELEASE)_$(ARCH).ipk
mkdir -p $(DL_DIR) IDIR_LIBPQ:=$(PKG_BUILD_DIR)/ipkg
$(SCRIPT_DIR)/download.pl $(DL_DIR) $(PKG_SOURCE_FILE) $(PKG_MD5SUM) $(PKG_SOURCE_SITE) INFO_LIBPQ:=$(IPKG_STATE_DIR)/info/libpq.list
$(PKG_BUILD_DIR)/ipkg/rules: $(DL_DIR)/$(PKG_SOURCE_FILE) $(DL_DIR)/$(PKG_SOURCE):
mkdir -p $(TOOL_BUILD_DIR) $(SCRIPT_DIR)/download.pl $(DL_DIR) $(PKG_SOURCE) $(PKG_MD5SUM) $(PKG_SOURCE_URL)
rm -rf $(PKG_BUILD_DIR)
$(PKG_SOURCE_CAT) $(DL_DIR)/$(PKG_SOURCE_FILE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) - $(PKG_BUILD_DIR)/.prepared: $(DL_DIR)/$(PKG_SOURCE)
$(PKG_CAT) $(DL_DIR)/$(PKG_SOURCE) | tar -C $(BUILD_DIR) $(TAR_OPTIONS) -
$(PATCH) $(PKG_BUILD_DIR) ./patches $(PATCH) $(PKG_BUILD_DIR) ./patches
cp -fpR ./ipkg $(PKG_BUILD_DIR)/ touch $(PKG_BUILD_DIR)/.prepared
find $(PKG_BUILD_DIR) -name CVS | xargs rm -rf
chmod a+x $(PKG_BUILD_DIR)/ipkg/rules
touch $(PKG_BUILD_DIR)/ipkg/rules
$(PKG_IPK): $(PKG_BUILD_DIR)/ipkg/rules $(PKG_BUILD_DIR)/.configured: $(PKG_BUILD_DIR)/.prepared
cd $(PKG_BUILD_DIR); \ # ./configure advertise "--infodir", but does not support it, replaced with "--docdir"
TOPDIR="$(TOPDIR)" IPKG_RULES_INC="$(TOPDIR)/rules.mk" \ (cd $(PKG_BUILD_DIR); rm -rf config.cache config.status; \
INSTALL_DIR="$(STAGING_DIR)" \ $(TARGET_CONFIGURE_OPTS) \
./ipkg/rules package CFLAGS="$(TARGET_CFLAGS)" \
CPPFLAGS="$$CPPFLAGS -I$(STAGING_DIR)/usr/include" \
LDFLAGS="-L$(STAGING_DIR)/usr/lib" \
./configure \
--target=$(GNU_TARGET_NAME) \
--host=$(GNU_TARGET_NAME) \
--build=$(GNU_HOST_NAME) \
--program-prefix="" \
--program-suffix="" \
--prefix=/usr \
--exec-prefix=/usr \
--bindir=/usr/bin \
--datadir=/usr/share \
--includedir=/usr/include \
--docdir=/usr/share/info \
--libdir=/usr/lib \
--libexecdir=/usr/lib \
--localstatedir=/var \
--mandir=/usr/share/man \
--sbindir=/usr/sbin \
--sysconfdir=/etc \
$(DISABLE_NLS) \
$(DISABLE_LARGEFILE) \
--enable-shared \
--enable-static \
--disable-integer-datetimes \
--disable-rpath \
--without-java \
--without-krb4 \
--without-krb5 \
--without-openssl \
--without-pam \
--without-perl \
--without-python \
--without-readline \
--without-rendezvous \
--without-tcl \
--without-tk \
--with-zlib="yes" \
);
touch $(PKG_BUILD_DIR)/.configured
$(IPKG_STATE_DIR)/info/libpq.list: $(PKG_IPK) $(PKG_BUILD_DIR)/.built: $(PKG_BUILD_DIR)/.configured
$(IPKG) install $(PKG_IPK) $(MAKE) -C "$(PKG_BUILD_DIR)" \
$(TARGET_CONFIGURE_OPTS)
touch $(PKG_BUILD_DIR)/.built
source: $(DL_DIR)/$(PKG_SOURCE_FILE) $(STAGING_DIR)/usr/lib/libpq.so: $(PKG_BUILD_DIR)/.built
prepare: $(PKG_BUILD_DIR)/ipkg/rules $(MAKE) -C "$(PKG_BUILD_DIR)" \
compile: $(PKG_IPK) DESTDIR="$(STAGING_DIR)" \
install: $(IPKG_STATE_DIR)/info/libpq.list install
$(IPKG_LIBPQ): $(STAGING_DIR)/usr/lib/libpq.so
$(SCRIPT_DIR)/make-ipkg-dir.sh $(IDIR_LIBPQ) libpq.control $(PKG_VERSION)-$(PKG_RELEASE) $(ARCH)
mkdir -p $(IDIR_LIBPQ)/usr/lib
cp -fp $(STAGING_DIR)/usr/lib/libpq.so.* $(IDIR_LIBPQ)/usr/lib/
$(STRIP) $(IDIR_LIBPQ)/usr/lib/*.so*
mkdir -p $(PACKAGE_DIR)
$(IPKG_BUILD) $(IDIR_LIBPQ) $(PACKAGE_DIR)
$(INFO_LIBPQ): $(IPKG_LIBPQ)
$(IPKG) install $(IPKG_LIBPQ)
prepare: $(PKG_BUILDPKG_SOURCE_DIR)/.prepared
compile: $(IPKG_LIBPQ)
install: $(INFO_LIBPQ)
clean: clean:
-cd $(PKG_BUILD_DIR); \ -$(MAKE) -C "$(PKG_BUILD_DIR)" \
TOPDIR="$(TOPDIR)" IPKG_RULES_INC="$(TOPDIR)/rules.mk" \ DESTDIR="$(STAGING_DIR)" \
INSTALL_DIR="$(STAGING_DIR)" \ uninstall
./ipkg/rules clean rm -rf $(PKG_BUILD_DIR) $(IPKG_LIBPQ)
rm -rf $(PKG_BUILD_DIR)
rm -f $(PKG_IPK)

View File

@ -0,0 +1,8 @@
Package: libpq
Priority: optional
Section: libs
Version: [TBDL]
Architecture: [TBDL]
Maintainer: Nico <nthill@free.fr>
Source: http://nthill.free.fr/openwrt/sources/postgresql/
Description: PostgreSQL client library

View File

@ -0,0 +1,10 @@
diff -ruN postgresql-7.4.6-old/src/template/linux postgresql-7.4.6-new/src/template/linux
--- postgresql-7.4.6-old/src/template/linux 2003-10-09 18:52:45.000000000 +0200
+++ postgresql-7.4.6-new/src/template/linux 2005-04-13 03:12:49.000000000 +0200
@@ -1,5 +1,5 @@
# Force _GNU_SOURCE on; plperl is broken with Perl 5.8.0 otherwise
-CPPFLAGS="-D_GNU_SOURCE"
+CPPFLAGS="$CPPFLAGS -D_GNU_SOURCE"
THREAD_SUPPORT=yes
NEED_REENTRANT_FUNCS=yes # Debian kernel 2.2 2003-09-27