summaryrefslogtreecommitdiff
path: root/devel
diff options
context:
space:
mode:
authorjlam <jlam@pkgsrc.org>2001-05-16 04:39:12 +0000
committerjlam <jlam@pkgsrc.org>2001-05-16 04:39:12 +0000
commit39e4577f8ce74427004766e11b83cd6a693e095e (patch)
tree3428d86033761007b66d500ac447726f60ff9504 /devel
parent0342227f5fa242e325db2cec5ea636da7cd97594 (diff)
downloadpkgsrc-39e4577f8ce74427004766e11b83cd6a693e095e.tar.gz
Add a Makefile.readline (copied from databases/postgresql) that is intended
to be usable by packages that use readline() functionality: # If readline() is not present in the base system through libedit, then a # dependency on devel/readline is added, the appropriate headers are linked # into ${WRKINCDIR} (${WRKSRC}/include), and the appropriate libraries are # linked into ${WRKLIBDIR} (${WRKSRC}/lib).
Diffstat (limited to 'devel')
-rw-r--r--devel/readline/Makefile.readline74
1 files changed, 74 insertions, 0 deletions
diff --git a/devel/readline/Makefile.readline b/devel/readline/Makefile.readline
new file mode 100644
index 00000000000..c380472647d
--- /dev/null
+++ b/devel/readline/Makefile.readline
@@ -0,0 +1,74 @@
+# $NetBSD: Makefile.readline,v 1.1 2001/05/16 04:39:12 jlam Exp $
+#
+# This Makefile fragment is included by packages that use readline().
+#
+# If readline() is not present in the base system through libedit, then a
+# dependency on devel/readline is added, the appropriate headers are linked
+# into ${WRKINCDIR} (${WRKSRC}/include), and the appropriate libraries are
+# linked into ${WRKLIBDIR} (${WRKSRC}/lib).
+#
+# To use this Makefile fragment, simply:
+#
+# (1) Include this Makefile fragment in the package Makefile,
+# (2) Optionally define WRKINCDIR and WRKLIBDIR,
+# (3) Add link-readline-headers and link-readline-libs to the prerequisite
+# targets for pre-configure,
+# (4) Add ${WRKINCDIR} to the front of the C preprocessor's header search
+# path, and
+# (5) Add ${WRKLIBDIR} to the front of the linker's library search path.
+#
+# NOTE: You may need to do some more work to get libedit recognized over
+# libreadline, especially by GNU configure scripts.
+
+.if exists(/usr/include/readline.h)
+READLINE_H= /usr/include/readline.h
+HISTORY_H= /usr/include/history.h
+LIBREADLINE= /usr/lib/libedit.a
+LIBREADLINE+= /usr/lib/libedit.so*
+LIBHISTORY= /usr/lib/libedit.a
+LIBHISTORY+= /usr/lib/libedit.so*
+HAVE_LIBEDIT_READLINE= # defined
+.elif exists(/usr/include/readline/readline.h)
+READLINE_H= /usr/include/readline/readline.h
+HISTORY_H= /usr/include/readline/history.h
+LIBREADLINE= /usr/lib/libedit.a
+LIBREADLINE+= /usr/lib/libedit.so*
+LIBHISTORY= /usr/lib/libedit.a
+LIBHISTORY+= /usr/lib/libedit.so*
+HAVE_LIBEDIT_READLINE= # defined
+.else
+READLINE_H= ${LOCALBASE}/readline/readline.h
+HISTORY_H= ${LOCALBASE}/readline/history.h
+LIBREADLINE= ${LOCALBASE}/lib/libreadline.a
+LIBREADLINE+= ${LOCALBASE}/lib/libreadline.so*
+LIBHISTORY= ${LOCALBASE}/lib/libhistory.a
+LIBHISTORY+= ${LOCALBASE}/lib/libhistory.so*
+DEPENDS+= readline>=2.2:../../devel/readline
+.endif
+
+WRKINCDIR?= ${WRKDIR}/include
+WRKLIBDIR?= ${WRKDIR}/lib
+
+# This target links the readline and history headers into ${WRKINCDIR},
+# which should be searched first by the C preprocessor.
+#
+link-readline-headers:
+ ${MKDIR} -p ${WRKINCDIR}/readline
+ ${RM} -f ${WRKINCDIR}/readline/readline.h
+ ${RM} -f ${WRKINCDIR}/readline/history.h
+ ${LN} -sf ${READLINE_H} ${WRKINCDIR}/readline
+ ${LN} -sf ${HISTORY_H} ${WRKINCDIR}/readline
+
+# This target links the readline and history libraries into ${WRKLIBDIR},
+# which should be searched first by the linker.
+#
+link-readline-libs:
+ ${MKDIR} -p ${WRKLIBDIR}
+ for lib in ${LIBREADLINE}; do \
+ dest=`${BASENAME} $${lib} | ${SED} "s|libedit|libreadline|"`; \
+ ${LN} -sf $${lib} ${WRKLIBDIR}/$${dest}; \
+ done
+ for lib in ${LIBHISTORY}; do \
+ dest=`${BASENAME} $${lib} | ${SED} "s|libedit|libhistory|"`; \
+ ${LN} -sf $${lib} ${WRKLIBDIR}/$${dest}; \
+ done