aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBaptiste Daroussin <bapt@FreeBSD.org>2013-05-06 15:31:45 +0000
committerBaptiste Daroussin <bapt@FreeBSD.org>2013-05-06 15:31:45 +0000
commit71bf80b1e5914a5a76fdb542f43b9159976779e0 (patch)
tree1cb2a85eefb4ee94dd410b90429972865fe74c46
parent6ecfed31c650a0e2a749a81b91b032e030842769 (diff)
downloadports-71bf80b1e5914a5a76fdb542f43b9159976779e0.tar.gz
ports-71bf80b1e5914a5a76fdb542f43b9159976779e0.zip
Notes
-rw-r--r--CHANGES16
-rw-r--r--Mk/Uses/ncurses.mk102
-rw-r--r--Mk/Uses/readline.mk25
3 files changed, 143 insertions, 0 deletions
diff --git a/CHANGES b/CHANGES
index eb2f601aa3a7..cdcfbc1b4472 100644
--- a/CHANGES
+++ b/CHANGES
@@ -10,6 +10,22 @@ in the release notes and/or placed into UPDATING.
All ports committers are allowed to commit to this file.
+20130506:
+AUTHOR: bapt@FreeBSD.org
+
+ * New USES macro to handle linking on ncurses and on readline
+
+ USES= ncurses will set env and make the port link to base version of ncurses
+ if no port version is installed otherwise it will link against port version
+ USES= ncurses:port will for the port to link against the ports version of
+ ncurses
+ USES= ncurses:base will force to link against base version of ncurses.
+
+ USES= readline will make the port link against base version of readline except
+ on 10+ where it will force dependency on the port version of readline
+ USES= readline:port will anyway force dependency on the port version of
+ readline.
+
20130426:
AUTHOR: mva@FreeBSD.org
diff --git a/Mk/Uses/ncurses.mk b/Mk/Uses/ncurses.mk
new file mode 100644
index 000000000000..b7d74542ba7d
--- /dev/null
+++ b/Mk/Uses/ncurses.mk
@@ -0,0 +1,102 @@
+# $FreeBSD$
+#
+# handle dependency on the ncurses port
+#
+# MAINTAINER: portmgr@FreeBSD.org
+#
+# Feature: ncurses
+# Usage: USES=ncurses
+# Valid ARGS: base port
+#
+# use/port can now set this options to the makefiles
+# NCURSES_RPATH= yes - pass RFLAGS options to CFLAGS
+#
+# Overridable defaults:
+# NCURSES_PORT= devel/ncurses
+#
+# The makefile sets this variables:
+# NCURSESBASE - "/usr" or ${LOCALBASE}
+# NCURSESLIB - path to the libs
+# NCURSESINC - path to the matching includes
+# NCURSESRPATH - rpath for dynamic linker
+#
+# BUILD_DEPENDS - are added if needed
+# RUN_DEPENDS - are added if needed
+
+.if !defined(_INCLUDE_USES_NCURSES_MK)
+_INCLUDE_USES_NCURSES_MK= yes
+
+.if !defined(ncurses_ARGS)
+. if !exists(${DESTDIR}/${LOCALBASE}/lib/libncurses.so) && exists(${DESTDIR}/usr/include/ncurses.h)
+ncurses_ARGS= base
+. endif
+ncurses_ARGS?= port
+.endif
+
+.if ${ncurses_ARGS} == base
+NCURSESBASE= /usr
+NCURSESINC= ${NCURSESBASE}/include
+
+. if exists(${LOCALBASE}/lib/libncurses.so)
+check-depends::
+ @${ECHO_CMD} "Dependency error: this port wants the ncurses library from the FreeBSD"
+ @${ECHO_CMD} "base system. You can't build against it, while a newer"
+ @${ECHO_CMD} "version is installed by a port."
+ @${ECHO_CMD} "Please deinstall the port or undefine WITH_NCURSES_BASE."
+ @${FALSE}
+. endif
+
+NCURSESPATH= /usr/lib:${LOCALBASE}/lib
+
+.elif ${ncurses_ARGS} == port
+NCURSESBASE= ${LOCALBASE}
+NCURSESINC= ${LOCALBASE}/include/ncurses
+
+. if !defined(NCURSES_PORT) && exists(${DESTDIR}/${LOCALBASE}/lib/libncurses.so)
+PKG_DBDIR?= ${DESTDIR}/var/db/pkg
+. if defined(WITH_PKGNG)
+. if defined(DESTDIR)
+PKGARGS= -c ${DESTDIR}
+. endif
+PKGARGS?=
+NCURSES_INSTALLED!= ${PKG_BIN} ${PKGARGS} which -qo ${LOCALBASE}/lib/libncurses.so || :
+. else
+NCURSES_INSTALLED!= find "${PKG_DBDIR}/" -type f -name "+CONTENTS" -print0 | \
+ xargs -0 grep -l "^lib/libncurses.so." | \
+ while read contents; do \
+ ncursesprefix=`grep "^@cwd " "$${contents}" | ${HEAD} -n 1`; \
+ if test "$${ncursesprefix}" = "@cwd ${LOCALBASE}" ; then \
+ echo "$${contents}"; break; fi; done; ${ECHO_CMD}
+. endif
+. endif
+.else
+.error USES=ncurses only accept 'port' and 'base' as arguments, got ${ncurses_ARGS}
+.endif
+NCURSES_INSTALLED?=
+
+.if ${NCURSES_INSTALLED} != ""
+. if defined(WITH_PKGNG)
+NCURSES_PORT= ${NCURSES_INSTALLED}
+NCURSES_SHLIBFILE!= ${PKG_INFO} -ql ${NCURSES_INSTALLED} | grep -m 1 "^`pkg query "%p" ${NCURSES_INSTALLED}`/lib/libncurses.so."
+. else
+NCURSES_PORT!= grep "^@comment ORIGIN:" "${NCURSES_INSTALLED}" | ${CUT} -d : -f 2
+NCURSES_SHLIBFILE!= grep -m 1 "^lib/libncurses.so." "${NCURSES_INSTALLED}"
+. endif
+NCURSES_SHLIBVER?= ${NCURSES_SHLIBFILE:E}
+.endif
+
+NCURSES_PORT?= devel/ncurses
+NCURSES_SHLIBVER?= 5
+
+BUILD_DEPENDS+= ${LOCALBASE}/lib/libncurses.so.${NCURSES_SHLIBVER}:${PORTSDIR}/${NCURSES_PORT}
+RUN_DEPENDS+= ${LOCALBASE}/lib/libncurses.so.${NCURSES_SHLIBVER}:${PORTSDIR}/${NCURSES_PORT}
+NCURSESRPATH= ${LOCALBASE}/lib
+
+NCURSESLIB= ${NCURSESBASE}/lib
+
+.if defined(NCURSES_RPATH)
+CFLAGS+= -Wl,-rpath,${NCURSESRPATH}
+.endif
+LDFLAGS+= -Wl,-rpath=${NCURSESPATH}
+
+.endif
diff --git a/Mk/Uses/readline.mk b/Mk/Uses/readline.mk
new file mode 100644
index 000000000000..b3c5c4a95914
--- /dev/null
+++ b/Mk/Uses/readline.mk
@@ -0,0 +1,25 @@
+# $FreeBSD$
+#
+# handle dependency on the readline port
+#
+# MAINTAINER: portmgr@FreeBSD.org
+#
+# Feature: readline
+# Usage: USES=readline
+# Valid ARGS: port
+#
+
+.if !defined(_INCLUDE_USES_READLINE_MK)
+_INCLUDE_USES_READLINE_MK= yes
+
+.if ${OSVERSION} > 1000000
+readline_ARGS= port
+.endif
+
+.if defined(readline_ARGS) && ${readline_ARGS} == port
+LIB_DEPENDS+= readline.6:${PORTSDIR}/devel/readline
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib -lreadline
+.endif
+
+.endif