[Midnightbsd-cvs] mports [24657] trunk/Mk/extensions/mono.mk: update mono extension for msbuild/nuget
laffer1 at midnightbsd.org
laffer1 at midnightbsd.org
Thu Nov 22 00:30:01 EST 2018
Revision: 24657
http://svnweb.midnightbsd.org/mports/?rev=24657
Author: laffer1
Date: 2018-11-22 00:30:00 -0500 (Thu, 22 Nov 2018)
Log Message:
-----------
update mono extension for msbuild/nuget
Modified Paths:
--------------
trunk/Mk/extensions/mono.mk
Modified: trunk/Mk/extensions/mono.mk
===================================================================
--- trunk/Mk/extensions/mono.mk 2018-11-22 05:29:12 UTC (rev 24656)
+++ trunk/Mk/extensions/mono.mk 2018-11-22 05:30:00 UTC (rev 24657)
@@ -7,6 +7,65 @@
# Usage: USES=mono:ARGS
# Valid ARGS: nuget
#
+# Arguments:
+#
+# nuget Specifies that the port uses nuget packages.
+#
+# EXTRACT_ONLY is conditionally overridden to exclude all
+# files with a '.nupkg' extension.
+#
+# Targets:
+#
+# makenuget This target will output the NUGET_DEPENDS based on the
+# port's packages.config file.
+#
+# makenupkg This target will create nupkg-${NAME} files based on the
+# port's downloaded packages in ${NUGET_PACKAGEDIR}
+#
+# Variables overrideable by the port:
+#
+# NUGET_PACKAGEDIR The directory in which the port expects the
+# nuget packages to be available
+# default: ${WRKSRC}/packages
+#
+# NUGET_LAYOUT The directory layout of ${NUGET_PACKAGEDIR}:
+# legacy:
+# ${NAME}
+# ${NAME}.${VERSION}
+# ${NAME.tl}/${VERSION}
+# flat:
+# ${NAME}
+# ${NAME:tl}
+# dotnet:
+# ${NAME:tl}/${VERSION}
+# default: legacy
+#
+# NUGET_FEEDS A list of nuget feed names
+# default: NUGET
+#
+# ${NAME}_URL: The base URL for the feed ${NAME}
+# defaults:
+# NUGET_URL=https://www.nuget.org/api/v2/
+# ${NAME}_URL=https://dotnet.myget.org/F/${NAME:tl:S/_/-/g}/api/v2/
+#
+# ${NAME}_FILE: The file containing a list of nuget packages from
+# feed ${NAME} in the format:
+# ${name}=${version}
+# default: ${PKGDIR}/nupkg-${NAME:tl}
+#
+# ${NAME}_DEPENDS: The list of nuget packages from feed ${NAME} in the
+# format:
+# ${name}=${version}
+# defaults:
+# NUGET_DEPENDS=${PAKET_DEPENDS}
+#
+# PAKET_PACKAGEDIR The directory in which the port expects the
+# nuget packages (managed by paket) to be available
+#
+# PAKET_DEPENDS The list of nuget packages from a nuget feed. The
+# version used needs to be resolved (unlike how paket
+# works). The format is:
+# ${name}=${version}
.if !defined(_INCLUDE_USES_MONO_MK)
_INCLUDE_USES_MONO_MK= yes
@@ -32,50 +91,116 @@
GACUTIL_INSTALL_PACKAGE=${GACUTIL} /i /package 1.0 /package 2.0
.if ${mono_ARGS:Mnuget}
-NUGET_PACKAGEDIR= ${WRKSRC}/packages
-EXTRACT_CMD= ${LOCALBASE}/bin/bsdtar
-EXTRACT_DEPENDS+= bsdtar:archivers/libarchive
+MAKE_ENV+= NUGET_PACKAGES=${NUGET_PACKAGEDIR}
-. for depend in ${NUGET_DEPENDS}
+# TODO: add nuget as a Port, use it for makenupkg
+NUGET_EXE?= ${WRKDIR}/nuget.exe
+NUGET_LATEST_URL?= https://dist.nuget.org/win-x86-commandline/latest/nuget.exe
+
+_NUGET_PACKAGEDIR= ${WRKDIR}/.nuget/packages
+NUGET_PACKAGEDIR?= ${WRKSRC}/packages
+NUGET_LAYOUT?= legacy
+NUGET_FEEDS?= NUGET
+NUGET_URL?= https://api.nuget.org/v3-flatcontainer/
+NUGET_VERSION?= v3
+
+PAKET_PACKAGEDIR?=
+PAKET_DEPENDS?=
+NUGET_DEPENDS?= ${PAKET_DEPENDS}
+
+. for feed in ${NUGET_FEEDS}
+${feed}_DEPENDS?=
+${feed}_FILE?= ${PKGDIR}/nupkg-${feed:tl}
+${feed}_URL?= https://dotnet.myget.org/F/${feed:tl:S/_/-/g}/api/v2/
+${feed}_VERSION?= v2
+. if exists(${${feed}_FILE})
+${feed}_EXTRA!= ${CAT} ${${feed}_FILE}
+. else
+${feed}_EXTRA=
+. endif
+MAKENUPKG_ENV+= ${feed:tl}_URL="${${feed}_URL}" ${feed:tl}_VERSION="${${feed}_VERSION}"
+. for depend in ${${feed}_DEPENDS} ${${feed}_EXTRA}
+. if empty(_NUGET_DEPENDS:M${depend})
id= ${depend:C/=.*$//}
version= ${depend:C/^.*=//}
-group= nuget_${id:S/.//g:S/-//g}
+group= nuget_${depend:C/[.+=-]//g}
nupkg= ${id:tl}.${version}.nupkg
-NUPKG_${group}:= ${nupkg}
DISTFILES_${group}:= ${nupkg}:${group}
-MASTER_SITES_${group}:= https://www.nuget.org/api/v2/package/${id}/${version}?dummy=/:${group}
+. if ${${feed}_VERSION} == v2
+MASTER_SITES_${group}:= ${${feed}_URL}package/${id}/${version}?dummy=/:${group}
+. else
+MASTER_SITES_${group}:= ${${feed}_URL}${id:tl}/${version}/:${group}
+. endif
NUGET_NUPKGS_${group}:= ${nupkg}:${depend}
+NUPKGS_${id}:= ${NUPKGS_${id}} ${version}
-NUGET_DISTFILES+=${NUPKG_nuget_${depend:C/=.*$//:S/.//g:S/-//g}}
-DISTFILES+= ${DISTFILES_nuget_${depend:C/=.*$//:S/.//g:S/-//g}}
-MASTER_SITES+= ${MASTER_SITES_nuget_${depend:C/=.*$//:S/.//g:S/-//g}}
-NUGET_NUPKGS+= ${NUGET_NUPKGS_nuget_${depend:C/=.*$//:S/.//g:S/-//g}}
+DISTFILES+= ${DISTFILES_nuget_${depend:S/.//g:S/-//g:S/=//g}}
+MASTER_SITES+= ${MASTER_SITES_nuget_${depend:S/.//g:S/-//g:S/=//g}}
+NUGET_NUPKGS+= ${NUGET_NUPKGS_nuget_${depend:S/.//g:S/-//g:S/=//g}}
+_NUGET_DEPENDS+= ${depend}
+. endif
. endfor
+. endfor
-# Prevent the nuget packages from being extracted (and poluting ${WRKDIR}, however
-# only bmake supports this.
-. if !defined(EXTRACT_ONLY) && defined(.PARSEDIR)
-EXTRACT_ONLY= ${_DISTFILES:[0]:C/${NUGET_DISTFILES}//g}
-. endif
+EXTRACT_ONLY?= ${_DISTFILES:N*.nupkg}
-pre-extract: nuget-extract
-
-_USES_extract+= 900:nuget-extract
+_USES_extract+= 600:nuget-extract
nuget-extract:
-. for nupkg in ${NUGET_NUPKGS}
- @${MKDIR} ${NUGET_PACKAGEDIR}/${nupkg:C/^.*://:S/=/./}
- @${LN} -s ${NUGET_PACKAGEDIR}/${nupkg:C/^.*://:S/=/./} ${NUGET_PACKAGEDIR}/${nupkg:C/^.*://:C/=.*//}
- @${EXTRACT_CMD} -xf ${DISTDIR}/${nupkg:C/:.*$//} -C ${NUGET_PACKAGEDIR}/${nupkg:C/^.*://:S/=/./} \
+ @${MKDIR} ${_NUGET_PACKAGEDIR} ${PAKET_PACKAGEDIR}
+. for nupkg in ${NUGET_NUPKGS}
+ @${MKDIR} ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}
+ @tar -xf ${DISTDIR}/${nupkg:C/:.*$//} -C ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|} \
-s/%2B/\+/g -s/%2B/\+/g -s/%2B/\+/g \
--exclude '\[Content_Types\].xml' \
--exclude package/ \
--exclude _rels/
-. endfor
+ @${MV} ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/${nupkg:C/^.*://:C/=.*//}.nuspec \
+ ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/${nupkg:tl:C/^.*://:C/=.*//}.nuspec
+ @${CP} ${DISTDIR}/${nupkg:C/:.*$//} ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/${nupkg:tl:C/^.*://:S/=/./}.nupkg
+ @openssl dgst -sha512 -binary ${DISTDIR}/${nupkg:C/:.*$//} | openssl enc -base64 | ${TR} -d "\n" \
+ > ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/${nupkg:tl:C/^.*://:S/=/./}.nupkg.sha512
+. if ${NUGET_LAYOUT} == legacy
+ @${CP} -a ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/ ${_NUGET_PACKAGEDIR}/${nupkg:C/^.*://:S|=|.|}/
+ @${CP} -a ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/ ${_NUGET_PACKAGEDIR}/${nupkg:C/^.*://:C|=.*||}/
+. if ${nupkg} != ${nupkg:tl}
+ @(cd ${_NUGET_PACKAGEDIR}/${nupkg:C/^.*://:C|=.*||}; \
+ ${MV} ${nupkg:tl:C/^.*://:C/=.*//}.nuspec ${nupkg:C/^.*://:C/=.*//}.nuspec; \
+ ${MV} ${nupkg:tl:C/^.*://:S/=/./}.nupkg ${nupkg:C/^.*://:S/=/./}.nupkg; \
+ ${MV} ${nupkg:tl:C/^.*://:S/=/./}.nupkg.sha512 ${nupkg:C/^.*://:S/=/./}.nupkg.sha512)
+ @(cd ${_NUGET_PACKAGEDIR}/${nupkg:C/^.*://:S|=|.|}; \
+ ${MV} ${nupkg:tl:C/^.*://:C/=.*//}.nuspec ${nupkg:C/^.*://:C/=.*//}.nuspec; \
+ ${MV} ${nupkg:tl:C/^.*://:S/=/./}.nupkg ${nupkg:C/^.*://:S/=/./}.nupkg; \
+ ${MV} ${nupkg:tl:C/^.*://:S/=/./}.nupkg.sha512 ${nupkg:C/^.*://:S/=/./}.nupkg.sha512)
+. endif
+. elif ${NUGET_LAYOUT} == flat
+ @${CP} -a ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}/ ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:C|=.*||}/
+ @${RM} -r ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}
+. if ${nupkg} != ${nupkg:tl}
+ @${CP} -a ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:C|=.*||}/ ${_NUGET_PACKAGEDIR}/${nupkg:C/^.*://:C|=.*||}/
+ @(cd ${_NUGET_PACKAGEDIR}/${nupkg:C/^.*://:C|=.*||}; \
+ ${MV} ${nupkg:tl:C/^.*://:C/=.*//}.nuspec ${nupkg:C/^.*://:C/=.*//}.nuspec; \
+ ${MV} ${nupkg:tl:C/^.*://:S/=/./}.nupkg ${nupkg:C/^.*://:S/=/./}.nupkg; \
+ ${MV} ${nupkg:tl:C/^.*://:S/=/./}.nupkg.sha512 ${nupkg:C/^.*://:S/=/./}.nupkg.sha512)
+. endif
+. endif
+. endfor
+ @${RLN} ${_NUGET_PACKAGEDIR} ${NUGET_PACKAGEDIR}
+ @${TOUCH} ${WRKDIR}/.nuget-sentinal
+
+_USES_extract+= 601:paket-extract
+paket-extract:
+. for nupkg in ${PAKET_DEPENDS}
+ @${RLN} ${_NUGET_PACKAGEDIR}/${nupkg:tl:S|=|/|} ${PAKET_PACKAGEDIR}/${nupkg:C/=.*//}
+ @(cd ${_NUGET_PACKAGEDIR}/${nupkg:tl:C/^.*://:S|=|/|}; \
+ ${CP} ${nupkg:tl:C/^.*://:C/=.*//}.nuspec ${nupkg:C/^.*://:C/=.*//}.nuspec; \
+ ${CP} ${nupkg:tl:C/^.*://:S/=/./}.nupkg ${nupkg:C/^.*://:S/=/./}.nupkg; \
+ ${CP} ${nupkg:tl:C/^.*://:S/=/./}.nupkg.sha512 ${nupkg:C/^.*://:S/=/./}.nupkg.sha512)
+. endfor
.endif
makenuget: patch
@${FIND} ${WRKSRC} -name packages.config | \
- ${XARGS} ${SED} -nE 's|.*<package id="([^"]+)" version="([^"]+)"[^/]*/>.*|\1-\2|gp' | \
+ ${XARGS} ${SED} -nE 's|.*<package id="([^"]+)" version="([^"]+)"[^/]*/>.*|\1=\2|gp' | \
${SORT} -u | \
${SED} \
-e '1s|^|NUGET_DEPENDS= |' \
@@ -82,5 +207,27 @@
-e '2,$$s|^| |g' \
-e '$$!s|$$| \\|g'
+makenupkg:
+ @${RM} ${WRKDIR}/nupkg-*
+ @for nuspec in `${FIND} ${_NUGET_PACKAGEDIR} -name '*.nuspec'`; do \
+ name="`${SED} -nE 's|.*<id>(.*)</id>.*|\1|p' $$nuspec`"; \
+ version="`${SED} -nE 's|.*<version>(.*)</version>.*|\1|p' $$nuspec`"; \
+ echo $$name=$$version ; \
+ done | ${SORT} -u | ${SETENV} ${MAKENUPKG_ENV} ${XARGS} -n1 sh -c ' \
+ for feed in ${NUGET_FEEDS:MNUGET:tl} ${NUGET_FEEDS:NNUGET:tl}; do \
+ if eval [ "\$${$${feed}_VERSION}" = v2 ]; then \
+ eval url="\$${$${feed}_URL}package/$${0%%=*}/$${0##*=}"; \
+ else \
+ eval url="\$${$${feed}_URL}$${0%%=*}/$${0##*=}/$${0%%=*}.$${0##*=}.nupkg"; \
+ fi; \
+ if curl --output /dev/null --silent --head --fail $$url; then\
+ ${ECHO} $$0 >> ${WRKDIR}/nupkg-$$feed; \
+ found=yes; \
+ break; \
+ fi; \
+ done; \
+ if [ -z "$$found" ]; then \
+ echo "$$0: no feed found"; \
+ exit 1; \
+ fi'
.endif
-
More information about the Midnightbsd-cvs
mailing list