# $NetBSD: find-prefix.mk,v 1.7 2008/02/10 10:30:58 rillig Exp $
#
# This is a "subroutine" that can be included to find the installation
# prefix of an installed package.
#
# Parameters:
#
# FIND_PREFIX
#	A list of <VARNAME>=<pattern> pairs, where
#
#	* <pattern> is a package wildcard pattern (see pkg_info(8)),
#	* <VARNAME> is the variable that will be set to the
#	  installation prefix for the package.
#
# Returns:
#
# <VARNAME>
#	The prefix of the corresponding package, or ${LOCALBASE}
#	if the package is not installed.
#
# Example:
#
# FIND_PREFIX:=	M4DIR=gm4
# .include "../../mk/find-prefix.mk"
# # ${M4DIR} now contains the installation prefix for the "gm4" package.
#

.for i in ${FIND_PREFIX}
.  for varname in ${i:C/=.*$//}
.    for pattern in ${i:C/^[^=]*=//}
.      if !defined(${varname})

# XXX: Is this *_DEFAULT variable really necessary? The default value
# can be easily embedded in the shell code. What if VARNAME is set to
# PKG_APACHE, for example?
#
${varname}_DEFAULT?=	${LOCALBASE}
_${varname}_cmd=		\
	${PKG_INFO} -qp ${pattern:Q} 2>/dev/null |			\
	{ read cmd arg;							\
	  case "$$arg" in						\
	  "")	${ECHO} ${${varname}_DEFAULT:Q} ;;			\
	  *)	${ECHO} "$$arg" ;;					\
	  esac; }
${varname}=		${_${varname}_cmd:sh}
.      endif
MAKEVARS+=	${varname}
.    endfor
.  endfor
.endfor