Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Project import generated by Copybara.
GitOrigin-RevId: 62fbd592bead1a3592c258a3191e3e603b026377
- Loading branch information
0 parents
commit 14cb4e0
Showing
62 changed files
with
10,948 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
/* Copyright (C) 2017 Databricks, Inc. | ||
* | ||
* Portions of this software incorporate or are derived from software contained within Apache Spark, | ||
* and this modified software differs from the Apache Spark software provided under the Apache | ||
* License, Version 2.0, a copy of which you may obtain at | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
*/ | ||
|
||
name := "delta" | ||
|
||
organization := "com.databricks" | ||
|
||
scalaVersion := "2.11.12" | ||
|
||
crossScalaVersions := Seq("2.12.8", "2.11.12") | ||
|
||
libraryDependencies ++= Seq( | ||
"org.apache.spark" %% "spark-hive" % "2.4.0", | ||
"org.scalatest" %% "scalatest" % "3.0.5" % "test", | ||
"org.apache.spark" %% "spark-sql" % "2.4.0" % "test" classifier "tests", | ||
"org.apache.spark" %% "spark-catalyst" % "2.4.0" % "test" classifier "tests", | ||
"org.apache.spark" %% "spark-core" % "2.4.0" % "test" classifier "tests" | ||
) | ||
|
||
// Display full-length stacktraces from ScalaTest: | ||
testOptions in Test += Tests.Argument("-oF") | ||
|
||
scalacOptions ++= Seq("-target:jvm-1.7") | ||
|
||
javacOptions ++= Seq("-source", "1.7", "-target", "1.7") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,158 @@ | ||
#!/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. | ||
# | ||
|
||
# When creating new tests for Spark SQL Hive, the HADOOP_CLASSPATH must contain the hive jars so | ||
# that we can run Hive to generate the golden answer. This is not required for normal development | ||
# or testing. | ||
if [ -n "$HIVE_HOME" ]; then | ||
for i in "$HIVE_HOME"/lib/* | ||
do HADOOP_CLASSPATH="$HADOOP_CLASSPATH:$i" | ||
done | ||
export HADOOP_CLASSPATH | ||
fi | ||
|
||
realpath () { | ||
( | ||
TARGET_FILE="$1" | ||
|
||
cd "$(dirname "$TARGET_FILE")" | ||
TARGET_FILE="$(basename "$TARGET_FILE")" | ||
|
||
COUNT=0 | ||
while [ -L "$TARGET_FILE" -a $COUNT -lt 100 ] | ||
do | ||
TARGET_FILE="$(readlink "$TARGET_FILE")" | ||
cd $(dirname "$TARGET_FILE") | ||
TARGET_FILE="$(basename $TARGET_FILE)" | ||
COUNT=$(($COUNT + 1)) | ||
done | ||
|
||
echo "$(pwd -P)/"$TARGET_FILE"" | ||
) | ||
} | ||
|
||
. "$(dirname "$(realpath "$0")")"/sbt-launch-lib.bash | ||
|
||
|
||
declare -r noshare_opts="-Dsbt.global.base=project/.sbtboot -Dsbt.boot.directory=project/.boot -Dsbt.ivy.home=project/.ivy" | ||
declare -r sbt_opts_file=".sbtopts" | ||
declare -r etc_sbt_opts_file="/etc/sbt/sbtopts" | ||
|
||
usage() { | ||
cat <<EOM | ||
Usage: $script_name [options] | ||
-h | -help print this message | ||
-v | -verbose this runner is chattier | ||
-d | -debug set sbt log level to debug | ||
-no-colors disable ANSI color codes | ||
-sbt-create start sbt even if current directory contains no sbt project | ||
-sbt-dir <path> path to global settings/plugins directory (default: ~/.sbt) | ||
-sbt-boot <path> path to shared boot directory (default: ~/.sbt/boot in 0.11 series) | ||
-ivy <path> path to local Ivy repository (default: ~/.ivy2) | ||
-mem <integer> set memory options (default: $sbt_mem, which is $(get_mem_opts $sbt_mem)) | ||
-no-share use all local caches; no sharing | ||
-no-global uses global caches, but does not use global ~/.sbt directory. | ||
-jvm-debug <port> Turn on JVM debugging, open at the given port. | ||
-batch Disable interactive mode | ||
# sbt version (default: from project/build.properties if present, else latest release) | ||
-sbt-version <version> use the specified version of sbt | ||
-sbt-jar <path> use the specified jar as the sbt launcher | ||
-sbt-rc use an RC version of sbt | ||
-sbt-snapshot use a snapshot version of sbt | ||
# java version (default: java from PATH, currently $(java -version 2>&1 | grep version)) | ||
-java-home <path> alternate JAVA_HOME | ||
# jvm options and output control | ||
JAVA_OPTS environment variable, if unset uses "$java_opts" | ||
SBT_OPTS environment variable, if unset uses "$default_sbt_opts" | ||
.sbtopts if this file exists in the current directory, it is | ||
prepended to the runner args | ||
/etc/sbt/sbtopts if this file exists, it is prepended to the runner args | ||
-Dkey=val pass -Dkey=val directly to the java runtime | ||
-J-X pass option -X directly to the java runtime | ||
(-J is stripped) | ||
-S-X add -X to sbt's scalacOptions (-S is stripped) | ||
-PmavenProfiles Enable a maven profile for the build. | ||
In the case of duplicated or conflicting options, the order above | ||
shows precedence: JAVA_OPTS lowest, command line options highest. | ||
EOM | ||
} | ||
|
||
process_my_args () { | ||
while [[ $# -gt 0 ]]; do | ||
case "$1" in | ||
-no-colors) addJava "-Dsbt.log.noformat=true" && shift ;; | ||
-no-share) addJava "$noshare_opts" && shift ;; | ||
-no-global) addJava "-Dsbt.global.base=$(pwd)/project/.sbtboot" && shift ;; | ||
-sbt-boot) require_arg path "$1" "$2" && addJava "-Dsbt.boot.directory=$2" && shift 2 ;; | ||
-sbt-dir) require_arg path "$1" "$2" && addJava "-Dsbt.global.base=$2" && shift 2 ;; | ||
-debug-inc) addJava "-Dxsbt.inc.debug=true" && shift ;; | ||
-batch) exec </dev/null && shift ;; | ||
|
||
-sbt-create) sbt_create=true && shift ;; | ||
|
||
*) addResidual "$1" && shift ;; | ||
esac | ||
done | ||
|
||
# Now, ensure sbt version is used. | ||
[[ "${sbt_version}XXX" != "XXX" ]] && addJava "-Dsbt.version=$sbt_version" | ||
} | ||
|
||
loadConfigFile() { | ||
cat "$1" | sed '/^\#/d' | ||
} | ||
|
||
# if sbtopts files exist, prepend their contents to $@ so it can be processed by this runner | ||
[[ -f "$etc_sbt_opts_file" ]] && set -- $(loadConfigFile "$etc_sbt_opts_file") "$@" | ||
[[ -f "$sbt_opts_file" ]] && set -- $(loadConfigFile "$sbt_opts_file") "$@" | ||
|
||
exit_status=127 | ||
saved_stty="" | ||
|
||
restoreSttySettings() { | ||
stty $saved_stty | ||
saved_stty="" | ||
} | ||
|
||
onExit() { | ||
if [[ "$saved_stty" != "" ]]; then | ||
restoreSttySettings | ||
fi | ||
exit $exit_status | ||
} | ||
|
||
saveSttySettings() { | ||
saved_stty=$(stty -g 2>/dev/null) | ||
if [[ ! $? ]]; then | ||
saved_stty="" | ||
fi | ||
} | ||
|
||
saveSttySettings | ||
trap onExit INT | ||
|
||
run "$@" | ||
|
||
exit_status=$? | ||
onExit |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,189 @@ | ||
#!/usr/bin/env bash | ||
# | ||
|
||
# A library to simplify using the SBT launcher from other packages. | ||
# Note: This should be used by tools like giter8/conscript etc. | ||
|
||
# TODO - Should we merge the main SBT script with this library? | ||
|
||
if test -z "$HOME"; then | ||
declare -r script_dir="$(dirname "$script_path")" | ||
else | ||
declare -r script_dir="$HOME/.sbt" | ||
fi | ||
|
||
declare -a residual_args | ||
declare -a java_args | ||
declare -a scalac_args | ||
declare -a sbt_commands | ||
declare -a maven_profiles | ||
|
||
if test -x "$JAVA_HOME/bin/java"; then | ||
echo -e "Using $JAVA_HOME as default JAVA_HOME." | ||
echo "Note, this will be overridden by -java-home if it is set." | ||
declare java_cmd="$JAVA_HOME/bin/java" | ||
else | ||
declare java_cmd=java | ||
fi | ||
|
||
echoerr () { | ||
echo 1>&2 "$@" | ||
} | ||
vlog () { | ||
[[ $verbose || $debug ]] && echoerr "$@" | ||
} | ||
dlog () { | ||
[[ $debug ]] && echoerr "$@" | ||
} | ||
|
||
acquire_sbt_jar () { | ||
SBT_VERSION=`awk -F "=" '/sbt\.version/ {print $2}' ./project/build.properties` | ||
URL1=https://dl.bintray.com/typesafe/ivy-releases/org.scala-sbt/sbt-launch/${SBT_VERSION}/sbt-launch.jar | ||
JAR=build/sbt-launch-${SBT_VERSION}.jar | ||
|
||
sbt_jar=$JAR | ||
|
||
if [[ ! -f "$sbt_jar" ]]; then | ||
# Download sbt launch jar if it hasn't been downloaded yet | ||
if [ ! -f "${JAR}" ]; then | ||
# Download | ||
printf "Attempting to fetch sbt\n" | ||
JAR_DL="${JAR}.part" | ||
if [ $(command -v curl) ]; then | ||
curl --fail --location --silent ${URL1} > "${JAR_DL}" &&\ | ||
mv "${JAR_DL}" "${JAR}" | ||
elif [ $(command -v wget) ]; then | ||
wget --quiet ${URL1} -O "${JAR_DL}" &&\ | ||
mv "${JAR_DL}" "${JAR}" | ||
else | ||
printf "You do not have curl or wget installed, please install sbt manually from http://www.scala-sbt.org/\n" | ||
exit -1 | ||
fi | ||
fi | ||
if [ ! -f "${JAR}" ]; then | ||
# We failed to download | ||
printf "Our attempt to download sbt locally to ${JAR} failed. Please install sbt manually from http://www.scala-sbt.org/\n" | ||
exit -1 | ||
fi | ||
printf "Launching sbt from ${JAR}\n" | ||
fi | ||
} | ||
|
||
execRunner () { | ||
# print the arguments one to a line, quoting any containing spaces | ||
[[ $verbose || $debug ]] && echo "# Executing command line:" && { | ||
for arg; do | ||
if printf "%s\n" "$arg" | grep -q ' '; then | ||
printf "\"%s\"\n" "$arg" | ||
else | ||
printf "%s\n" "$arg" | ||
fi | ||
done | ||
echo "" | ||
} | ||
|
||
"$@" | ||
} | ||
|
||
addJava () { | ||
dlog "[addJava] arg = '$1'" | ||
java_args=( "${java_args[@]}" "$1" ) | ||
} | ||
|
||
enableProfile () { | ||
dlog "[enableProfile] arg = '$1'" | ||
maven_profiles=( "${maven_profiles[@]}" "$1" ) | ||
export SBT_MAVEN_PROFILES="${maven_profiles[@]}" | ||
} | ||
|
||
addSbt () { | ||
dlog "[addSbt] arg = '$1'" | ||
sbt_commands=( "${sbt_commands[@]}" "$1" ) | ||
} | ||
addResidual () { | ||
dlog "[residual] arg = '$1'" | ||
residual_args=( "${residual_args[@]}" "$1" ) | ||
} | ||
addDebugger () { | ||
addJava "-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=$1" | ||
} | ||
|
||
# a ham-fisted attempt to move some memory settings in concert | ||
# so they need not be dicked around with individually. | ||
get_mem_opts () { | ||
local mem=${1:-4000} | ||
local perm=$(( $mem / 4 )) | ||
(( $perm > 256 )) || perm=256 | ||
(( $perm < 4096 )) || perm=4096 | ||
local codecache=$(( $perm / 2 )) | ||
|
||
echo "-Xms${mem}m -Xmx${mem}m -XX:ReservedCodeCacheSize=${codecache}m" | ||
} | ||
|
||
require_arg () { | ||
local type="$1" | ||
local opt="$2" | ||
local arg="$3" | ||
if [[ -z "$arg" ]] || [[ "${arg:0:1}" == "-" ]]; then | ||
echo "$opt requires <$type> argument" 1>&2 | ||
exit 1 | ||
fi | ||
} | ||
|
||
is_function_defined() { | ||
declare -f "$1" > /dev/null | ||
} | ||
|
||
process_args () { | ||
while [[ $# -gt 0 ]]; do | ||
case "$1" in | ||
-h|-help) usage; exit 1 ;; | ||
-v|-verbose) verbose=1 && shift ;; | ||
-d|-debug) debug=1 && shift ;; | ||
|
||
-ivy) require_arg path "$1" "$2" && addJava "-Dsbt.ivy.home=$2" && shift 2 ;; | ||
-mem) require_arg integer "$1" "$2" && sbt_mem="$2" && shift 2 ;; | ||
-jvm-debug) require_arg port "$1" "$2" && addDebugger $2 && shift 2 ;; | ||
-batch) exec </dev/null && shift ;; | ||
|
||
-sbt-jar) require_arg path "$1" "$2" && sbt_jar="$2" && shift 2 ;; | ||
-sbt-version) require_arg version "$1" "$2" && sbt_version="$2" && shift 2 ;; | ||
-java-home) require_arg path "$1" "$2" && java_cmd="$2/bin/java" && export JAVA_HOME=$2 && shift 2 ;; | ||
|
||
-D*) addJava "$1" && shift ;; | ||
-J*) addJava "${1:2}" && shift ;; | ||
-P*) enableProfile "$1" && shift ;; | ||
*) addResidual "$1" && shift ;; | ||
esac | ||
done | ||
|
||
is_function_defined process_my_args && { | ||
myargs=("${residual_args[@]}") | ||
residual_args=() | ||
process_my_args "${myargs[@]}" | ||
} | ||
} | ||
|
||
run() { | ||
# no jar? download it. | ||
[[ -f "$sbt_jar" ]] || acquire_sbt_jar "$sbt_version" || { | ||
# still no jar? uh-oh. | ||
echo "Download failed. Obtain the sbt-launch.jar manually and place it at $sbt_jar" | ||
exit 1 | ||
} | ||
|
||
# process the combined args, then reset "$@" to the residuals | ||
process_args "$@" | ||
set -- "${residual_args[@]}" | ||
argumentCount=$# | ||
|
||
# run sbt | ||
execRunner "$java_cmd" \ | ||
${SBT_OPTS:-$default_sbt_opts} \ | ||
$(get_mem_opts $sbt_mem) \ | ||
${java_opts} \ | ||
${java_args[@]} \ | ||
-jar "$sbt_jar" \ | ||
"${sbt_commands[@]}" \ | ||
"${residual_args[@]}" | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# | ||
# 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. | ||
# | ||
sbt.version=0.13.18 |
Oops, something went wrong.