X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/369b6de63a042bd7b0a95a5510f0260a314c2361..9048749c1419cf5e130a4b5d992a2b9c5bafd9cf:/build/run-library.sh diff --git a/build/run-library.sh b/build/run-library.sh index 9140ac1611..01b7c2c9de 100755 --- a/build/run-library.sh +++ b/build/run-library.sh @@ -35,13 +35,19 @@ format_last_commit_here() { version_from_git() { # Generates a version number from the git log for the current working # directory, and writes it to stdout. - local git_ts git_hash + local git_ts git_hash prefix + if [[ -n "$1" ]] ; then + prefix="$1" + else + prefix="0.1" + fi + declare $(format_last_commit_here "git_ts=%ct git_hash=%h") - echo "0.1.$(date -ud "@$git_ts" +%Y%m%d%H%M%S).$git_hash" + echo "${prefix}.$(date -ud "@$git_ts" +%Y%m%d%H%M%S).$git_hash" } nohash_version_from_git() { - version_from_git | cut -d. -f1-3 + version_from_git $1 | cut -d. -f1-3 } timestamp_from_git() { @@ -63,6 +69,10 @@ handle_ruby_gem() { local gem_version="$(nohash_version_from_git)" local gem_src_dir="$(pwd)" + if [[ -n "$ONLY_BUILD" ]] && [[ "$gem_name" != "$ONLY_BUILD" ]] ; then + return 0 + fi + if ! [[ -e "${gem_name}-${gem_version}.gem" ]]; then find -maxdepth 1 -name "${gem_name}-*.gem" -delete @@ -78,6 +88,10 @@ package_go_binary() { local description="$1"; shift local license_file="${1:-agpl-3.0.txt}"; shift + if [[ -n "$ONLY_BUILD" ]] && [[ "$prog" != "$ONLY_BUILD" ]] ; then + return 0 + fi + debug_echo "package_go_binary $src_path as $prog" local basename="${src_path##*/}" @@ -104,12 +118,14 @@ package_go_binary() { declare -a switches=() systemd_unit="$WORKSPACE/${src_path}/${prog}.service" if [[ -e "${systemd_unit}" ]]; then - switches+=("${systemd_unit}=/lib/systemd/system/${prog}.service") - switches+=(--after-install "$WORKSPACE/build/go-package-scripts/postinst") + switches+=( + --after-install "${WORKSPACE}/build/go-python-package-scripts/postinst" + --before-remove "${WORKSPACE}/build/go-python-package-scripts/prerm" + "${systemd_unit}=/lib/systemd/system/${prog}.service") fi - switches+=("$WORKSPACE/$license_file=/usr/share/doc/$prog/$license_file") + switches+=("$WORKSPACE/${license_file}=/usr/share/doc/$prog/${license_file}") - fpm_build "$GOPATH/bin/$basename=/usr/bin/$prog" "$prog" 'Curoverse, Inc.' dir "$version" "--url=https://arvados.org" "--license=GNU Affero General Public License, version 3.0" "--description=$description" "${switches[@]}" + fpm_build "$GOPATH/bin/${basename}=/usr/bin/${prog}" "${prog}" 'Curoverse, Inc.' dir "${version}" "--url=https://arvados.org" "--license=GNU Affero General Public License, version 3.0" "--description=${description}" "${switches[@]}" } default_iteration() { @@ -135,6 +151,11 @@ _build_rails_package_scripts() { handle_rails_package() { local pkgname="$1"; shift + + if [[ -n "$ONLY_BUILD" ]] && [[ "$pkgname" != "$ONLY_BUILD" ]] ; then + return 0 + fi + local srcdir="$1"; shift local license_path="$1"; shift local scripts_dir="$(mktemp --tmpdir -d "$pkgname-XXXXXXXX.scripts")" && \ @@ -200,6 +221,10 @@ fpm_build () { VERSION=$1 shift + if [[ -n "$ONLY_BUILD" ]] && [[ "$PACKAGE_NAME" != "$ONLY_BUILD" ]] && [[ "$PACKAGE" != "$ONLY_BUILD" ]] ; then + return 0 + fi + local default_iteration_value="$(default_iteration "$PACKAGE" "$VERSION")" case "$PACKAGE_TYPE" in @@ -211,6 +236,7 @@ fpm_build () { --python-package-name-prefix "$PYTHON2_PKG_PREFIX" \ --prefix "$PYTHON2_PREFIX" \ --python-install-lib "$PYTHON2_INSTALL_LIB" \ + --python-install-data . \ --exclude "${PYTHON2_INSTALL_LIB#/}/tests" \ --depends "$PYTHON2_PACKAGE" # Fix --iteration for #9242. @@ -227,6 +253,7 @@ fpm_build () { --python-package-name-prefix "$PYTHON3_PKG_PREFIX" \ --prefix "$PYTHON3_PREFIX" \ --python-install-lib "$PYTHON3_INSTALL_LIB" \ + --python-install-data . \ --exclude "${PYTHON3_INSTALL_LIB#/}/tests" \ --depends "$PYTHON3_PACKAGE" # Fix --iteration for #9242. @@ -261,6 +288,14 @@ fpm_build () { # that will take precedence, as desired. COMMAND_ARR+=(--iteration "$default_iteration_value") + if [[ python = "$PACKAGE_TYPE" ]] && [[ -e "${PACKAGE}/${PACKAGE_NAME}.service" ]] + then + COMMAND_ARR+=( + --after-install "${WORKSPACE}/build/go-python-package-scripts/postinst" + --before-remove "${WORKSPACE}/build/go-python-package-scripts/prerm" + ) + fi + # Append --depends X and other arguments specified by fpm-info.sh in # the package source dir. These are added last so they can override # the arguments added by this script. @@ -271,7 +306,7 @@ fpm_build () { declare -a fpm_dirs=( # source dir part of 'dir' package ("/source=/dest" => "/source"): "${PACKAGE%%=/*}" - # backports ("llfuse==0.41.1" => "backports/python-llfuse") + # backports ("llfuse>=1.0" => "backports/python-llfuse") "${WORKSPACE}/backports/${PACKAGE_TYPE}-${PACKAGE%%[<=>]*}") if [[ -n "$PACKAGE_NAME" ]]; then fpm_dirs+=("${WORKSPACE}/backports/${PACKAGE_NAME}")