From: Nicolas Thill Date: Tue, 18 Jul 2006 12:09:39 +0000 (+0000) Subject: port ncurses to buildroot-ng. X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=75f49c24bf7d2a5ca9fea2047c0513f9b0df32db;p=openwrt%2Fsvn-archive%2Farchive.git port ncurses to buildroot-ng. SVN-Revision: 4136 --- diff --git a/libs/ncurses/Makefile b/libs/ncurses/Makefile new file mode 100644 index 0000000000..75ca074b4f --- /dev/null +++ b/libs/ncurses/Makefile @@ -0,0 +1,164 @@ +# +# Copyright (C) 2006 OpenWrt.org +# +# This is free software, licensed under the GNU General Public License v2. +# See /LICENSE for more information. +# +# $Id$ + +include $(TOPDIR)/rules.mk + +PKG_NAME:=ncurses +PKG_VERSION:=5.2 +PKG_RELEASE:=8 + +PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_VERSION) +PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz +PKG_SOURCE_URL:=@GNU/ncurses +PKG_MD5SUM:=464d6a49010cf2a6eb9ce59a264d4d47 +PKG_CAT:=zcat + +PKG_INSTALL_DIR:=$(PKG_BUILD_DIR)/ipkg-install + +include $(INCLUDE_DIR)/package.mk + +define Package/libncurses + SECTION:=libs + CATEGORY:=Libraries + TITLE:=Terminal handling library + DESCRIPTION:=Terminal handling library + URL:=http://www.gnu.org/software/ncurses/ +endef + +define Build/Configure +endef + +define Build/Compile + rm -rf $(PKG_INSTALL_DIR) + mkdir -p $(PKG_INSTALL_DIR) + (cd $(PKG_BUILD_DIR); rm -f config.cache; \ + ./configure \ + --target=$(GNU_HOST_NAME) \ + --host=$(GNU_HOST_NAME) \ + --build=$(GNU_HOST_NAME) \ + --program-prefix="" \ + --program-suffix="" \ + --prefix=/usr \ + --exec-prefix=/usr \ + --bindir=/usr/bin \ + --datadir=/usr/share \ + --includedir=/usr/include \ + --infodir=/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-echo \ + --enable-const \ + --enable-overwrite \ + --disable-rpath \ + --without-ada \ + --without-cxx \ + --without-cxx-binding \ + --without-debug \ + --without-profile \ + --with-progs \ + --with-normal \ + --without-shared \ + --with-terminfo-dirs=/usr/share/terminfo \ + --with-default-terminfo-dir=/usr/share/terminfo \ + ); + $(MAKE) -C $(PKG_BUILD_DIR) \ + DESTDIR="$(PKG_INSTALL_DIR)" \ + libs install.progs + (cd $(PKG_BUILD_DIR); rm -f config.cache; \ + $(TARGET_CONFIGURE_OPTS) \ + CFLAGS="$(TARGET_CFLAGS)" \ + CPPFLAGS="-I$(STAGING_DIR)/usr/include -I$(STAGING_DIR)/include" \ + LDFLAGS="-L$(STAGING_DIR)/usr/lib -L$(STAGING_DIR)/lib" \ + ac_cv_linux_vers="2" \ + ./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 \ + --infodir=/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-echo \ + --enable-const \ + --enable-overwrite \ + --disable-rpath \ + --without-ada \ + --without-cxx \ + --without-cxx-binding \ + --without-debug \ + --without-profile \ + --without-progs \ + --with-normal \ + --with-shared \ + --with-terminfo-dirs=/usr/share/terminfo \ + --with-default-terminfo-dir=/usr/share/terminfo \ + ); + $(MAKE) -C $(PKG_BUILD_DIR) \ + $(TARGET_CONFIGURE_OPTS) \ + BUILD_CC="$(TARGET_CC)" \ + HOSTCC="$(HOSTCC)" \ + HOSTCCFLAGS="" \ + DESTDIR="$(PKG_INSTALL_DIR)" \ + libs install.libs install.data +endef + +define Package/libncurses/install + install -d -m0755 $(1)/usr/lib + $(CP) $(PKG_INSTALL_DIR)/usr/lib/lib{ncurses,panel,menu}*.so.* $(1)/usr/lib/ + install -d -m0755 $(1)/usr/share/terminfo + for file in a/ansi d/dumb l/linux r/rxvt s/screen v/vt100 v/vt102 x/xterm x/xterm-color; do \ + install -d -m0755 $(1)/usr/share/terminfo/`dirname $$$$file`; \ + $(CP) $(PKG_INSTALL_DIR)/usr/share/terminfo/$$$$file \ + $(1)/usr/share/terminfo/$$$$file; \ + done +endef + +define Build/InstallDev + mkdir -p $(STAGING_DIR)/usr/include + $(CP) $(PKG_INSTALL_DIR)/usr/include/curses.h $(STAGING_DIR)/usr/include/ + $(CP) $(PKG_INSTALL_DIR)/usr/include/ncurses.h $(STAGING_DIR)/usr/include/ + $(CP) $(PKG_INSTALL_DIR)/usr/include/menu.h $(STAGING_DIR)/usr/include/ + $(CP) $(PKG_INSTALL_DIR)/usr/include/panel.h $(STAGING_DIR)/usr/include/ + $(CP) $(PKG_INSTALL_DIR)/usr/include/term{,cap}.h $(STAGING_DIR)/usr/include/ + $(CP) $(PKG_INSTALL_DIR)/usr/include/unctrl.h $(STAGING_DIR)/usr/include/ + mkdir -p $(STAGING_DIR)/usr/lib + $(CP) $(PKG_INSTALL_DIR)/usr/lib/libcurses.so $(STAGING_DIR)/usr/lib/ + $(CP) $(PKG_INSTALL_DIR)/usr/lib/lib{ncurses,panel,menu}.{a,so*} $(STAGING_DIR)/usr/lib/ +endef + +define Build/UninstallDev + rm -rf \ + $(STAGING_DIR)/usr/include/curses.h \ + $(STAGING_DIR)/usr/include/ncurses.h \ + $(STAGING_DIR)/usr/include/menu.h \ + $(STAGING_DIR)/usr/include/panel.h \ + $(STAGING_DIR)/usr/include/term{,cap}.h \ + $(STAGING_DIR)/usr/include/unctrl.h \ + $(STAGING_DIR)/usr/lib/libcurses.so \ + $(STAGING_DIR)/usr/lib/lib{ncurses,panel,menu}.{a,so*} +endef + +$(eval $(call BuildPackage,libncurses)) diff --git a/libs/ncurses/patches/500-cross.patch b/libs/ncurses/patches/500-cross.patch new file mode 100644 index 0000000000..9536191408 --- /dev/null +++ b/libs/ncurses/patches/500-cross.patch @@ -0,0 +1,24 @@ +diff -ruN ncurses-5.2-orig/aclocal.m4 ncurses-5.2-6/aclocal.m4 +--- ncurses-5.2-orig/aclocal.m4 2000-10-21 00:57:49.000000000 +0200 ++++ ncurses-5.2-6/aclocal.m4 2005-08-09 14:50:15.000000000 +0200 +@@ -1919,7 +1919,7 @@ + EXTRA_LDFLAGS="$LOCAL_LDFLAGS $EXTRA_LDFLAGS" + fi + test "$cf_cv_shlib_version" = auto && cf_cv_shlib_version=rel +- MK_SHARED_LIB='$(CC) -shared -Wl,-soname,`basename $[@] .$(REL_VERSION)`.$(ABI_VERSION),-stats,-lc -o $[@]' ++ MK_SHARED_LIB='$(CC) -shared -Wl,-soname,`basename $[@] .$(REL_VERSION)`.$(ABI_VERSION),-stats,$(LDFLAGS) -lc -o $[@]' + ;; + openbsd2*) + CC_SHARED_OPTS="$CC_SHARED_OPTS -DPIC" +diff -ruN ncurses-5.2-orig/configure ncurses-5.2-6/configure +--- ncurses-5.2-orig/configure 2000-10-21 00:58:49.000000000 +0200 ++++ ncurses-5.2-6/configure 2005-08-09 14:50:25.000000000 +0200 +@@ -2660,7 +2660,7 @@ + EXTRA_LDFLAGS="$LOCAL_LDFLAGS $EXTRA_LDFLAGS" + fi + test "$cf_cv_shlib_version" = auto && cf_cv_shlib_version=rel +- MK_SHARED_LIB='$(CC) -shared -Wl,-soname,`basename $@ .$(REL_VERSION)`.$(ABI_VERSION),-stats,-lc -o $@' ++ MK_SHARED_LIB='$(CC) -shared -Wl,-soname,`basename $@ .$(REL_VERSION)`.$(ABI_VERSION),-stats,$(LDFLAGS) -lc -o $@' + ;; + openbsd2*) + CC_SHARED_OPTS="$CC_SHARED_OPTS -DPIC" diff --git a/libs/ncurses/patches/501-cross-no_libdir.patch b/libs/ncurses/patches/501-cross-no_libdir.patch new file mode 100644 index 0000000000..b8b277fb18 --- /dev/null +++ b/libs/ncurses/patches/501-cross-no_libdir.patch @@ -0,0 +1,65 @@ +diff -ruN ncurses-5.2-old/configure ncurses-5.2-new/configure +--- ncurses-5.2-old/configure 2005-08-23 04:17:49.000000000 +0200 ++++ ncurses-5.2-new/configure 2005-08-23 04:18:39.000000000 +0200 +@@ -7191,11 +7191,11 @@ + fi + done + echo "$ac_t""$cf_cv_src_modules" 1>&6 +-TEST_ARGS="-L${LIB_DIR} -L\$(libdir) $TEST_ARGS" ++TEST_ARGS="-L${LIB_DIR} $TEST_ARGS" + + + +-PROG_ARGS="-L${LIB_DIR} -L\$(libdir) $PROG_ARGS" ++PROG_ARGS="-L${LIB_DIR} $PROG_ARGS" + + + SRC_SUBDIRS="man include" +diff -ruN ncurses-5.2-old/form/Makefile.in ncurses-5.2-new/form/Makefile.in +--- ncurses-5.2-old/form/Makefile.in 2000-10-14 19:57:02.000000000 +0200 ++++ ncurses-5.2-new/form/Makefile.in 2005-08-23 04:22:08.000000000 +0200 +@@ -85,7 +85,7 @@ + LINK = $(LIBTOOL) $(CC) + LDFLAGS = @LDFLAGS@ @LD_MODEL@ @LIBS@ + +-SHLIB_DIRS = -L../lib -L$(libdir) ++SHLIB_DIRS = -L../lib + SHLIB_LIST = $(SHLIB_DIRS) -lncurses@LIB_SUFFIX@ @SHLIB_LIST@ + + MK_SHARED_LIB = @MK_SHARED_LIB@ +diff -ruN ncurses-5.2-old/menu/Makefile.in ncurses-5.2-new/menu/Makefile.in +--- ncurses-5.2-old/menu/Makefile.in 2000-10-14 19:57:02.000000000 +0200 ++++ ncurses-5.2-new/menu/Makefile.in 2005-08-23 04:22:18.000000000 +0200 +@@ -85,7 +85,7 @@ + LINK = $(LIBTOOL) $(CC) + LDFLAGS = @LDFLAGS@ @LD_MODEL@ @LIBS@ + +-SHLIB_DIRS = -L../lib -L$(libdir) ++SHLIB_DIRS = -L../lib + SHLIB_LIST = $(SHLIB_DIRS) -lncurses@LIB_SUFFIX@ @SHLIB_LIST@ + + MK_SHARED_LIB = @MK_SHARED_LIB@ +diff -ruN ncurses-5.2-old/ncurses/Makefile.in ncurses-5.2-new/ncurses/Makefile.in +--- ncurses-5.2-old/ncurses/Makefile.in 2000-10-15 00:55:35.000000000 +0200 ++++ ncurses-5.2-new/ncurses/Makefile.in 2005-08-23 04:21:53.000000000 +0200 +@@ -99,7 +99,7 @@ + LINK = $(LIBTOOL) $(CC) + LDFLAGS = @LDFLAGS@ @LD_MODEL@ @LIBS@ + +-SHLIB_DIRS = -L../lib -L$(libdir) ++SHLIB_DIRS = -L../lib + SHLIB_LIST = $(SHLIB_DIRS) @SHLIB_LIST@ + TINFO_LIST = $(SHLIB_DIRS) @TINFO_LIST@ + +diff -ruN ncurses-5.2-old/panel/Makefile.in ncurses-5.2-new/panel/Makefile.in +--- ncurses-5.2-old/panel/Makefile.in 2000-10-14 19:57:02.000000000 +0200 ++++ ncurses-5.2-new/panel/Makefile.in 2005-08-23 04:22:30.000000000 +0200 +@@ -86,7 +86,7 @@ + LINK = $(LIBTOOL) $(CC) + LDFLAGS = @LDFLAGS@ @LD_MODEL@ @LIBS@ + +-SHLIB_DIRS = -L../lib -L$(libdir) ++SHLIB_DIRS = -L../lib + SHLIB_LIST = $(SHLIB_DIRS) -lncurses@LIB_SUFFIX@ @SHLIB_LIST@ + + MK_SHARED_LIB = @MK_SHARED_LIB@