#!/usr/bin/env bash # # Licensed to the Apache Software Foundation (ASF) under one or more # contributor license agreements. See the NOTICE file distributed with # this work for additional information regarding copyright ownership. # The ASF licenses this file to You under the Apache License, Version 2.0 # (the "License"); you may not use this file except in compliance with # the License. You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # set -e VALID_VERSIONS=( 2.12 2.13 ) usage() { echo "Usage: $(basename $0) [-h|--help] where : -h| --help Display this help text valid version values : ${VALID_VERSIONS[*]} " 1>&2 exit 1 } if [[ ($# -ne 1) || ( $1 == "--help") || $1 == "-h" ]]; then usage fi TO_VERSION=$1 check_scala_version() { for i in ${VALID_VERSIONS[*]}; do [ $i = "$1" ] && return 0; done echo "Invalid Scala version: $1. Valid versions: ${VALID_VERSIONS[*]}" 1>&2 exit 1 } check_scala_version "$TO_VERSION" if [ $TO_VERSION = "2.13" ]; then FROM_VERSION="2.12" else FROM_VERSION="2.13" fi sed_i() { sed -e "$1" "$2" > "$2.tmp" && mv "$2.tmp" "$2" } BASEDIR=$(dirname $0)/.. for f in $(find "$BASEDIR" -name 'pom.xml' -not -path '*target*'); do echo $f sed_i 's/\(artifactId.*\)_'$FROM_VERSION'/\1_'$TO_VERSION'/g' $f sed_i 's/^\([[:space:]]*\)\(\)/\1\2/' $f sed_i 's/^\([[:space:]]*\)$/\1\)/\1-->\2/' $f done # dependency:get is workaround for SPARK-34762 to download the JAR file of commons-cli. # Without this, build with Scala 2.13 using SBT will fail because the help plugin used below downloads only the POM file. COMMONS_CLI_VERSION=`build/mvn help:evaluate -Dexpression=commons-cli.version -q -DforceStdout` build/mvn dependency:get -Dartifact=commons-cli:commons-cli:${COMMONS_CLI_VERSION} -q # Update in parent POM # First find the right full version from the profile's build SCALA_VERSION=`build/mvn help:evaluate -Pscala-${TO_VERSION} -Dexpression=scala.version -q -DforceStdout` sed_i '1,/[0-9]*\.[0-9]*\.[0-9]*[0-9]*\.[0-9]*\.[0-9]*'$SCALA_VERSION' in parent POM # Match any scala binary version to ensure idempotency sed_i '1,/[0-9]*\.[0-9]*[0-9]*\.[0-9]*'$TO_VERSION'