diff options
author | linimon <linimon@FreeBSD.org> | 2006-09-15 14:57:07 +0800 |
---|---|---|
committer | linimon <linimon@FreeBSD.org> | 2006-09-15 14:57:07 +0800 |
commit | 4d6c64033b7a35790d8d87c9b0717d01531b441e (patch) | |
tree | 5b036d092abf3da84f6ca6dd7f6c00ed6063cbef /Mk | |
parent | 7a02d5f1a3ba25d29cd92b3d868d14c08fdabd15 (diff) | |
download | freebsd-ports-gnome-4d6c64033b7a35790d8d87c9b0717d01531b441e.tar.gz freebsd-ports-gnome-4d6c64033b7a35790d8d87c9b0717d01531b441e.tar.zst freebsd-ports-gnome-4d6c64033b7a35790d8d87c9b0717d01531b441e.zip |
* Add PKGVERSION to bsd.port.mk [1]
* Add bsd.lua.mk to support for lua-based ports [2]
* Remove DESTDIR from bsd.scons.mk [3]
* Add some quotes in 'missing' target to improve handling of duplicate
origins [4]
PR: 98565 [1], 101612 [2], 101952 [3], 102100 [4]
Submitted by: ahze [1], alepulver [2], alexbl [3], shaun [4]
Diffstat (limited to 'Mk')
-rw-r--r-- | Mk/bsd.lua.mk | 420 | ||||
-rw-r--r-- | Mk/bsd.port.mk | 24 |
2 files changed, 442 insertions, 2 deletions
diff --git a/Mk/bsd.lua.mk b/Mk/bsd.lua.mk new file mode 100644 index 000000000000..84697199df01 --- /dev/null +++ b/Mk/bsd.lua.mk @@ -0,0 +1,420 @@ +#-*- mode: makefile; tab-width: 4; -*- +# ex:ts=4 +# +# $FreeBSD$ +# +# bsd.lua.mk - Support for Lua based ports. +# +# Created by: Alejandro Pulver <alepulver@FreeBSD.org> +# +# Please view me with 4 column tabs! +# +# The following variables can be defined in a port that uses the Lua library, +# tolua, Ruby bindings or related components like .lua modules (with run +# and/or build dependencies). It can be used after and/or before +# bsd.port.pre.mk, but Ruby components will only work if Ruby variables (e.g. +# USE_RUBY) are defined before it (this is a bsd.ruby.mk limitation), at least +# it is manually included. +# USE_LUA - Set to the list of Lua versions that can be used by the +# port. The syntax allows the following elements: +# - Single version (e.g. "4.0"). +# - Range of versions (e.g. "5.0-5.1"). Must be ascending. +# - Partial range: single version and upper (e.g. "5.0+"). +# - Partial range: single version and lower (e.g. "5.1-"). +# Multiple elements can be specified separated by spaces. +# USE_LUA_NOT - Set to the list of Lua versions that can't be used by the +# port. In other words, it removes some versions from USE_LUA. +# If the latter is not defined, it will have the value of all +# the possible versions. The syntax is like USE_LUA. +# LUA_COMPS - Set to the list of Lua components the port uses. Several +# components can be specified separated by spaces. By default +# it will have the value of "lua". Suffixes in the form ":xxx" +# may be added to the components to determine the dependency +# type. +# The available components are: +# lua - The Lua library. +# tolua - The tolua library (vers 4.0-5.0). +# ruby - The Ruby bindings for Lua (vers 4.0-5.0). +# app, compat51, dfui, filename, gettext, posix, pty and +# socket - Modules for Lua 5.0. +# The available dependency types are: +# build - Requires component for building. +# lib - Requires component for building and running. +# run - Requires component for running. +# If no suffix is present then "lib" will be used for "lua" +# 4.0-5.0 and "ruby", "build" for lua 5.1 and "tolua" (they +# are static), all others default to "run". +# LUA_PREMK - Define to determine version and define variables after +# <bsd.port.pre.mk> (in case the port needs to manually run +# the Lua program or the like). +# WANT_LUA - Set to "yes" or a valid single version (no ranges, etc). +# In both cases it will detect the installed Lua components +# and add them to the variable HAVE_LUA. If a version is +# selected, HAVE_LUA will contain a list of components in the +# other case it will contain a list of "component-version" +# pairs (e.g. lua-4.0, tolua-5.1, etc). +# It has to be used before bsd.port.pre.mk. +# WANT_LUA_VER - Set to the prefered Lua version for the port. It must be +# present in USE_LUA or missing in USE_LUA_NOT. This is +# overriden by the user variable WITH_LUA_VER if set. It can +# contain multiple versions in order of preference (last ones +# are tried first). +# +# The following variables are intended for the user and can be defined in +# make.conf. +# WITH_LUA_VER - Define to the list of prefered versions in reverse order. +# +# The following variables are defined by this file, to be read from the port. +# HAVE_LUA - The list of Lua components installed, if WANT_LUA was +# defined. The components will have version suffix if it was +# set to "yes". +# LUA_VER - The Lua version that is going to be used (e.g. "5.1"). +# LUA_VER_SH - The Lua shared library major version (e.g. "1"). +# LUA_VER_STR - The Lua version without the dots (e.g. "51"). +# LUA_PREFIX - The prefix where Lua (and components) is installed. +# LUA_SUBDIR - The directory under bin/share/lib where Lua is installed. +# LUA_INCDIR - The directory where Lua and tolua header files are installed. +# LUA_LIBDIR - The directory where Lua and tolua libraries are installed. +# LUA_MODLIBDIR - The directory where Lua modules (.lua) are installed. +# LUA_MODSHAREDIR - The directory where Lua module libraries (.so) are +# installed. +# LUA_PKGNAMEPREFIX - The package name prefix used by Lua modules. +# +# Examples: +# - A port that needs Lua 4.0 and tolua (also 4.0) libraries (lua for building +# and running and tolua for building). +# USE_LUA= 4.0 +# LUA_COMPS= lua tolua +# - A port that needs Ruby bindings for Lua 5.0 for building and running. +# USE_LUA= 5.0 +# LUA_COMPS= ruby +# - A port that needs tolua 5.0 or 5.1 for building. +# USE_LUA= 5.0 5.1 +# LUA_COMPS= tolua +# - A port that needs Lua version 5.0 or higher for building and running. +# USE_LUA= 5.0+ +# - A port that needs Lua of any version other than 5.1 for building and +# running. +# USE_LUA_NOT=5.1 +# + +LUA_Include_MAINTAINER= alepulver@FreeBSD.org + +# +# Global definitions. +# + +.if !defined(_LUA_Definitions_Done) +_LUA_Definitions_Done= yes + +# Common variables: +# _LUA_COMPS_ALL - List of valid components. +# _LUA_DEP_TYPES_ALL - List of valid dependency types. +# _LUA_VERS_ALL - List of available Lua versions. +# _LUA_VERS_LISTS= - Reverse lists preference order. +# _LUA_PLIST_ALL - List of variables to be added to PLIST_SUB. +# _LUA_PLIST_DIR_ALL - List of path variables (relative to ${LUA_PREFIX}) +# to be added to PLIST_SUB. +# + +_LUA_COMPS_ALL= lua tolua ruby \ + app compat51 dfui filename gettext posix pty socket +_LUA_DEP_TYPES_ALL= build lib run +_LUA_VERS_ALL= 4.0 5.0 5.1 +_LUA_PLIST_ALL= LUA_VER LUA_VER_SH LUA_VER_STR LUA_PREFIX LUA_SUBDIR +_LUA_PLIST_DIR_ALL= LUA_BINDIR LUA_INCDIR LUA_LIBDIR \ + LUA_MODLIBDIR LUA_MODSHAREDIR +_LUA_VERS_LISTS= WANT_LUA_VER WITH_LUA_VER + +# +# Variables used to determine what is needed. +# _LUA_PORT_comp_ver - Port directory. +# _LUA_LIB_comp_ver - Name of the shared library (optional). +# _LUA_SHVER_comp_ver - Shared library version (optional). +# _LUA_FILE_comp_ver - File installed by that component. +# _LUA_DEPTYPE_comp_ver - Default dependency type. +# + +_LUA_PORT_lua_4.0= lang/lua4 +_LUA_DEPTYPE_lua_4.0= lib +_LUA_PORT_tolua_4.0= lang/tolua4 +_LUA_PORT_ruby_4.0= lang/ruby-lua4 + +_LUA_PORT_lua_5.0= lang/lua50 +_LUA_DEPTYPE_lua_5.0= lib +_LUA_PORT_tolua_5.0= lang/tolua +_LUA_PORT_ruby_5.0= lang/ruby-lua + +_LUA_PORT_app_5.0= devel/lua50-app +_LUA_PORT_compat51_5.0= devel/lua50-compat51 +_LUA_FILE_compat51_5.0= ${LUA_MODSHAREDIR}/compat-5.1.lua +_LUA_PORT_dfui_5.0= devel/lua50-dfui +_LUA_PORT_filename_5.0= devel/lua50-filename +_LUA_PORT_gettext_5.0= devel/lua50-gettext +_LUA_PORT_posix_5.0= devel/lua50-posix +_LUA_PORT_pty_5.0= devel/lua50-pty +_LUA_PORT_socket_5.0= net/luasocket + +_LUA_PORT_lua_5.1= lang/lua +_LUA_DEPTYPE_lua_5.1= build + +.for comp in ${_LUA_COMPS_ALL} +_LUA_COMP= ${comp} +. for ver in ${_LUA_VERS_ALL} +. if ${_LUA_COMP} == "lua" +_LUA_LIB_${comp}_${ver}= lua-${LUA_VER}.${LUA_VER_SH} +_LUA_SHVER_${comp}_${ver}= ${LUA_VER_SH} +_LUA_FILE_${comp}_${ver}= ${LUA_LIBDIR}/liblua.a +. elif ${_LUA_COMP} == "tolua" +_LUA_FILE_${comp}_${ver}= ${LUA_LIBDIR}/libtolua.a +_LUA_DEPTYPE_${comp}_${ver}=build +. elif ${_LUA_COMP} == "ruby" +_LUA_FILE_${comp}_${ver}= ${RUBY_SITEARCHLIBDIR}/lua-${LUA_VER}.so +_LUA_DEPTYPE_${comp}_${ver}=lib +. else +. if !defined(_LUA_FILE_${comp}_${ver}) +_LUA_FILE_${comp}_${ver}= ${LUA_MODSHAREDIR}/${comp}.lua +. endif +_LUA_DEPTYPE_${comp}_${ver}=run +. endif +. endfor +.endfor + +.endif + +# +# Check for present components. +# + +.if defined(WANT_LUA) && defined(BEFOREPORTMK) +. for __WANT_LUA in ${WANT_LUA} +# Check if WANT_LUA contains more than one word. +. if defined(HAVE_LUA) +IGNORE?= selected multiple values for WANT_LUA: ${WANT_LUA} +. endif +HAVE_LUA= # +# Check for all versions. +. if ${WANT_LUA:L} == "yes" +. for comp in ${_LUA_COMPS_ALL} +. for ver in ${_LUA_VERS_ALL} +_LUA_COMP= _LUA_FILE_${comp}_${ver} +. if defined(${_LUA_COMP}) && exists(${${_LUA_COMP}}) +HAVE_LUA+= ${comp}-${ver} +. endif +. endfor +. endfor +# Check for a specific version. +. elif ${_LUA_VERS_ALL:M${__WANT_LUA}} != "" +. for comp in ${_LUA_COMPS_ALL} +. if exists(${_LUA_FILE_${comp}_${__WANT_LUA}}) +HAVE_LUA+= ${comp} +. endif +. endfor +. else +IGNORE?= selected an invalid value for WANT_LUA: ${__WANT_LUA} +. endif +. endfor +.endif # WANT_LUA && BEFOREPORTMK + +# +# Select Lua version. +# + +.if !defined(_LUA_Version_Done) && (defined(_POSTMKINCLUDED) || \ + (defined(LUA_PREMK) && defined(BEFOREPORTMK) && \ + (defined(USE_LUA) || defined(USE_LUA_NOT)))) +_LUA_Version_Done= yes + +# Set defaults (if one isn't present). + +USE_LUA?= ${_LUA_VERS_ALL} +USE_LUA_NOT?= # + +# +# Make lists of valid and invalid versions. +# +# The following variables are used: +# _LUA_VER_CHECK - If the version is a single one, express in a range. +# _LUA_VER_MIN - Lower version of the range. +# _LUA_VER_MAX - Higher version of the range. +# _LUA_VER_LIST - List of requested versions. +# _LUA_VER_NOT_LIST - List of disallowed versions. +# _LUA_VER_FINAL - List of requested version without disallowed ones. +# + +.for list in VER VER_NOT +_LUA_${list}_LIST= # +. for ver in ${USE_LUA${list:C/VER//}} +_LUA_VER_CHECK:= ${ver:C/^([[:digit:]]+(\.[[:digit:]]+)*)$/\1-\1/} +_LUA_VER_MIN:= ${_LUA_VER_CHECK:C/([[:digit:]]+(\.[[:digit:]]+)*)[-+].*/\1/} +_LUA_VER_MAX:= ${_LUA_VER_CHECK:C/.*-([[:digit:]]+(\.[[:digit:]]+)*)/\1/} +# Minimum version not specified. +. if ${_LUA_VER_MIN} == ${_LUA_VER_CHECK} +. undef _LUA_VER_MIN +. for v in ${_LUA_VERS_ALL} +_LUA_VER_MIN?= ${v} +. endfor +. endif +# Maximum version not specified. +. if ${_LUA_VER_MAX} == ${_LUA_VER_CHECK} +. for v in ${_LUA_VERS_ALL} +_LUA_VER_MAX= ${v} +. endfor +. endif +# Expand versions and add valid ones to each list. +. for v in ${_LUA_VERS_ALL} +. if ${_LUA_VER_MIN} <= ${v} && ${_LUA_VER_MAX} >= ${v} && \ + ${_LUA_${list}_LIST:M${v}} == "" +_LUA_${list}_LIST+= ${v} +. endif +. endfor +. endfor +.endfor + +# Merge the lists into a single list of valid versions. + +_LUA_VER_FINAL= # +.for ver in ${_LUA_VER_LIST} +. if ${_LUA_VER_NOT_LIST:M${ver}} == "" +_LUA_VER_FINAL+= ${ver} +. endif +.endfor + +# Check for a null version. + +.if empty(_LUA_VER_FINAL) +IGNORE?= selected a null or invalid Lua version +.endif + +# +# Choose final version. +# + +# +# Check for the following (in order): +# 1) WITH_LUA_VER - User preference. +# 2) WANT_LUA_VER - Port preference. +# 3) _LUA_VER_FINAL - Available versions. +# + +.for list in _LUA_VER_FINAL ${_LUA_LISTS_ORDER} +. if defined(${list}) +. for ver in ${${list}} +. if ${_LUA_VER_FINAL:M${ver}} != "" +_LUA_VER= ${ver} +. endif +. endfor +. endif +.endfor + +# +# Set variables. +# + +# Version. +LUA_VER= ${_LUA_VER} +LUA_VER_SH?= ${LUA_VER:C/[[:digit:]]\.([[:digit:]])/\1/} +LUA_VER_STR?= ${LUA_VER:S/.//g} + +# Paths. +LUA_PREFIX?= ${LOCALBASE} +LUA_SUBDIR?= lua${LUA_VER_STR} +LUA_BINDIR?= ${LUA_PREFIX}/bin/${LUA_SUBDIR} +LUA_INCDIR?= ${LUA_PREFIX}/include/${LUA_SUBDIR} +LUA_LIBDIR?= ${LUA_PREFIX}/lib/${LUA_SUBDIR} +LUA_MODLIBDIR?= ${LUA_PREFIX}/lib/lua/${LUA_VER} +LUA_MODSHAREDIR?= ${LUA_PREFIX}/share/lua/${LUA_VER} + +# Package name. +LUA_PKGNAMEPREFIX?= lua${LUA_VER_STR}- + +.endif # !_LUA_Version_Done && (_POSTMKINCLUDED || \ +# (LUA_PREMK && BEFOREPORTMK && (USE_LUA || USE_LUA_NOT))) + +# +# Process components list and add dependencies, variables, etc. +# + +.if defined(_POSTMKINCLUDED) + +# +# Component parsing. +# +# The variables used are: +# _LUA_COMP - Component part. +# _LUA_DEP_TYPE - Dependency type part. +# _LUA_COMP_NEW - Component + dependency type. +# _LUA_COMPS_FINAL - Final list of components with dependency types. +# + +# Default components. + +LUA_COMPS?= lua + +# Detect invalid and duplicated components. + +_LUA_COMPS_FINAL= # +.for comp in ${LUA_COMPS} +_LUA_COMP= ${comp:C/:([[:alpha:]]+)$//} +. if ${_LUA_COMP} == ${comp} +_LUA_DEP_TYPE= ${_LUA_DEPTYPE_${comp}_${_LUA_VER}} +. else +_LUA_DEP_TYPE= ${comp:C/.+:([[:alpha:]]+)$/\1/} +. endif +_LUA_COMP_NEW= ${_LUA_COMP}_${_LUA_DEP_TYPE} +. for __LUA_COMP in ${_LUA_COMP} +. if ${_LUA_COMPS_ALL:M${__LUA_COMP}} == "" +IGNORE?= selected an invalid Lua component: ${__LUA_COMP} +. endif +. endfor +. for __LUA_DEP_TYPE in ${_LUA_DEP_TYPE} +. if ${_LUA_DEP_TYPES_ALL:M${__LUA_DEP_TYPE}} == "" +IGNORE?= selected an invalid Lua dependency type: ${__LUA_DEP_TYPE} +. endif +. endfor +. if !defined(_LUA_PORT_${_LUA_COMP}_${_LUA_VER}) +IGNORE?= selected a Lua component (${_LUA_COMP}) which is not available for the selected version (${_LUA_VER}) +. endif +. for newcomp in ${_LUA_COMP_NEW} +. if ${_LUA_COMPS_FINAL:M${newcomp}} == "" +_LUA_COMPS_FINAL+= ${newcomp} +. endif +. endfor +.endfor + +# Add dependencies. +# +# The variable used are: +# _LUA_COMP - - Component part. +# _LUA_DEP_TYPE - Dependency type part. + +.for comp in ${_LUA_COMPS_FINAL} +_LUA_DEP_TYPE= ${comp:C/.+_([[:alpha:]]+)$/\1/} +_LUA_COMP= ${comp:C/_([[:alpha:]]+)$//} +# XXX Need a .for loop here so the variable is expanded before the assignment. +. for comp_part in ${_LUA_COMP} +. if ${_LUA_DEP_TYPE} == "lib" +. if defined(_LUA_LIB_${comp_part}_${_LUA_VER}) +LIB_DEPENDS+= ${_LUA_LIB_${comp_part}_${_LUA_VER}}:${PORTSDIR}/${_LUA_PORT_${comp_part}_${_LUA_VER}} +. else +BUILD_DEPENDS+= ${_LUA_FILE_${comp_part}_${_LUA_VER}}:${PORTSDIR}/${_LUA_PORT_${comp_part}_${_LUA_VER}} +RUN_DEPENDS+= ${_LUA_FILE_${comp_part}_${_LUA_VER}}:${PORTSDIR}/${_LUA_PORT_${comp_part}_${_LUA_VER}} +. endif +. else +${_LUA_DEP_TYPE:U}_DEPENDS+= ${_LUA_FILE_${comp_part}_${_LUA_VER}}:${PORTSDIR}/${_LUA_PORT_${comp_part}_${_LUA_VER}} +. endif +. endfor +.endfor + +# Packaging list variables. +.for var in ${_LUA_PLIST_ALL} +PLIST_SUB+= ${var}="${${var}}" +.endfor +.for var in ${_LUA_PLIST_DIR_ALL} +PLIST_SUB+= ${var}="${${var}:S/${LUA_PREFIX}\///}" +.endfor +.for var in ${_LUA_PLIST_ALL} ${_LUA_PLIST_DIR_ALL} +MAKE_ENV+= ${var}="${${var}}" +.endfor + +.endif # _POSTMKINCLUDED diff --git a/Mk/bsd.port.mk b/Mk/bsd.port.mk index f0cf7abf40d4..126bf44469de 100644 --- a/Mk/bsd.port.mk +++ b/Mk/bsd.port.mk @@ -72,6 +72,9 @@ FreeBSD_MAINTAINER= portmgr@FreeBSD.org # PKGNAMEPREFIX - Prefix to specify that port is language-specific, etc. # Optional. # PKGNAMESUFFIX - Suffix to specify compilation options. Optional. +# PKGVERSION - Always defined as +# ${PORTVERSION}. +# Do not define this in your Makefile. # UNIQUENAME - A name for your port that is globally unique. By default, # this is set to ${LATEST_LINK} when LATEST_LINK is set, # and to ${PKGNAMEPREFIX}${PORTNAME} otherwise. @@ -426,6 +429,12 @@ FreeBSD_MAINTAINER= portmgr@FreeBSD.org # or http://www.FreeBSD.org/gnome/docs/porting.html # for more details. ## +# USE_LUA - If set, this port uses the Lua library and related +# components. See bsd.lua.mk for more details. +## +# USE_WX - If set, this port uses the WxWidgets library and related +# components. See bsd.wx.mk for more details. +## # USE_KDEBASE_VER # - Set to 3 to use the KDE windowing system. # Implies inclusion of bsd.kde.mk. @@ -1295,8 +1304,11 @@ _SUF2= ,${PORTEPOCH} # check for old, crufty, makefile types, part 2. The "else" case # should have been handled in part 1, above. +.if !defined(PKGVERSION) +PKGVERSION= ${PORTVERSION:C/[-_,]/./g}${_SUF1}${_SUF2} +.endif .if !defined(PKGNAME) -PKGNAME= ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}-${PORTVERSION:C/[-_,]/./g}${_SUF1}${_SUF2} +PKGNAME= ${PKGNAMEPREFIX}${PORTNAME}${PKGNAMESUFFIX}-${PKGVERSION} .endif DISTNAME?= ${PORTNAME}-${DISTVERSIONPREFIX}${DISTVERSION:C/:(.)/\1/g}${DISTVERSIONSUFFIX} @@ -1495,6 +1507,10 @@ PERL= ${LOCALBASE}/bin/perl .include "${PORTSDIR}/Mk/bsd.gnome.mk" .endif +.if defined(WANT_LUA) || defined(USE_LUA) || defined(USE_LUA_NOT) +.include "${PORTSDIR}/Mk/bsd.lua.mk" +.endif + .if defined(WANT_WX) || defined(USE_WX) || defined(USE_WX_NOT) .include "${PORTSDIR}/Mk/bsd.wx.mk" .endif @@ -1997,6 +2013,10 @@ RUN_DEPENDS+= ${PERL5}:${PORTSDIR}/lang/${PERL_PORT} .include "${PORTSDIR}/Mk/bsd.tcl.mk" .endif +.if defined(USE_LUA) || defined(USE_LUA_NOT) +.include "${PORTSDIR}/Mk/bsd.lua.mk" +.endif + .if defined(USE_WX) || defined(USE_WX_NOT) .include "${PORTSDIR}/Mk/bsd.wx.mk" .endif @@ -5190,7 +5210,7 @@ missing: @for dir in $$(${ALL-DEPENDS-LIST}); do \ THISORIGIN=$$(${ECHO_CMD} $$dir | ${SED} 's,${PORTSDIR}/,,'); \ installed=$$(${PKG_INFO} -qO $${THISORIGIN}); \ - if [ -z $$installed ]; then \ + if [ -z "$$installed" ]; then \ ${ECHO_CMD} $$THISORIGIN; \ fi \ done |