diff options
-rwxr-xr-x | libexec/build-make-compile | 2 | ||||
-rwxr-xr-x | libexec/build-make-prep | 2 | ||||
-rwxr-xr-x | libexec/build-make-test | 3 | ||||
-rwxr-xr-x | libexec/build-makedeps | 274 |
4 files changed, 124 insertions, 157 deletions
diff --git a/libexec/build-make-compile b/libexec/build-make-compile index d3eb176..3a5de16 100755 --- a/libexec/build-make-compile +++ b/libexec/build-make-compile @@ -92,6 +92,8 @@ build_make_compile() wait find * -depth \( ! -type d \) -print0 > "${binpkg_list}" mv "${binpkg_list}" "${D}/var/db/binpkgs/${CATEGORY}/${NAME}" + + date >> "${BUILDER_TMPDIR}/${CATEGORY}/${NAME}/.compile" )} if test "${BUILDER_CALL_STACK}" = '__main__'; then diff --git a/libexec/build-make-prep b/libexec/build-make-prep index f9f74db..732c7cf 100755 --- a/libexec/build-make-prep +++ b/libexec/build-make-prep @@ -86,6 +86,8 @@ build_make_prep() fi >> "${PKG_LOGFILE}" 2>&1 done fi + + date > "${BUILDER_TMPDIR}/${CATEGORY}/${NAME}/.prep" )} if test "${BUILDER_CALL_STACK}" = '__main__'; then diff --git a/libexec/build-make-test b/libexec/build-make-test index e72dfd9..bd9f5d6 100755 --- a/libexec/build-make-test +++ b/libexec/build-make-test @@ -24,7 +24,8 @@ build_make_test() cd "${W}" pkg_test >> "${PKG_LOGFILE}" 2>&1 - )} + date >> "${BUILDER_TMPDIR}/${CATEGORY}/${NAME}/.test" +)} if test "${BUILDER_CALL_STACK}" = '__main__'; then simple_usage 'test' '[all|[<category>/]<package|all>]' "$@" diff --git a/libexec/build-makedeps b/libexec/build-makedeps index 9cf62fb..1156626 100755 --- a/libexec/build-makedeps +++ b/libexec/build-makedeps @@ -1,45 +1,43 @@ #!/usr/bin/env build + +build_makedeps_name() { echo "${1}"|tr '/-' '__'; } + cat >"${BUILDER_MAKEFILE}" <<EOF ## # Some generic catchall rules -all: all_all_archive -all_fetch: all_all_fetch -all_prep: all_all_prep -all_compile: all_all_compile -all_archive: all_all_archive -all_install: all_all_install -all_test: all_all_test -all_export: all_all_export -all_source: all_all_source -all_makedeps: -all_source: +all: all_all +all_all: all_all_package +all_all_clean: exports_clean +all_all_distclean: sysroot_clean artifacts_clean tmpdir_clean exports_clean sysroot_clean: - @if test -d "${SYSROOT}"; then \ - echo "cleaning: sysroot" ; \ - (cd "${SYSROOT}" && find . -delete) ; \ + @if test -d "${SYSROOT}"; then \\ + echo "cleaning: sysroot" ; \\ + (cd "${SYSROOT}" && find . -delete) ; \\ fi artifacts_clean: - @if test -d "${BUILDER_ATFDIR}"; then \ - echo "cleaning: artifacts" ; \ - (cd "${BUILDER_ATFDIR}" && find . -delete) ; \ + @if test -d "${BUILDER_ATFDIR}"; then \\ + echo "cleaning: artifacts" ; \\ + (cd "${BUILDER_ATFDIR}" && find . -delete) ; \\ fi tmpdir_clean: - @if test -d "${BUILDER_TMPDIR}"; then \ - echo "cleaning: tmpdir" ; \ - find "${BUILDER_TMPDIR}" -delete ; \ + @if test -d "${BUILDER_TMPDIR}"; then \\ + echo "cleaning: tmpdir" ; \\ + find "${BUILDER_TMPDIR}" -delete ; \\ fi exports_clean: - @if test -d "${BUILDER_TOPDIR}/exports"; then \ - echo "cleaning: exports" ; \ - find "${BUILDER_TOPDIR}/exports" -delete ; \ + @if test -d "${BUILDER_TOPDIR}/exports"; then \\ + echo "cleaning: exports" ; \\ + find "${BUILDER_TOPDIR}/exports" -delete ; \\ fi + EOF PACKAGES_CLEAN= -for package in $(echo "${BUILDER_PKGDIR}"/*/*); do - test -d "${package}" || die "no packages defined" - package="${package#${BUILDER_PKGDIR}/}" +set -- $(cd "${BUILDER_PKGDIR}" && echo */*) +for package; do + test -d "${BUILDER_PKGDIR}/${package}" || die "no packages defined" + if ! test -f "${BUILDER_PKGDIR}/${package}/Buildrules"; then error "no rulesfile for package '${package}'" continue @@ -47,134 +45,144 @@ for package in $(echo "${BUILDER_PKGDIR}"/*/*); do load_rules "${package}" - package_make="$(echo "${package}"|tr '/-' '__')" - package_source="${BUILDER_PKGDIR}/${CATEGORY}/${NAME}/source" - package_prep="${BUILDER_TMPDIR}/${CATEGORY}/${NAME}/.prepped" - package_compile="${BUILDER_TMPDIR}/${CATEGORY}/${NAME}/.compiled" - package_archive="${BUILDER_ATFDIR}/${CATEGORY}/${NAME}-${VERSION}-${RELEASE}.${ARCHIVE_FORMAT}" - package_install="${SYSROOT}/var/db/binpkgs/${CATEGORY}/${NAME}" - package_test="${BUILDER_TMPDIR}/${CATEGORY}/${NAME}/.tested" - package_export="${BUILDER_TOPDIR}/exports/${CATEGORY}/${NAME}-${VERSION}-${RELEASE}.${CHOST%%-*}.rpm" - package_logdir="${L}" + makedep_category="$(build_makedeps_name "${CATEGORY}")" + + makedep_target="$(build_makedeps_name "${package}")" + makedep_tmpdir="${BUILDER_TMPDIR}/${package}" + makedep_prep="${makedep_tmpdir}/.prep" + makedep_compile="${makedep_tmpdir}/.compile" + makedep_test="${makedep_tmpdir}/.test" + makedep_source="${BUILDER_PKGDIR}/${package}/source" + makedep_package="${BUILDER_ATFDIR}/${package}-${VERSION}-${RELEASE}.${ARCHIVE_FORMAT}" + makedep_export="${BUILDER_TOPDIR}/exports/${package}-${VERSION}-${RELEASE}.${CHOST%%-*}.rpm" + makedep_install="${SYSROOT}/var/db/binpkgs/${package}" + + # Our entry header with simple rules + cat<<-END_OF_RULES + ## + # ${CATEGORY}/${NAME} - ${DESCRIPTION} + all_all ${makedep_category}_all ${makedep_target}: ${makedep_package} + all_all_source ${makedep_category}_all_source ${makedep_target}_source: ${makedep_source} + all_all_prep ${makedep_category}_all_prep ${makedep_target}_prep: ${makedep_prep} + all_all_compile ${makedep_category}_all_compile ${makedep_target}_compile: ${makedep_compile} + all_all_packge ${makedep_category}_all_package ${makedep_target}_package: ${makedep_package} + all_all_install ${makedep_category}_all_install ${makedep_target}_install: ${makedep_install} + all_all_test ${makedep_category}_all_test ${makedep_target}_test: ${makedep_test} + all_all_export ${makedep_category}_all_export ${makedep_target}_export: ${makedep_export} + END_OF_RULES + + # Add Forward and Reverse depends + for dep in ${BDEPENDS}; do + if ! test -d "${BUILDER_PKGDIR}/${dep}"; then + die "bad BDEPENDS in package '${package}'" + elif ! test -f "${BUILDER_PKGDIR}/${dep}/Buildrules"; then + die "no Buildrules for '${dep}'" + fi + + target="$(build_makedeps_name "${dep}")" + echo "${target}_clean: ${makedep_target}_clean" + echo "${target}_distclean: ${makedep_target}_distclean" + echo "${makedep_prep}: ${SYSROOT}/var/db/binpkgs/${dep}" + done + unset target + unset dep + + for dep in ${RDEPENDS}; do + if ! test -d "${BUILDER_PKGDIR}/${dep}"; then + die "bad RDEPENDS in package '${package}'" + elif ! test -f "${BUILDER_PKGDIR}/${dep}/Buildrules"; then + die "no Buildrules for '${dep}'" + fi + echo "${makedep_install}: ${SYSROOT}/var/db/binpkgs/${dep}" + echo "${makedep_test}: ${BUILDER_TMPDIR}/${dep}/.tested" + done + unset dep - package_sources= + # Depend on updates to 'builder' for index in ".git/modules/scripts" "scripts/.git"; do if test -f "${BUILDER_TOPDIR}/${index}/index"; then - package_sources="${BUILDER_TOPDIR}/${index}/index" + echo "${makedep_prep}: ${BUILDER_TOPDIR}/${index}/index" break fi done + unset index + # Depend on the build rules + echo "${makedep_prep}: ${RULESFILE}" + if test -f "${BUILDER_PKGDIR}/${CATEGORY}/.buildrules"; then + echo "${makedep_prep}: ${BUILDER_PKGDIR}/${CATEGORY}/.buildrules" + fi + + # Depend on included files for config in ${BUILDER_INCLUDED}; do if test -f "${BUILDER_CFGDIR}/${config}"; then die "include does not exist '${file}'" fi - package_sources="${package_sources} ${BUILDER_CFGDIR}/${config}" + echo "${makedep_prep}: ${BUILDER_CFGDIR}/${config}" done unset config + # Depend on extra source files from ${F} for file in ${EXTRA_SOURCES}; do if test -f "${F}/${file}"; then die "file does not exist '${file}'" fi - package_sources="${package_sources} ${F}/${file}" + echo "${makedep_prep}: ${F}/${file}" done unset file - package_sources="${package_sources} ${RULESFILE}" - if test -f "${BUILDER_PKGDIR}/${CATEGORY}/.buildrules"; then - package_sources="${package_sources} ${BUILDER_PKGDIR}/${CATEGORY}/.buildrules" - fi - + # Depend on all listed patches for patch in ${PATCHES}; do patch="${F}/${NAME}-${VERSION}-${patch}.patch" if ! test -f "${patch}"; then die "patch does not exist '${patch}'" fi - package_sources="${package_sources} ${patch}" + echo "${makedep_prep}: ${patch}" done unset patch + # FIXME there can be strange characters in a URI .. this might not be # the best approach in the long term. + PACKAGE_SOURCES= for url in ${SOURCE_URI}; do case "${url}" in # Do not translate local paths into archives in BUILDER_SRCDIR - (file://*|/*) package_sources="${package_sources} ${url##file://}";; + (file://*|/*) PACKAGE_SOURCES="${PACKAGE_SOURCES} ${url##file://}";; # Assume anything else with :// in the name is remote (*://*) pkg_src="$(build-url --archive "${url}")" if test "$?" -ne "0"; then exit 1 fi - package_sources="${package_sources} ${BUILDER_SRCDIR}/${pkg_src}";; + PACKAGE_SOURCES="${PACKAGE_SOURCES} ${BUILDER_SRCDIR}/${pkg_src}";; # Junk? (*) die "do not know how to handle url '${url}'";; esac done + echo "${makedep_source}: ${PACKAGE_SOURCES}" + + if test -e "${makedep_source}"; then + cat<<-EOF + ${makedep_target}_fetch: ${BUILDER_PKGDIR}/${package}/source + EOF + else + cat<<-EOF + ${makedep_prep}: ${PACKAGE_SOURCES} + ${makedep_target}_fetch: ${PACKAGE_SOURCES} + EOF + fi - # This loop can end up being fairly costly if we have to fire up - # build-query, particularly when dealing with a large number of - # packages. So we do some FS level checks first in hopes of avoiding - # it and improving performance. - package_bdeps= - package_tdeps= - for pkg_dep in ${BDEPENDS}; do - if ! test -d "${BUILDER_PKGDIR}/${pkg_dep}"; then - die "bad BDEPENDS in package '${package}'" - elif ! test -f "${BUILDER_PKGDIR}/${pkg_dep}/Buildrules"; then - die "no Buildrules for '${pkg_dep}'" - fi - package_bdeps="${package_bdeps} ${SYSROOT}/var/db/binpkgs/${pkg_dep}" - package_tdeps="${package_tdeps} ${BUILDER_TMPDIR}/${pkg_dep}/work/.tested" - done - - package_rdeps= - for pkg_dep in ${RDEPENDS}; do - if ! test -d "${BUILDER_PKGDIR}/${pkg_dep}"; then - die "bad RDEPENDS in package '${package}'" - elif ! test -f "${BUILDER_PKGDIR}/${pkg_dep}/Buildrules"; then - die "no Buildrules for '${pkg_dep}'" - fi - package_rdeps="${package_rdeps} ${SYSROOT}/var/db/binpkgs/${pkg_dep}" - done - unset pkg_dep - -cat <<EOF - -## -# ${CATEGORY}/${NAME} - ${DESCRIPTION} -${package_make}: ${package_archive} -${package_make}_makedeps: -${package_make}_fetch: ${package_sources} -${package_make}_clean: - @build-make-clean "${CATEGORY}/${NAME}" -${package_make}_distclean: - @build-make-distclean "${CATEGORY}/${NAME}" -${package_make}_prep: ${package_prep} -${package_prep}: ${package_sources} ${package_bdeps} - @build-make-prep "${CATEGORY}/${NAME}" - @date >> "${package_prep}" -${package_make}_compile: ${package_compile} -${package_compile}: ${package_prep} - @build-make-compile "${CATEGORY}/${NAME}" - @date >> "${package_compile}" -${package_make}_package: ${package_archive} -${package_archive}: ${package_compile} - @build-make-package "${CATEGORY}/${NAME}" -${package_make}_install: ${package_install} -${package_install}: ${package_archive} ${package_rdeps} - @build-make-install "${CATEGORY}/${NAME}" -${package_make}_source: ${package_source} -${package_source}: ${package_sources} - @build-make-source "${CATEGORY}/${NAME}" -${package_make}_test: ${package_test} -${package_test}: ${package_tdeps} ${package_install} - @build-make-test "${CATEGORY}/${NAME}" -${package_make}_export: ${package_export} -${package_export}: ${package_install} - @build-make-export "${CATEGORY}/${NAME}" -EOF + ## + # Produce the various build commands + printf "${makedep_prep}:\n\t@build-make-prep '${package}'\n" + printf "${makedep_compile}: ${makedep_prep}\n\t@build-make-compile '${package}'\n" + printf "${makedep_package}: ${makedep_compile}\n\t@build-make-package '${package}'\n" + printf "${makedep_install}: ${makedep_package}\n\t@build-make-install '${package}'\n" + printf "${makedep_test}: ${makedep_install}\n\t@build-make-test '${package}'\n" + printf "${makedep_export}: ${makedep_install}\n\t@build-make-export '${package}'\n" + printf "${makedep_target}_clean:\n\t@build-make-clean '${package}'\n" + printf "${makedep_target}_distclean:\n\t@build-make-distclean '${package}'\n" ## # This is a bit of a fun late-injection of the source archive for a @@ -188,7 +196,6 @@ EOF # All forms of URL translation and variable translation are done for us # by fetch so that makedeps doesn't have any specific expectations on # what the variable name should be. - for url in ${SOURCE_URI}; do case "${url}" in # Do not translate local paths into archives in BUILDER_SRCDIR @@ -206,52 +213,7 @@ EOF esac done - category="$(echo "${CATEGORY}"|tr '/-' '__')" - CATEGORIES="${CATEGORIES} ${category}" - - eval "${category}_SOURCES=\"\${${category}_SOURCES} ${package_sources}\"" - eval "${category}_PACKAGES=\"\${${category}_PACKAGES} ${package_archive}\"" - eval "${category}_INSTALL=\"\${${category}_INSTALL} ${package_install}\"" - eval "${category}_TEST=\"\${${category}_TEST} ${package_test}\"" - eval "${category}_EXPORT=\"\${${category}_EXPORT} ${package_export}\"" - eval "${category}_SOURCE=\"\${${category}_SOURCE} ${package_source}\"" - eval "${category}_CLEAN=\"\${${category}_CLEAN} ${package_make}_clean\"" - eval "${category}_DISTCLEAN=\"\${${category}_DISTCLEAN} ${package_make}_distclean\"" - - PACKAGES_CLEAN="${PACKAGES_CLEAN} ${package_make}_clean" + printf '# End of %s\n\n' "${CATEGORY}/${NAME}" done >> "${BUILDER_MAKEFILE}" -# FIXME It would have been nice to have not inserted the category if it was -# already in the list. -CATEGORIES="$(for CATEGORY in ${CATEGORIES};do echo "${CATEGORY}";done|sort|uniq)" - -for CATEGORY in ${CATEGORIES}; do -cat<<EOF >> "${BUILDER_MAKEFILE}" -${CATEGORY}_all: ${CATEGORY}_archive -${CATEGORY}_all_fetch: $(eval echo "\${${CATEGORY}_SOURCES}") -${CATEGORY}_all_archive: $(eval echo "\${${CATEGORY}_PACKAGES}") -${CATEGORY}_all_install: $(eval echo "\${${CATEGORY}_INSTALL}") -${CATEGORY}_all_test: $(eval echo "\${${CATEGORY}_TEST}") -${CATEGORY}_all_export: $(eval echo "\${${CATEGORY}_EXPORT}") -${CATEGORY}_all_source: $(eval echo "\${${CATEGORY}_SOURCE}") -${CATEGORY}_all_clean: $(eval echo "\${${CATEGORY}_CLEAN}") -${CATEGORY}_all_distclean: $(eval echo "\${${CATEGORY}_DISTCLEAN}") -all_all: ${CATEGORY}_all -all_all_fetch: ${CATEGORY}_all_fetch -all_all_archive: ${CATEGORY}_all_archive -all_all_install: ${CATEGORY}_all_install -all_all_test: ${CATEGORY}_all_test -all_all_export: ${CATEGORY}_all_export -all_all_source: ${CATEGORY}_all_source - -EOF -done - -cat<<EOF >> "${BUILDER_MAKEFILE}" -all_clean: ${PACKAGES_CLEAN} exports_clean -all_distclean: sysroot_clean artifacts_clean tmpdir_clean exports_clean -all_all_distclean: all_distclean -all_all_clean: all_clean -EOF - # vim: filetype=sh |