pkgsrc-Changes archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
CVS commit: pkgsrc/lang/elixir
Module Name: pkgsrc
Committed By: nikita
Date: Thu Nov 10 14:23:15 UTC 2022
Added Files:
pkgsrc/lang/elixir: mix.mk
Log Message:
lang/elixir: Add code to simplify handling mix build system.
Inspired by FreeBSD ports' elixir.mk
To generate a diff of this commit:
cvs rdiff -u -r0 -r1.1 pkgsrc/lang/elixir/mix.mk
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Added files:
Index: pkgsrc/lang/elixir/mix.mk
diff -u /dev/null pkgsrc/lang/elixir/mix.mk:1.1
--- /dev/null Thu Nov 10 14:23:15 2022
+++ pkgsrc/lang/elixir/mix.mk Thu Nov 10 14:23:15 2022
@@ -0,0 +1,79 @@
+# $NetBSD: mix.mk,v 1.1 2022/11/10 14:23:15 nikita Exp $
+#
+# Common logic that can be used by packages that use mix as a build tool.
+#
+# Inspired by elixir.mk from FreeBSD ports.
+#
+# It is not yet fully tested.
+# See devel/hex for an example.
+
+DEPENDS+= elixir>=1.14.0:../../lang/elixir
+
+ELIXIR_APP_NAME?= ${PKGBASE}
+ELIXIR_LIB_ROOT?= ${DESTDIR}${PREFIX}/lib/elixir/lib
+ELIXIR_APP_ROOT?= ${ELIXIR_LIB_ROOT}/${ELIXIR_APP_NAME}
+ELIXIR_HIDDEN?= "^${ELIXIR_APP_NAME}$$"
+ELIXIR_LOCALE?= en_US.UTF-8
+
+MIX_CMD?= ${PREFIX}/bin/mix
+MIX_REWRITE?=
+MIX_BUILD_DEPS?=
+MIX_RUN_DEPS?=
+MIX_DOC_DIRS?=
+MIX_DOC_FILES?=
+MIX_ENV?=
+MIX_ENV_NAME?= prod
+MIX_BUILD_NAME?= prod
+MIX_TARGET?= compile
+MIX_EXTRA_APPS?=
+MIX_EXTRA_DIRS?=
+MIX_EXTRA_FILES?=
+MIX_COMPILE?= ${SETENV} ${MIX_ENV} LANG=${ELIXIR_LOCALE} LC_ALL=${ELIXIR_LOCALE} MIX_ENV=${MIX_ENV_NAME} ELIXIR_HIDDEN=${ELIXIR_HIDDEN} ${MIX_CMD} ${MIX_TARGET}
+
+.if !target(do-build)
+do-build: do-mix-build
+.endif
+
+.PHONY: do-mix-build
+do-mix-build:
+ ${RM} ${WRKSRC}/mix.lock
+ cd ${WRKSRC} && ${MIX_COMPILE}
+.for app in ${MIX_EXTRA_APPS}
+ ${RM} ${WRKSRC}/${app}/mix.lock
+ cd ${WRKSRC}/${app} && ${MIX_COMPILE}
+.endfor
+
+.if !target(do-install)
+do-install: do-mix-install
+.endif
+
+do-mix-install:
+ ${MKDIR} ${ELIXIR_APP_ROOT}/lib
+ cd ${WRKSRC}/lib && ${CP} -R * ${ELIXIR_APP_ROOT}/lib
+ ${MKDIR} ${ELIXIR_APP_ROOT}/ebin
+ ${INSTALL_DATA} ${WRKSRC}/_build/${MIX_BUILD_NAME}/lib/${ELIXIR_APP_NAME}/ebin/* \
+ ${ELIXIR_APP_ROOT}/ebin
+ if test -d ${WRKSRC}/priv; then \
+ ${MKDIR} ${ELIXIR_APP_ROOT}/priv; \
+ cd ${WRKSRC}/priv && ${CP} -R * ${ELIXIR_APP_ROOT}/priv; \
+ fi
+.if ${MIX_DOC_FILES} != "" || ${MIX_DOC_DIRS} != ""
+ ${MKDIR} ${DESTDIR}${PREFIX}/share/doc/${PKGNAME}/
+.endif
+.for file in ${MIX_DOC_FILES}
+ ${INSTALL_DATA} ${WRKSRC}/${file} ${DESTDIR}${PREFIX}/share/doc/${PKGNAME}/
+.endfor
+.for dir in ${MIX_DOC_DIRS}
+ cd ${WRKSRC} && ${CP} -R ${dir} ${DESTDIR}${PREFIX}/share/doc/${PKGNAME}/
+.endfor
+.for file in ${MIX_EXTRA_FILES}
+ ${INSTALL_DATA} ${WRKSRC}/${file} ${ELIXIR_APP_ROOT}
+.endfor
+.for dir in ${MIX_EXTRA_DIRS}
+ ${MKDIR} ${ELIXIR_APP_ROOT}/${dir}
+ cd ${WRKSRC}/${dir} && ${CP} -R . ${ELIXIR_APP_ROOT}/${dir}
+.endfor
+.for app in ${MIX_EXTRA_APPS}
+ ${INSTALL_DATA} ${WRKSRC}/${app}/_build/${MIX_BUILD_NAME}/lib/*/ebin/* \
+ ${ELIXIR_APP_ROOT}/ebin
+.endfor
Home |
Main Index |
Thread Index |
Old Index