* Add support for Ruby 1.9.x and update 1.8.7.302 (1.8.7 patchlevel 302).

Ruby's patchlevel N reflect as "plN" instead of ".N" from Ruby 1.9.

	ruby18-base-1.8.7.302
	ruby19-base-1.9.2pl0

  Still Ruby 1.9.2pl0 support is disabled.

* Introduce RUBY_API_VERSION.

* RUBY_BUILD_RDOC and RUBY_BUILD_RI controls build of rdoc/ri.  But,
  currently ruby18-base and ruby19-base according to PKG_OPTION.

* Define rubygem supporting macros.

* RUBY_HAS_ARCHLIB is deprecated.

* Many directory macros are changed to relative path against PREFIX and
  some of them are their name.
This commit is contained in:
taca 2010-09-10 03:19:54 +00:00
parent 34bd1cfe85
commit e041e244c5

View file

@ -1,4 +1,4 @@
# $NetBSD: rubyversion.mk,v 1.48 2009/06/16 15:08:38 taca Exp $
# $NetBSD: rubyversion.mk,v 1.49 2010/09/10 03:19:54 taca Exp $
#
.if !defined(_RUBYVERSION_MK)
@ -8,9 +8,15 @@ _RUBYVERSION_MK= # defined
# current supported Ruby's version
RUBY18_VERSION= 1.8.7
RUBY19_VERSION= 1.9.2
# patch
RUBY18_PATCHLEVEL= 174
RUBY18_PATCHLEVEL= pl302
RUBY19_PATCHLEVEL= pl0
# current API compatible version.
RUBY18_API_VERSION= 1.8.7
RUBY19_API_VERSION= 1.9.1
# RUBY_VERSION_DEFAULT defines default version for Ruby related
# packages and user can define in mk.conf. (1.6 or 1.8)
@ -25,25 +31,29 @@ RUBY_VERSION_DEFAULT?= 1.8
#
.if ${RUBY_VERSION_DEFAULT} == "1.8"
RUBY_VERSION?= ${RUBY18_VERSION}
RUBY_PATCH_LEVEL?= ${RUBY18_PATCHLEVEL}
RUBY_API_VERSION?= ${RUBY18_API_VERSION}
.elif ${RUBY_VERSION_DEFAULT} == "1.9"
RUBY_VERSION?= ${RUBY19_VERSION}
RUBY_API_VERSION?= ${RUBY19_API_VERSION}
.endif
.if !empty(RUBY_PATCH_LEVEL)
RUBY_VERSION_SUFFIX= ${RUBY_VERSION}.${RUBY_PATCH_LEVEL}
.else
RUBY_VERSION_SUFFIX= ${RUBY_VERSION}
RUBY_PATCH_LEVEL= ${RUBY${RUBY_VER}_PATCHLEVEL}
.if ${RUBY_VERSION} == ${RUBY18_VERSION}
RUBY_VERSION_SUFFIX= ${RUBY_VERSION}${RUBY_PATCH_LEVEL:S/pl/./}
.elif ${RUBY_VERSION} == ${RUBY19_VERSION}
RUBY_VERSION_SUFFIX= ${RUBY_VERSION}${RUBY_PATCH_LEVEL}
.endif
# RUBY_VERSION_SUPPORTED defines the list of ${RUBY_VER} which is
# supported by the package. It should be defined by the packages
# for specific Ruby versions.
#
RUBY_VERSION_SUPPORTED?= 18
RUBY_VERSION_SUPPORTED?= 18 # 19
# RUBY_VERSION_LIST defines the list of ${RUBY_VER} which is known to
# this framework.
#
RUBY_VERSION_LIST= 18
RUBY_VERSION_LIST= 18 # 19
# RUBY_NOVERSION should be set to "Yes" if the package dosen't depend on
# any specific version of ruby command. In this case, package's
@ -63,27 +73,22 @@ _RUBY_VER= ${RUBY_VERSION:C/(-.*)//}
_RUBY_VER_MAJOR= ${_RUBY_VER:C/([0-9]+)\.([0-9]+)\.([0-9]+)/\1/}
_RUBY_VER_MINOR= ${_RUBY_VER:C/([0-9]+)\.([0-9]+)\.([0-9]+)/\2/}
_RUBY_VER_TEENY= ${_RUBY_VER:C/([0-9]+)\.([0-9]+)\.([0-9]+)/\3/}
.if !empty(RUBY_PATCH_LEVEL)
_RUBY_PATCHLEVEL= ${RUBY_VERSION:C/(.*-)//}
.endif
# RUBY_VER defines Ruby base release.
#
RUBY_VER= ${_RUBY_VER_MAJOR}${_RUBY_VER_MINOR}
# RUBY_API_TEENY is used by shared library version after Ruby 1.9.1
#
# RUBY_HAS_ARCHLIB This package contains machine dependent binaries.
.if ${RUBY_VER} == "19"
RUBY_API_TEENY= 1
.else
RUBY_API_TEENY= ${_RUBY_VER_TEENY}
.endif
# RUBY_REQD Minimum required Ruby's version
#
.if defined(RUBY_HAS_ARCHLIB) && empty(RUBY_HAS_ARCHLIB:M[nN][oO])
.if ${RUBY_VER} == "18"
RUBY_REQD?= ${RUBY18_VERSION}
.endif
.else
.if ${RUBY_VER} == "18"
RUBY_REQD?= 1.8.1
.endif
.endif
RUBY_REQD?= ${RUBY_VERSION}
# RUBY_SUFFIX is appended to Ruby's commands; ruby, irb and so on.
#
@ -93,6 +98,13 @@ RUBY_SUFFIX?= ${RUBY_VER}
#
RUBY_NAME?= ruby${RUBY_SUFFIX}
# Optional encoding argument for shbang line
RUBY_ENCODING_ARG?=
# Name of gem and rake command
RUBYGEM_NAME= gem${RUBY_SUFFIX}
RAKE_NAME= rake${RUBY_SUFFIX}
# RUBY_BASE is base of ruby package's name
#
RUBY_BASE= ruby${RUBY_VER}-base
@ -103,7 +115,13 @@ RUBY_PKGPREFIX?= ${RUBY_NAME}
# RUBY_VER_DIR is used as part of Ruby's library directories.
#
#.if ${RUBY_VER} == "18"
RUBY_VER_DIR?= ${_RUBY_VER_MAJOR}.${_RUBY_VER_MINOR}
#.else
#RUBY_VER_DIR?= ${RUBY_VERSION}
#.endif
RUBY_SITE_SUBDIR?= ${_RUBY_VER_MAJOR}.${_RUBY_VER_MINOR}
# Simple check for package availability with Ruby's version.
#
@ -119,6 +137,12 @@ RUBY_SUFFIX=
RUBY_NAME= ruby
.endif
# Build rdoc
RUBY_BUILD_RDOC?= YES
# Build ri, index for ri command
RUBY_BUILD_RI?= YES
# RUBY related command's full pathname.
#
RUBY?= ${PREFIX}/bin/${RUBY_NAME}
@ -133,17 +157,17 @@ RUBY_ARCH?= ${LOWER_ARCH}-${LOWER_OPSYS}${APPEND_ELF}${LOWER_OPSYS_VERSUFFIX}
# Ruby shared library version handling.
#
RUBY_SHLIBMAJOR?= ${_RUBY_VER_MAJOR}
RUBY_SHLIBVER?= ${RUBY_VERSION}
RUBY_SHLIBVER?= ${RUBY_API_VERSION}
.if ${OPSYS} == "NetBSD" || ${OPSYS} == "Interix"
RUBY_SHLIBMAJOR= ${RUBY_VER}
RUBY_SHLIBVER= ${RUBY_VER}.${_RUBY_VER_TEENY}
RUBY_SHLIBVER= ${RUBY_VER}.${RUBY_API_TEENY}
.elif ${OPSYS} == "FreeBSD" || ${OPSYS} == "DragonFly"
RUBY_SHLIBMAJOR= # unused
RUBY_SHLIBVER= ${RUBY_VER}
.elif ${OPSYS} == "OpenBSD"
RUBY_SHLIBMAJOR= # unused
RUBY_SHLIBVER= ${_RUBY_VER_MAJOR}.${_RUBY_VER_MINOR}${_RUBY_VER_TEENY}
RUBY_SHLIBVER= ${_RUBY_VER_MAJOR}.${_RUBY_VER_MINOR}${RUBY_API_TEENY}
.elif ${OPSYS} == "IRIX"
RUBY_SHLIBMAJOR= # unused
.elif ${OPSYS} == "Linux"
@ -156,7 +180,6 @@ RUBY_NOSHLIBMAJOR= "@comment "
RUBY_NOSHLIBMAJOR=
.endif
#
# RUBY_DLEXT is suffix of extention library.
#
@ -194,28 +217,30 @@ RUBY_SRCDIR?= ${_PKGSRC_TOPDIR}/lang/${RUBY_BASE}
#
# common paths
#
RUBY_LIB?= lib/ruby/${RUBY_VER_DIR}
RUBY_INC= include/ruby-${RUBY_VER_DIR}
RUBY_ARCHINC= ${RUBY_INC}/${RUBY_ARCH}
RUBY_LIB_BASE= lib/ruby
RUBY_LIB?= ${RUBY_LIB_BASE}/${RUBY_VER_DIR}
RUBY_ARCHLIB?= ${RUBY_LIB}/${RUBY_ARCH}
RUBY_SITELIB_BASE?= lib/ruby/site_ruby
RUBY_SITELIB_BASE?= ${RUBY_LIB_BASE}/site_ruby
RUBY_SITELIB?= ${RUBY_SITELIB_BASE}/${RUBY_VER_DIR}
RUBY_SITEARCHLIB?= ${RUBY_SITELIB}/${RUBY_ARCH}
RUBY_VENDORLIB_BASE?= lib/ruby/vendor_ruby
RUBY_VENDORLIB_BASE?= ${RUBY_LIB_BASE}/vendor_ruby
RUBY_VENDORLIB?= ${RUBY_VENDORLIB_BASE}/${RUBY_VER_DIR}
RUBY_VENDORARCHLIB?= ${RUBY_VENDORLIB}/${RUBY_ARCH}
RUBY_DOC?= share/doc/${RUBY_NAME}
RUBY_EG?= share/examples/${RUBY_NAME}
# RUBY_GEM_BASE
# The base path of the gem repository.
#
# These will be discontinued in near future.
RUBY_GEM_BASE?= ${RUBY_LIB_BASE}/gems
# GEM_HOME
# The path of the gem repository.
#
RUBY_LIBDIR= ${PREFIX}/${RUBY_LIB}
RUBY_ARCHLIBDIR= ${PREFIX}/${RUBY_ARCHLIB}
RUBY_SITELIBDIR= ${PREFIX}/${RUBY_SITELIB}
RUBY_SITEARCHLIBDIR= ${PREFIX}/${RUBY_SITEARCHLIB}
RUBY_VENDORLIBDIR= ${PREFIX}/${RUBY_VENDORLIB}
RUBY_VENDORARCHLIBDIR= ${PREFIX}/${RUBY_VENDORARCHLIB}
RUBY_DOCDIR= ${PREFIX}/${RUBY_DOC}
RUBY_EXAMPLESDIR= ${PREFIX}/${RUBY_EG}
GEM_HOME?= ${RUBY_GEM_BASE}/${RUBY_VER_DIR}
#
# ri database relative path
@ -235,28 +260,34 @@ MAKE_ENV+= RUBY=${RUBY:Q} RUBY_VER=${RUBY_VER:Q} \
MAKEFLAGS+= RUBY_VERSION=${RUBY_VERSION:Q} \
RUBY_VERSION_DEFAULT=${RUBY_VERSION_DEFAULT:Q}
#
# PLIST
#
PLIST_RUBY_DIRS= RUBY_LIB="${RUBY_LIB}" \
RUBY_ARCHLIB="${RUBY_ARCHLIB}" \
PLIST_VARS+= ruby18 ruby19
.if ${RUBY_VER} == "18"
PLIST.ruby18= yes
.elif ${RUBY_VER} == "19"
PLIST.ruby19= yes
.endif
PLIST_RUBY_DIRS= RUBY_INC=${RUBY_INC:Q} RUBY_ARCHINC=${RUBY_ARCHINC:Q} \
RUBY_LIB_BASE=${RUBY_LIB_BASE:Q} \
RUBY_LIB=${RUBY_LIB:Q} \
RUBY_ARCHLIB=${RUBY_ARCHLIB:Q} \
RUBY_SITELIB_BASE=${RUBY_SITELIB_BASE:Q} \
RUBY_SITELIB="${RUBY_SITELIB}" \
RUBY_SITEARCHLIB="${RUBY_SITEARCHLIB}" \
RUBY_SITELIB=${RUBY_SITELIB:Q} \
RUBY_SITEARCHLIB=${RUBY_SITEARCHLIB:Q} \
RUBY_VENDORLIB_BASE=${RUBY_VENDORLIB_BASE:Q} \
RUBY_VENDORLIB=${RUBY_VENDORLIB:Q} \
RUBY_VENDORARCHLIB=${RUBY_VENDORARCHLIB:Q} \
RUBY_DOC="${RUBY_DOC}" \
RUBY_EG="${RUBY_EG}" \
RUBY_LIBDIR="${RUBY_LIBDIR}" \
RUBY_ARCHLIBDIR="${RUBY_ARCHLIBDIR}" \
RUBY_SITELIBDIR="${RUBY_SITELIBDIR}" \
RUBY_SITEARCHLIBDIR="${RUBY_SITEARCHLIBDIR}" \
RUBY_DOCDIR="${RUBY_DOCDIR}" \
RUBY_EXAMPLESDIR="${RUBY_EXAMPLESDIR}" \
RUBY_RIDIR="${RUBY_RIDIR}" \
RUBY_BASERIDIR="${RUBY_BASERIDIR}" \
RUBY_SYSRIDIR="${RUBY_SYSRIDIR}" \
RUBY_SITERIDIR="${RUBY_SITERIDIR}"
RUBY_DOC=${RUBY_DOC:Q} \
RUBY_EG=${RUBY_EG:Q} \
RUBY_GEM_BASE=${RUBY_GEM_BASE:Q} \
GEM_HOME=${GEM_HOME:Q} \
RUBY_RIDIR=${RUBY_RIDIR:Q} \
RUBY_BASERIDIR=${RUBY_BASERIDIR:Q} \
RUBY_SYSRIDIR=${RUBY_SYSRIDIR:Q} \
RUBY_SITERIDIR=${RUBY_SITERIDIR:Q}
#
# substitutions
@ -272,11 +303,13 @@ MESSAGE_SUBST+= RUBY="${RUBY}" RUBY_VER="${RUBY_VER}" \
${PLIST_RUBY_DIRS:S,DIR="${PREFIX}/,DIR=",}
PLIST_SUBST+= RUBY=${RUBY:Q} RUBY_VER=${RUBY_VER:Q} \
RUBY_PKGPREFIX=${RUBY_PKGPREFIX} \
RUBY_VERSION=${RUBY_VERSION:Q} \
RUBY_VER_DIR=${RUBY_VER_DIR:Q} \
RUBY_DLEXT=${RUBY_DLEXT:Q} \
RUBY_ARCH=${RUBY_ARCH:Q} \
${PLIST_RUBY_DIRS:S,DIR="${PREFIX}/,DIR=",}
${PLIST_RUBY_DIRS:S,DIR="${PREFIX}/,DIR=",} \
GEM_HOME=${GEM_HOME:Q}
#
# make dynamic PLIST
@ -321,6 +354,20 @@ RUBY_GENERATE_PLIST = ( \
.include "../../mk/dlopen.buildlink3.mk"
.endif
.if ${RUBY_VER} == "19"
PRINT_PLIST_AWK+= /${RUBY_DLEXT}\.${RUBY_SHLIBVER:S|.|\\.|}$$/ \
{ sub(/${RUBY_DLEXT}\.${RUBY_SHLIBVER:S|.|\\.|}$$/, \
"$${RUBY_DLEXT}.$${RUBY_SHLIBVER}"); }
PRINT_PLIST_AWK+= /${RUBY_DLEXT}\.${RUBY_SHLIBMAJOR}$$/ \
{ sub(/${RUBY_DLEXT}\.${RUBY_SHLIBMAJOR}$$/, \
"$${RUBY_DLEXT}.$${RUBY_SHLIBMAJOR}"); }
.endif
PRINT_PLIST_AWK+= /^${RUBY_ARCHINC:S|/|\\/|g}/ \
{ gsub(/${RUBY_ARCHINC:S|/|\\/|g}/, "$${RUBY_ARCHINC}"); \
print; next; }
PRINT_PLIST_AWK+= /^${RUBY_INC:S|/|\\/|g}/ \
{ gsub(/${RUBY_INC:S|/|\\/|g}/, "$${RUBY_INC}"); \
print; next; }
PRINT_PLIST_AWK+= /\.${RUBY_DLEXT}$$/ \
{ gsub(/${RUBY_DLEXT}$$/, "$${RUBY_DLEXT}") }
PRINT_PLIST_AWK+= /^${RUBY_ARCHLIB:S|/|\\/|g}/ \
@ -338,10 +385,10 @@ PRINT_PLIST_AWK+= /^${RUBY_SITEARCHLIB:S|/|\\/|g}/ \
PRINT_PLIST_AWK+= /^${RUBY_SITELIB:S|/|\\/|g}/ \
{ gsub(/${RUBY_SITELIB:S|/|\\/|g}/, "$${RUBY_SITELIB}"); \
print; next; }
PRINT_PLIST_AWK+= /^${RUBY_SITELIB_BASE:S|/|\\/|g}$$/ \
PRINT_PLIST_AWK+= /^${RUBY_SITELIB_BASE:S|/|\\/|g}/ \
{ gsub(/${RUBY_SITELIB_BASE:S|/|\\/|g}/, "$${RUBY_SITELIB_BASE}"); \
print; next; }
PRINT_PLIST_AWK+= /^${RUBY_VENDORLIB_BASE:S|/|\\/|g}$$/ \
PRINT_PLIST_AWK+= /^${RUBY_VENDORLIB_BASE:S|/|\\/|g}/ \
{ gsub(/${RUBY_VENDORLIB_BASE:S|/|\\/|g}/, "$${RUBY_VENDORLIB_BASE}"); \
print; next; }
PRINT_PLIST_AWK+= /^${RUBY_LIB:S|/|\\/|g}/ \
@ -356,8 +403,9 @@ PRINT_PLIST_AWK+= /^${RUBY_EG:S|/|\\/|g}/ \
PRINT_PLIST_AWK+= /^${RUBY_SITERIDIR:S|/|\\/|g}/ \
{ gsub(/${RUBY_SITERIDIR:S|/|\\/|g}/, "$${RUBY_SITERIDIR}"); \
print; next; }
PRINT_PLIST_AWK+= /^${RUBY_SYSRIDIR:S|/|\\/|g}/ \
{ gsub(/${RUBY_SYSRIDIR:S|/|\\/|g}/, "$${RUBY_SYSRIDIR}"); \
print; next; }
PRINT_PLIST_AWK+= /^${RUBY_SYSRIDIR:S|/|\\/|g}\// \
{ next; }
PRINT_PLIST_AWK+= /\/${RUBY_NAME}/ \
{ sub(/${RUBY_NAME}/, "$${RUBY_NAME}"); }
.endif # _RUBY_MK