Commit 50f557f4 authored by Franco Fichtner's avatar Franco Fichtner

pkg: ok, 500% harder than found in the last commit

Transition away from making the internals known, so rework
the whole tree.mk to expand better to dynamic destinations.
parent 96f5e7fa
...@@ -214,14 +214,13 @@ scripts: want-git ...@@ -214,14 +214,13 @@ scripts: want-git
install: force install: force
@${MAKE} -C ${.CURDIR}/contrib install DESTDIR=${DESTDIR} @${MAKE} -C ${.CURDIR}/contrib install DESTDIR=${DESTDIR}
@${MAKE} -C ${.CURDIR}/src install_boot DESTDIR=${DESTDIR}
@${MAKE} -C ${.CURDIR}/src install DESTDIR=${DESTDIR} \ @${MAKE} -C ${.CURDIR}/src install DESTDIR=${DESTDIR} \
CORE_NAME=${CORE_NAME} CORE_ABI=${CORE_ABI} \ CORE_NAME=${CORE_NAME} CORE_ABI=${CORE_ABI} \
CORE_PACKAGESITE=${CORE_PACKAGESITE} \ CORE_PACKAGESITE=${CORE_PACKAGESITE} \
CORE_REPOSITORY=${CORE_REPOSITORY} CORE_REPOSITORY=${CORE_REPOSITORY}
bootstrap: force bootstrap: force
@${MAKE} -C ${.CURDIR}/src install_bootstrap DESTDIR=${DESTDIR} \ @${MAKE} -C ${.CURDIR}/src install-bootstrap DESTDIR=${DESTDIR} \
NO_SAMPLE=please CORE_PACKAGESITE=${CORE_PACKAGESITE} \ NO_SAMPLE=please CORE_PACKAGESITE=${CORE_PACKAGESITE} \
CORE_NAME=${CORE_NAME} CORE_ABI=${CORE_ABI} \ CORE_NAME=${CORE_NAME} CORE_ABI=${CORE_ABI} \
CORE_REPOSITORY=${CORE_REPOSITORY} CORE_REPOSITORY=${CORE_REPOSITORY}
......
all: all:
TREES_=${TREES} .for TARGET in ${TREES} ${EXTRAS}
ROOT_=${ROOT}
.for TARGET in _ ${EXTRA:C/.*/_&/g} .if "${TREES_${TARGET}}" == ""
TREES_${TARGET}=${TARGET}
.endif
install${TARGET}: force .if "${ROOT_${TARGET}}" == ""
.for TREE in ${TREES${TARGET}} ROOT_${TARGET}=${ROOT}
.endif
# fixup root target dir
ROOT_${TARGET}:=${ROOT_${TARGET}:S/^\/$//}
install-${TARGET}: force
.for TREE in ${TREES_${TARGET}}
@REALTARGET=/$$(dirname ${TREE}); \ @REALTARGET=/$$(dirname ${TREE}); \
mkdir -p ${DESTDIR}${ROOT${TARGET}}$${REALTARGET}; \ mkdir -p ${DESTDIR}${ROOT_${TARGET}}$${REALTARGET}; \
cp -vr ${TREE} ${DESTDIR}${ROOT${TARGET}}$${REALTARGET} cp -vr ${TREE} ${DESTDIR}${ROOT_${TARGET}}$${REALTARGET}
@(cd ${TREE}; find * -type f ! -name "*.pyc") | while read FILE; do \ @(cd ${TREE}; find * -type f ! -name "*.pyc") | while read FILE; do \
if [ "$${FILE%%.in}" != "$${FILE}" ]; then \ if [ "$${FILE%%.in}" != "$${FILE}" ]; then \
sed -i '' \ sed -i '' \
...@@ -17,20 +25,20 @@ install${TARGET}: force ...@@ -17,20 +25,20 @@ install${TARGET}: force
-e "s=%%CORE_REPOSITORY%%=${CORE_REPOSITORY}=g" \ -e "s=%%CORE_REPOSITORY%%=${CORE_REPOSITORY}=g" \
-e "s=%%CORE_NAME%%=${CORE_NAME}=g" \ -e "s=%%CORE_NAME%%=${CORE_NAME}=g" \
-e "s=%%CORE_ABI%%=${CORE_ABI}=g" \ -e "s=%%CORE_ABI%%=${CORE_ABI}=g" \
"${DESTDIR}${ROOT${TARGET}}/${TREE}/$${FILE}"; \ "${DESTDIR}${ROOT_${TARGET}}/${TREE}/$${FILE}"; \
mv -v "${DESTDIR}${ROOT${TARGET}}/${TREE}/$${FILE}" \ mv -v "${DESTDIR}${ROOT_${TARGET}}/${TREE}/$${FILE}" \
"${DESTDIR}${ROOT${TARGET}}/${TREE}/$${FILE%%.in}"; \ "${DESTDIR}${ROOT_${TARGET}}/${TREE}/$${FILE%%.in}"; \
fi; \ fi; \
FILE="$${FILE%%.in}"; \ FILE="$${FILE%%.in}"; \
if [ -n "${NO_SAMPLE}" -a "$${FILE%%.sample}" != "$${FILE}" ]; then \ if [ -n "${NO_SAMPLE}" -a "$${FILE%%.sample}" != "$${FILE}" ]; then \
mv -v "${DESTDIR}${ROOT${TARGET}}/${TREE}/$${FILE}" \ mv -v "${DESTDIR}${ROOT_${TARGET}}/${TREE}/$${FILE}" \
"${DESTDIR}${ROOT${TARGET}}/${TREE}/$${FILE%%.sample}"; \ "${DESTDIR}${ROOT_${TARGET}}/${TREE}/$${FILE%%.sample}"; \
fi; \ fi; \
done done
.endfor .endfor
plist${TARGET}: force plist-${TARGET}: force
.for TREE in ${TREES${TARGET}} .for TREE in ${TREES_${TARGET}}
@(cd ${TREE}; find * -type f ! -name "*.pyc") | while read FILE; do \ @(cd ${TREE}; find * -type f ! -name "*.pyc") | while read FILE; do \
FILE="$${FILE%%.in}"; PREFIX=""; \ FILE="$${FILE%%.in}"; PREFIX=""; \
if [ -z "${NO_SAMPLE}" -a "$${FILE%%.sample}" != "$${FILE}" ]; then \ if [ -z "${NO_SAMPLE}" -a "$${FILE%%.sample}" != "$${FILE}" ]; then \
...@@ -39,14 +47,17 @@ plist${TARGET}: force ...@@ -39,14 +47,17 @@ plist${TARGET}: force
if [ -n "${NO_SAMPLE}" ]; then \ if [ -n "${NO_SAMPLE}" ]; then \
FILE="$${FILE%%.sample}"; \ FILE="$${FILE%%.sample}"; \
fi; \ fi; \
echo "$${PREFIX}${ROOT${TARGET}}/${TREE}/$${FILE}"; \ echo "$${PREFIX}${ROOT_${TARGET}:}/${TREE}/$${FILE}"; \
done done
.endfor .endfor
.endfor .endfor
install: install_ .for TARGET in ${TREES}
plist: plist_ install: install-${TARGET}
plist: plist-${TARGET}
.endfor
force: force:
.PHONY: force .PHONY: force
ROOT= /usr/local TREES= boot etc opnsense sbin wizard www
TREES= etc opnsense sbin wizard www
EXTRA= boot bootstrap ROOT= /usr/local
ROOT_boot= /
ROOT_boot= # / EXTRAS= bootstrap
TREES_boot= boot
ROOT_bootstrap= /usr/local
TREES_bootstrap=etc/pkg TREES_bootstrap=etc/pkg
ROOT_bootstrap= /usr/local
.include "../Mk/tree.mk" .include "../Mk/tree.mk"
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment