Files
ChatAI-InGroup/gradlew
2024-09-28 19:10:41 +08:00

235 lines
9.6 KiB
Bash

\\#!/bin/sh
\\#
\\# Copyright © 2015-2021 the original authors.
\\#
\\# Licensed 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
\\#
\\# https://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.
\\#
\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#
\\#
\\# Gradle start up script for POSIX generated by Gradle.
\\#
\\# Important for running:
\\#
\\# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
\\# noncompliant, but you have some other compliant shell such as ksh or
\\# bash, then to run this script, type that shell name before the whole
\\# command line, like:
\\#
\\# ksh Gradle
\\#
\\# Busybox and similar reduced shells will NOT work, because this script
\\# requires all of these POSIX shell features:
\\# * functions;
\\# * expansions «\#[[\#[[\$]]#]]\#var», «\#[[\#[[\$]]#]]\#{var}», «\#[[\#[[\$]]#]]\#{var:-default}», «\#[[\#[[\$]]#]]\#{var+SET}»,
\\# «\#[[\#[[\$]]#]]\#{var\\#prefix}», «\#[[\#[[\$]]#]]\#{var%suffix}», and «\#[[\#[[\$]]#]]\#( cmd )»;
\\# * compound commands having a testable exit status, especially «case»;
\\# * various built-in commands including «command», «set», and «ulimit».
\\#
\\# Important for patching:
\\#
\\# (2) This script targets any POSIX shell, so it avoids extensions provided
\\# by Bash, Ksh, etc; in particular arrays are avoided.
\\#
\\# The "traditional" practice of packing multiple parameters into a
\\# space-separated string is a well documented source of bugs and security
\\# problems, so this is (mostly) avoided, by progressively accumulating
\\# options in "\#[[\#[[\$]]#]]\#@", and eventually passing that to Java.
\\#
\\# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
\\# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
\\# see the in-line comments for details.
\\#
\\# There are tweaks for specific operating systems such as AIX, CygWin,
\\# Darwin, MinGW, and NonStop.
\\#
\\# (3) This script is generated from the Groovy template
\\# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
\\# within the Gradle project.
\\#
\\# You can find Gradle at https://github.com/gradle/gradle/.
\\#
\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#\\#
\\# Attempt to set APP_HOME
\\# Resolve links: \#[[\#[[\$]]#]]\#0 may be a link
app_path=\#[[\#[[\$]]#]]\#0
\\# Need this for daisy-chained symlinks.
while
APP_HOME=\#[[\#[[\$]]#]]\#{app_path%"\#[[\#[[\$]]#]]\#{app_path\\#\\#*/}"} \\# leaves a trailing /; empty if no leading path
[ -h "\#[[\#[[\$]]#]]\#app_path" ]
do
ls=\#[[\#[[\$]]#]]\#( ls -ld "\#[[\#[[\$]]#]]\#app_path" )
link=\#[[\#[[\$]]#]]\#{ls\\#*' -> '}
case \#[[\#[[\$]]#]]\#link in \\#(
/*) app_path=\#[[\#[[\$]]#]]\#link ;; \\#(
*) app_path=\#[[\#[[\$]]#]]\#APP_HOME\#[[\#[[\$]]#]]\#link ;;
esac
done
APP_HOME=\#[[\#[[\$]]#]]\#( cd "\#[[\#[[\$]]#]]\#{APP_HOME:-./}" && pwd -P ) || exit
APP_NAME="Gradle"
APP_BASE_NAME=\#[[\#[[\$]]#]]\#{0\\#\\#*/}
\\# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
\\# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD=maximum
warn () {
echo "\#[[\#[[\$]]#]]\#*"
} >&2
die () {
echo
echo "\#[[\#[[\$]]#]]\#*"
echo
exit 1
} >&2
\\# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
nonstop=false
case "\#[[\#[[\$]]#]]\#( uname )" in \\#(
CYGWIN* ) cygwin=true ;; \\#(
Darwin* ) darwin=true ;; \\#(
MSYS* | MINGW* ) msys=true ;; \\#(
NONSTOP* ) nonstop=true ;;
esac
CLASSPATH=\#[[\#[[\$]]#]]\#APP_HOME/gradle/wrapper/gradle-wrapper.jar
\\# Determine the Java command to use to start the JVM.
if [ -n "\#[[\#[[\$]]#]]\#JAVA_HOME" ] ; then
if [ -x "\#[[\#[[\$]]#]]\#JAVA_HOME/jre/sh/java" ] ; then
\\# IBM's JDK on AIX uses strange locations for the executables
JAVACMD=\#[[\#[[\$]]#]]\#JAVA_HOME/jre/sh/java
else
JAVACMD=\#[[\#[[\$]]#]]\#JAVA_HOME/bin/java
fi
if [ ! -x "\#[[\#[[\$]]#]]\#JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: \#[[\#[[\$]]#]]\#JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD=java
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
\\# Increase the maximum file descriptors if we can.
if ! "\#[[\#[[\$]]#]]\#cygwin" && ! "\#[[\#[[\$]]#]]\#darwin" && ! "\#[[\#[[\$]]#]]\#nonstop" ; then
case \#[[\#[[\$]]#]]\#MAX_FD in \\#(
max*)
MAX_FD=\#[[\#[[\$]]#]]\#( ulimit -H -n ) ||
warn "Could not query maximum file descriptor limit"
esac
case \#[[\#[[\$]]#]]\#MAX_FD in \\#(
'' | soft) :;; \\#(
*)
ulimit -n "\#[[\#[[\$]]#]]\#MAX_FD" ||
warn "Could not set maximum file descriptor limit to \#[[\#[[\$]]#]]\#MAX_FD"
esac
fi
\\# Collect all arguments for the java command, stacking in reverse order:
\\# * args from the command line
\\# * the main class name
\\# * -classpath
\\# * -D...appname settings
\\# * --module-path (only if needed)
\\# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
\\# For Cygwin or MSYS, switch paths to Windows format before running java
if "\#[[\#[[\$]]#]]\#cygwin" || "\#[[\#[[\$]]#]]\#msys" ; then
APP_HOME=\#[[\#[[\$]]#]]\#( cygpath --path --mixed "\#[[\#[[\$]]#]]\#APP_HOME" )
CLASSPATH=\#[[\#[[\$]]#]]\#( cygpath --path --mixed "\#[[\#[[\$]]#]]\#CLASSPATH" )
JAVACMD=\#[[\#[[\$]]#]]\#( cygpath --unix "\#[[\#[[\$]]#]]\#JAVACMD" )
\\# Now convert the arguments - kludge to limit ourselves to /bin/sh
for arg do
if
case \#[[\#[[\$]]#]]\#arg in \\#(
-*) false ;; \\# don't mess with options \\#(
/?*) t=\#[[\#[[\$]]#]]\#{arg\\#/} t=/\#[[\#[[\$]]#]]\#{t%%/*} \\# looks like a POSIX filepath
[ -e "\#[[\#[[\$]]#]]\#t" ] ;; \\#(
*) false ;;
esac
then
arg=\#[[\#[[\$]]#]]\#( cygpath --path --ignore --mixed "\#[[\#[[\$]]#]]\#arg" )
fi
\\# Roll the args list around exactly as many times as the number of
\\# args, so each arg winds up back in the position where it started, but
\\# possibly modified.
\\#
\\# NB: a `for` loop captures its iteration list before it begins, so
\\# changing the positional parameters here affects neither the number of
\\# iterations, nor the values presented in `arg`.
shift \\# remove old arg
set -- "\#[[\#[[\$]]#]]\#@" "\#[[\#[[\$]]#]]\#arg" \\# push replacement arg
done
fi
\\# Collect all arguments for the java command;
\\# * \#[[\#[[\$]]#]]\#DEFAULT_JVM_OPTS, \#[[\#[[\$]]#]]\#JAVA_OPTS, and \#[[\#[[\$]]#]]\#GRADLE_OPTS can contain fragments of
\\# shell script including quotes and variable substitutions, so put them in
\\# double quotes to make sure that they get re-expanded; and
\\# * put everything else in single quotes, so that it's not re-expanded.
set -- \
"-Dorg.gradle.appname=\#[[\#[[\$]]#]]\#APP_BASE_NAME" \
-classpath "\#[[\#[[\$]]#]]\#CLASSPATH" \
org.gradle.wrapper.GradleWrapperMain \
"\#[[\#[[\$]]#]]\#@"
\\# Use "xargs" to parse quoted args.
\\#
\\# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
\\#
\\# In Bash we could simply go:
\\#
\\# readarray ARGS < <( xargs -n1 <<<"\#[[\#[[\$]]#]]\#var" ) &&
\\# set -- "\#[[\#[[\$]]#]]\#{ARGS[@]}" "\#[[\#[[\$]]#]]\#@"
\\#
\\# but POSIX shell has neither arrays nor command substitution, so instead we
\\# post-process each arg (as a line of input to sed) to backslash-escape any
\\# character that might be a shell metacharacter, then use eval to reverse
\\# that process (while maintaining the separation between arguments), and wrap
\\# the whole thing up as a single "set" statement.
\\#
\\# This will of course break if any of these variables contains a newline or
\\# an unmatched quote.
\\#
eval "set -- \#[[\#[[\$]]#]]\#(
printf '%s\n' "\#[[\#[[\$]]#]]\#DEFAULT_JVM_OPTS \#[[\#[[\$]]#]]\#JAVA_OPTS \#[[\#[[\$]]#]]\#GRADLE_OPTS" |
xargs -n1 |
sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
tr '\n' ' '
)" '"\#[[\#[[\$]]#]]\#@"'
exec "\#[[\#[[\$]]#]]\#JAVACMD" "\#[[\#[[\$]]#]]\#@"