|
|
#!/bin/sh
|
|
|
# 声明这是一个 shell 脚本,指定使用 /bin/sh 作为解释器
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# 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
|
|
|
#
|
|
|
# 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.
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# 以上是关于该脚本遵循的 Apache 许可证相关信息,说明版权归属、使用条件等
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# Maven2 Start Up Batch script
|
|
|
#
|
|
|
# Required ENV vars:
|
|
|
# ------------------
|
|
|
# JAVA_HOME - location of a JDK home dir
|
|
|
#
|
|
|
# Optional ENV vars
|
|
|
# -----------------
|
|
|
# M2_HOME - location of maven2's installed home dir
|
|
|
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
|
|
|
# e.g. to debug Maven itself, use
|
|
|
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
|
|
|
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# 以上是关于该脚本的描述,说明这是 Maven2 的启动脚本,以及所需和可选的环境变量
|
|
|
|
|
|
if [ -z "$MAVEN_SKIP_RC" ] ; then
|
|
|
# 如果 MAVEN_SKIP_RC 环境变量为空(即未设置)
|
|
|
if [ -f /etc/mavenrc ] ; then
|
|
|
# 如果 /etc/mavenrc 文件存在
|
|
|
. /etc/mavenrc
|
|
|
# 执行 /etc/mavenrc 文件中的命令(通常用于设置环境变量等)
|
|
|
fi
|
|
|
|
|
|
if [ -f "$HOME/.mavenrc" ] ; then
|
|
|
# 如果用户主目录下的 .mavenrc 文件存在
|
|
|
. "$HOME/.mavenrc"
|
|
|
# 执行该文件中的命令
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
# OS specific support. $var _must_ be set to either true or false.
|
|
|
cygwin=false;
|
|
|
# 定义变量 cygwin 并初始化为 false,表示是否是 Cygwin 系统
|
|
|
darwin=false;
|
|
|
# 定义变量 darwin 并初始化为 false,表示是否是 Darwin(Mac OS)系统
|
|
|
mingw=false
|
|
|
# 定义变量 mingw 并初始化为 false,表示是否是 MinGW 系统
|
|
|
case "`uname`" in
|
|
|
# 根据系统的 uname 命令输出进行匹配
|
|
|
CYGWIN*) cygwin=true ;;
|
|
|
# 如果 uname 输出以 CYGWIN 开头,设置 cygwin 为 true
|
|
|
MINGW*) mingw=true;;
|
|
|
# 如果 uname 输出以 MINGW 开头,设置 mingw 为 true
|
|
|
Darwin*) darwin=true
|
|
|
# 如果是 Darwin 系统,设置 darwin 为 true
|
|
|
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
|
|
|
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
if [ -x "/usr/libexec/java_home" ]; then
|
|
|
# 如果 /usr/libexec/java_home 可执行
|
|
|
export JAVA_HOME="`/usr/libexec/java_home`"
|
|
|
# 使用 /usr/libexec/java_home 命令获取 JDK 路径并设置 JAVA_HOME 环境变量
|
|
|
else
|
|
|
export JAVA_HOME="/Library/Java/Home"
|
|
|
# 否则,设置 JAVA_HOME 为默认的 Mac OS 上 Java 安装路径
|
|
|
fi
|
|
|
fi
|
|
|
;;
|
|
|
esac
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
if [ -r /etc/gentoo-release ] ; then
|
|
|
# 如果 /etc/gentoo-release 文件可读(通常在 Gentoo 系统上)
|
|
|
JAVA_HOME=`java-config --jre-home`
|
|
|
# 使用 java-config --jre-home 命令获取 JDK 路径并设置 JAVA_HOME
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ -z "$M2_HOME" ] ; then
|
|
|
# 如果 M2_HOME 环境变量未设置
|
|
|
## resolve links - $0 may be a link to maven's home
|
|
|
PRG="$0"
|
|
|
# 将当前脚本的路径赋值给 PRG 变量
|
|
|
|
|
|
# need this for relative symlinks
|
|
|
while [ -h "$PRG" ] ; do
|
|
|
# 当 PRG 是一个符号链接时
|
|
|
ls=`ls -ld "$PRG"`
|
|
|
# 使用 ls -ld 命令获取符号链接的详细信息并赋值给 ls 变量
|
|
|
link=`expr "$ls" : '.*-> \(.*\)$'`
|
|
|
# 使用 expr 命令从 ls 变量中提取符号链接指向的目标路径并赋值给 link 变量
|
|
|
if expr "$link" : '/.*' > /dev/null; then
|
|
|
# 如果 link 是一个绝对路径
|
|
|
PRG="$link"
|
|
|
# 将 PRG 设置为链接的目标路径
|
|
|
else
|
|
|
PRG="`dirname "$PRG"`/$link"
|
|
|
# 否则,根据当前 PRG 的目录和链接目标计算出完整路径并赋值给 PRG
|
|
|
fi
|
|
|
done
|
|
|
|
|
|
saveddir=`pwd`
|
|
|
# 保存当前工作目录到 saveddir 变量
|
|
|
|
|
|
M2_HOME=`dirname "$PRG"`/..
|
|
|
# 根据 PRG 计算出 Maven 安装目录的路径并赋值给 M2_HOME
|
|
|
|
|
|
# make it fully qualified
|
|
|
M2_HOME=`cd "$M2_HOME" && pwd`
|
|
|
# 进入 M2_HOME 目录并获取其绝对路径,更新 M2_HOME
|
|
|
|
|
|
cd "$saveddir"
|
|
|
# 切换回之前保存的工作目录
|
|
|
|
|
|
# echo Using m2 at $M2_HOME
|
|
|
# (注释掉的行,原本可能用于输出使用的 M2_HOME 路径)
|
|
|
fi
|
|
|
|
|
|
# For Cygwin, ensure paths are in UNIX format before anything is touched
|
|
|
if $cygwin ; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME=`cygpath --unix "$M2_HOME"`
|
|
|
# 如果 M2_HOME 不为空,将其转换为 UNIX 格式路径
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
|
|
|
# 如果 JAVA_HOME 不为空,将其转换为 UNIX 格式路径
|
|
|
[ -n "$CLASSPATH" ] &&
|
|
|
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
|
|
|
# 如果 CLASSPATH 不为空,将其转换为 UNIX 格式路径
|
|
|
fi
|
|
|
|
|
|
# For Mingw, ensure paths are in UNIX format before anything is touched
|
|
|
if $mingw ; then
|
|
|
# 如果是 MinGW 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME="`(cd "$M2_HOME"; pwd)`"
|
|
|
# 如果 M2_HOME 不为空,进入该目录并获取其绝对路径(转换为 UNIX 格式)
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
|
|
|
# 如果 JAVA_HOME 不为空,进入该目录并获取其绝对路径(转换为 UNIX 格式)
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
javaExecutable="`which javac`"
|
|
|
# 使用 which 命令查找 javac 可执行文件的路径并赋值给 javaExecutable 变量
|
|
|
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
|
|
|
# 如果找到了 javac 可执行文件且不是 "no"(即有效路径)
|
|
|
# readlink(1) is not available as standard on Solaris 10.
|
|
|
readLink=`which readlink`
|
|
|
# 使用 which 命令查找 readlink 命令的路径并赋值给 readLink 变量
|
|
|
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
|
|
|
# 如果找到了 readlink 命令且不是 "no"(即有效路径)
|
|
|
if $darwin ; then
|
|
|
# 如果是 Darwin 系统
|
|
|
javaHome="`dirname \"$javaExecutable\"`"
|
|
|
# 获取 javac 可执行文件所在目录并赋值给 javaHome 变量
|
|
|
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
|
|
|
# 进入 javaHome 目录并获取其绝对路径,再加上 javac 文件名,更新 javaExecutable
|
|
|
else
|
|
|
javaExecutable="`readlink -f \"$javaExecutable\"`"
|
|
|
# 否则(非 Darwin 系统),使用 readlink -f 命令获取 javac 可执行文件的绝对路径并更新 javaExecutable
|
|
|
fi
|
|
|
javaHome="`dirname \"$javaExecutable\"`"
|
|
|
# 获取更新后的 javaExecutable 所在目录并赋值给 javaHome 变量
|
|
|
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
|
|
|
# 从 javaHome 变量中提取 bin 目录的上一级目录路径并赋值给 javaHome 变量
|
|
|
JAVA_HOME="$javaHome"
|
|
|
# 将计算出的 JDK 路径设置为 JAVA_HOME 环境变量
|
|
|
export JAVA_HOME
|
|
|
# 导出 JAVA_HOME 环境变量
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVACMD" ] ; then
|
|
|
# 如果 JAVACMD 变量未设置
|
|
|
if [ -n "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量不为空
|
|
|
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
|
# 如果 JAVA_HOME/jre/sh/java 可执行(IBM 的 JDK 在 AIX 上的特殊路径)
|
|
|
JAVACMD="$JAVA_HOME/jre/sh/java"
|
|
|
# 设置 JAVACMD 为该路径
|
|
|
else
|
|
|
JAVACMD="$JAVA_HOME/bin/java"
|
|
|
# 否则,设置 JAVACMD 为标准的 JAVA_HOME/bin/java 路径
|
|
|
fi
|
|
|
else
|
|
|
JAVACMD="`which java`"
|
|
|
# 如果 JAVA_HOME 未设置,使用 which 命令查找 java 可执行文件的路径并设置为 JAVACMD
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ ! -x "$JAVACMD" ] ; then
|
|
|
# 如果 JAVACMD 不是可执行文件
|
|
|
echo "Error: JAVA_HOME is not defined correctly." >&2
|
|
|
# 向标准错误输出流输出错误信息,提示 JAVA_HOME 定义不正确
|
|
|
echo " We cannot execute $JAVACMD" >&2
|
|
|
# 向标准错误输出流输出无法执行 JAVACMD 的信息
|
|
|
exit 1
|
|
|
# 以错误状态码 1 退出脚本
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
echo "Warning: JAVA_HOME environment variable is not set."
|
|
|
# 输出警告信息,提示 JAVA_HOME 环境变量未设置
|
|
|
fi
|
|
|
|
|
|
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
|
|
|
# 设置 CLASSWORLDS_LAUNCHER 变量为指定的类名,用于启动类加载器
|
|
|
|
|
|
# traverses directory structure from process work directory to filesystem root
|
|
|
# first directory with .mvn subdirectory is considered project base directory
|
|
|
find_maven_basedir() {
|
|
|
# 定义函数 find_maven_basedir,用于查找 Maven 项目的基础目录
|
|
|
|
|
|
if [ -z "$1" ]
|
|
|
then
|
|
|
# 如果函数的第一个参数为空
|
|
|
echo "Path not specified to find_maven_basedir"
|
|
|
# 输出错误信息,提示未指定路径
|
|
|
return 1
|
|
|
# 以错误状态码 1 返回
|
|
|
fi
|
|
|
|
|
|
basedir="$1"
|
|
|
# 将函数的第一个参数赋值给 basedir 变量
|
|
|
wdir="$1"
|
|
|
# 将函数的第一个参数赋值给 wdir 变量
|
|
|
while [ "$wdir" != '/' ] ; do
|
|
|
# 当 wdir 不是根目录时
|
|
|
if [ -d "$wdir"/.mvn ] ; then
|
|
|
# 如果 wdir 目录下存在 .mvn 子目录
|
|
|
basedir=$wdir
|
|
|
# 将 basedir 设置为 wdir
|
|
|
break
|
|
|
# 跳出循环
|
|
|
fi
|
|
|
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
|
|
|
if [ -d "${wdir}" ]; then
|
|
|
wdir=`cd "$wdir/.."; pwd`
|
|
|
# 如果 wdir 是一个目录,进入上一级目录并获取其路径,更新 wdir
|
|
|
fi
|
|
|
# end of workaround
|
|
|
done
|
|
|
echo "${basedir}"
|
|
|
# 输出找到的 Maven 项目基础目录路径
|
|
|
}
|
|
|
|
|
|
# concatenates all lines of a file
|
|
|
concat_lines() {
|
|
|
# 定义函数 concat_lines,用于连接文件的所有行
|
|
|
|
|
|
if [ -f "$1" ]; then
|
|
|
# 如果函数的第一个参数是一个文件
|
|
|
echo "$(tr -s '\n' ' ' < "$1")"
|
|
|
# 使用 tr 命令将文件中的换行符替换为空格,并输出连接后的内容
|
|
|
fi
|
|
|
}
|
|
|
|
|
|
BASE_DIR=`find_maven_basedir "$(pwd)"`
|
|
|
# 调用 find_maven_basedir 函数,传入当前工作目录路径,获取 Maven 项目基础目录并赋值给 BASE_DIR 变量
|
|
|
if [ -z "$BASE_DIR" ]; then
|
|
|
# 如果 BASE_DIR 为空
|
|
|
exit 1;
|
|
|
# 以错误状态码 1 退出脚本
|
|
|
fi
|
|
|
|
|
|
##########################################################################################
|
|
|
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
|
|
|
# This allows using the maven wrapper in projects that prohibit checking in binary data.
|
|
|
##########################################################################################
|
|
|
# 以下是关于自动从 Maven 中央仓库下载 maven-wrapper.jar 的扩展部分说明
|
|
|
|
|
|
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
|
|
|
# 如果在 Maven 项目基础目录下的 .mvn/wrapper 目录中存在可读取的 maven-wrapper.jar 文件
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Found .mvn/wrapper/maven-wrapper.jar"
|
|
|
# 输出找到 maven-wrapper.jar 文件的信息
|
|
|
fi
|
|
|
else
|
|
|
# 如果不存在 maven-wrapper.jar 文件
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
|
|
|
# 输出未找到文件并开始下载的信息
|
|
|
fi
|
|
|
if [ -n "$MVNW_REPOURL" ]; then
|
|
|
# 如果 MVNW_REPOURL 环境变量不为空
|
|
|
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.5/maven-wrapper-0.5.5.jar"
|
|
|
# 设置 jarUrl 为指定仓库路径下的 maven-wrapper.jar 文件路径
|
|
|
else
|
|
|
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.5/maven-wrapper-0.5.5.jar"
|
|
|
# 否则,设置 jarUrl 为 Maven 中央仓库的 maven-wrapper.jar 文件路径
|
|
|
fi
|
|
|
while IFS="=" read key value; do
|
|
|
# 按行读取文件内容,以 = 分割为键值对
|
|
|
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
|
|
|
# 如果键为 wrapperUrl,将值赋给 jarUrl 并跳出循环
|
|
|
esac
|
|
|
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
|
|
|
# 从 .mvn/wrapper/maven-wrapper.properties 文件中读取内容进行处理
|
|
|
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Downloading from: $jarUrl"
|
|
|
# 输出从哪个路径下载 maven-wrapper.jar 文件的信息
|
|
|
fi
|
|
|
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
|
|
|
# 设置 wrapperJarPath 为要下载到的本地路径
|
|
|
|
|
|
if $cygwin; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
|
|
|
# 将 wrapperJarPath 转换为 Windows 格式路径
|
|
|
fi
|
|
|
|
|
|
if command -v wget > /dev/null; then
|
|
|
# 如果 wget 命令存在
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Found wget ... using wget"
|
|
|
# 输出找到 wget 命令并将使用它下载的信息
|
|
|
fi
|
|
|
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
|
|
|
# 如果 MVNW_USERNAME 或 MVNW_PASSWORD 环境变量为空
|
|
|
wget "$jarUrl" -O "$wrapperJarPath"
|
|
|
# 使用 wget 命令从 jarUrl 下载文件并保存到 wrapperJarPath
|
|
|
else
|
|
|
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
|
|
|
# 如果有用户名和密码,使用它们进行认证后下载文件
|
|
|
fi
|
|
|
elif command -v curl > /dev/null; then
|
|
|
# 如果 wget 不可用但 curl 命令存在
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Found curl ... using curl"
|
|
|
# 输出找到 curl 命令并将使用它下载的信息
|
|
|
fi
|
|
|
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
|
|
|
# 如果 MVNW_USERNAME 或 MVNW_PASSWORD 环境变量为空
|
|
|
curl -o "$wrapperJarPath" "$jarUrl" -f
|
|
|
# 使用 curl 命令从 jarUrl 下载文件并保存到 wrapperJarPath,-f 表示失败时不显示进度条
|
|
|
else
|
|
|
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
|
|
|
# 如果有用户名和密码,使用它们进行认证后下载文件
|
|
|
fi
|
|
|
else
|
|
|
# 如果 wget 和 curl 都不可用
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Falling back to using Java to download"
|
|
|
# 输出将使用 Java 进行下载的信息
|
|
|
fi
|
|
|
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
|
|
|
# 设置 javaClass 为 MavenWrapperDownloader.java 文件的路径
|
|
|
|
|
|
# For Cygwin, switch paths to Windows format before running javac
|
|
|
if $cygwin; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
javaClass=`cygpath --path --windows "$javaClass"`
|
|
|
# 将 javaClass 路径转换为 Windows 格式
|
|
|
fi
|
|
|
|
|
|
if [ -e "$javaClass" ]; then
|
|
|
# 如果 MavenWrapperDownloader.java 文件存在
|
|
|
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
|
|
|
# 如果 MavenWrapperDownloader.class 文件不存在
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo " - Compiling MavenWrapperDownloader.java ..."
|
|
|
# 输出正在编译 MavenWrapperDownloader.java 文件的信息
|
|
|
fi
|
|
|
# Compiling the Java class
|
|
|
("$JAVA_HOME/bin/javac" "$javaClass")
|
|
|
# 使用 javac 命令编译 MavenWrapperDownloader.java 文件
|
|
|
fi
|
|
|
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
|
|
|
# 如果编译后的 MavenWrapperDownloader.class 文件存在
|
|
|
# Running the downloader
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo " - Running MavenWrapperDownloader.java ..."
|
|
|
# 输出正在运行 MavenWrapperDownloader.java 程序的信息
|
|
|
fi
|
|
|
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
|
|
|
# 使用 java 命令运行编译后的程序进行下载,传入项目基础目录作为参数
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
##########################################################################################
|
|
|
# End of extension
|
|
|
##########################################################################################
|
|
|
# 自动下载 maven-wrapper.jar 扩展部分结束
|
|
|
|
|
|
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
|
|
|
# 导出 MAVEN_PROJECTBASEDIR 环境变量,如果 MAVEN_BASEDIR 未设置,则使用 BASE_DIR 的值
|
|
|
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo $MAVEN_PROJECTBASEDIR
|
|
|
# 输出 MAVEN_PROJECTBASEDIR 的值
|
|
|
fi
|
|
|
|
|
|
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
|
|
|
# 将 MAVEN_PROJECTBASEDIR/.mvn/jvm.config 文件中的内容连接起来,并追加到 MAVEN_OPTS 变量后面
|
|
|
|
|
|
# For Cygwin, switch paths to Windows format before running java
|
|
|
if $cygwin; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME=`cygpath --path --windows "$M2_HOME"`
|
|
|
# 如果 M2_HOME 不为空,将其转换为 Windows 格式路径
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
|
|
|
# 如果 JAVA_HOME 不为空,将其转换为 Windows 格式路径
|
|
|
[ -n "$CLASSPATH" ] &&
|
|
|
CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
|
|
|
# 如果 CLASSPATH 不为空,将其转换为 Windows 格式路径
|
|
|
[ -n "$MAVEN_PROJECTBASEDIR" ] &&
|
|
|
MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
|
|
|
# 如果 MAVEN_PROJECTBASEDIR 不为空,将其转换为 Windows 格式路径
|
|
|
fi
|
|
|
|
|
|
# Provide a "standardized" way to retrieve the CLI args that will
|
|
|
# work with both Windows and non-Windows executions.
|
|
|
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
|
|
|
# 将 MAVEN_CONFIG 变量的值和脚本的所有参数连接起来,赋值给 MAVEN_CMD_LINE_ARGS 变量
|
|
|
export MAVEN_CMD_LINE_ARGS
|
|
|
# 导出 MAVEN_CMD_LINE_ARGS 环境变量
|
|
|
|
|
|
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
|
|
|
# 设置 WRAPPER_LAUNCHER 变量为 Maven 包装器的主类名
|
|
|
|
|
|
exec "$JAVACMD" \
|
|
|
# 执行 Java 命令
|
|
|
$MAVEN_OPTS \
|
|
|
# 传递 MAVEN_OPTS 变量中的参数给 Java 虚拟机
|
|
|
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
|
|
|
# 设置 Java 类路径为 maven-wrapper.jar 文件所在路径
|
|
|
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
|
|
|
# 设置系统属性 maven.home 和 maven.multiModuleProjectDirectory
|
|
|
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"
|
|
|
# 执行 WRAPPER_LAUNCHER 类,并传递 MAVEN_CONFIG 和脚本的所有参数
|
|
|
#!/bin/sh
|
|
|
# 声明这是一个 shell 脚本,指定使用 /bin/sh 作为解释器
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# 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
|
|
|
#
|
|
|
# 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.
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# 以上是关于该脚本遵循的 Apache 许可证相关信息,说明版权归属、使用条件等
|
|
|
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# Maven2 Start Up Batch script
|
|
|
#
|
|
|
# Required ENV vars:
|
|
|
# ------------------
|
|
|
# JAVA_HOME - location of a JDK home dir
|
|
|
#
|
|
|
# Optional ENV vars
|
|
|
# -----------------
|
|
|
# M2_HOME - location of maven2's installed home dir
|
|
|
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
|
|
|
# e.g. to debug Maven itself, use
|
|
|
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
|
|
|
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
|
|
|
# ----------------------------------------------------------------------------
|
|
|
# 以上是关于该脚本的描述,说明这是 Maven2 的启动脚本,以及所需和可选的环境变量
|
|
|
|
|
|
if [ -z "$MAVEN_SKIP_RC" ] ; then
|
|
|
# 如果 MAVEN_SKIP_RC 环境变量为空(即未设置)
|
|
|
if [ -f /etc/mavenrc ] ; then
|
|
|
# 如果 /etc/mavenrc 文件存在
|
|
|
. /etc/mavenrc
|
|
|
# 执行 /etc/mavenrc 文件中的命令(通常用于设置环境变量等,以配置 Maven 相关运行参数)
|
|
|
fi
|
|
|
|
|
|
if [ -f "$HOME/.mavenrc" ] ; then
|
|
|
# 如果用户主目录下的 .mavenrc 文件存在
|
|
|
. "$HOME/.mavenrc"
|
|
|
# 执行该文件中的命令,进一步配置 Maven 运行相关的环境或参数
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
# OS specific support. $var _must_ be set to either true or false.
|
|
|
cygwin=false;
|
|
|
# 定义变量 cygwin 并初始化为 false,表示当前系统是否是 Cygwin 系统(Cygwin 是一个在 Windows 上模拟 Unix 环境的软件)
|
|
|
darwin=false;
|
|
|
# 定义变量 darwin 并初始化为 false,表示当前系统是否是 Darwin(Mac OS)系统
|
|
|
mingw=false
|
|
|
# 定义变量 mingw 并初始化为 false,表示当前系统是否是 MinGW 系统(MinGW 是在 Windows 上提供一套开源的开发工具集)
|
|
|
case "`uname`" in
|
|
|
# 根据系统的 uname 命令输出(获取系统名称)进行匹配
|
|
|
CYGWIN*) cygwin=true ;;
|
|
|
# 如果 uname 输出以 CYGWIN 开头,设置 cygwin 为 true,表明当前系统是 Cygwin 环境
|
|
|
MINGW*) mingw=true;;
|
|
|
# 如果 uname 输出以 MINGW 开头,设置 mingw 为 true,表明当前系统是 MinGW 环境
|
|
|
Darwin*) darwin=true
|
|
|
# 如果是 Darwin 系统,设置 darwin 为 true
|
|
|
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
|
|
|
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
if [ -x "/usr/libexec/java_home" ]; then
|
|
|
# 如果 /usr/libexec/java_home 可执行(该命令可用于获取系统上可用的 JDK 路径)
|
|
|
export JAVA_HOME="`/usr/libexec/java_home`"
|
|
|
# 使用 /usr/libexec/java_home 命令获取 JDK 路径并设置 JAVA_HOME 环境变量
|
|
|
else
|
|
|
export JAVA_HOME="/Library/Java/Home"
|
|
|
# 否则,设置 JAVA_HOME 为默认的 Mac OS 上 Java 安装路径(常见的默认路径)
|
|
|
fi
|
|
|
fi
|
|
|
;;
|
|
|
esac
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
if [ -r /etc/gentoo-release ] ; then
|
|
|
# 如果 /etc/gentoo-release 文件可读(在 Gentoo Linux 系统中,该文件标识系统版本等信息)
|
|
|
JAVA_HOME=`java-config --jre-home`
|
|
|
# 使用 java-config --jre-home 命令获取 JDK 路径并设置 JAVA_HOME(适用于 Gentoo 系统获取 JDK 路径的方式)
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ -z "$M2_HOME" ] ; then
|
|
|
# 如果 M2_HOME 环境变量未设置
|
|
|
## resolve links - $0 may be a link to maven's home
|
|
|
PRG="$0"
|
|
|
# 将当前脚本的路径赋值给 PRG 变量,$0 在 shell 中表示脚本本身的名称或路径
|
|
|
# need this for relative symlinks
|
|
|
while [ -h "$PRG" ] ; do
|
|
|
# 当 PRG 是一个符号链接时(-h 用于判断是否为符号链接)
|
|
|
ls=`ls -ld "$PRG"`
|
|
|
# 使用 ls -ld 命令获取符号链接的详细信息并赋值给 ls 变量,包括链接指向的目标等信息
|
|
|
link=`expr "$ls" : '.*-> \(.*\)$'`
|
|
|
# 使用 expr 命令从 ls 变量中提取符号链接指向的目标路径并赋值给 link 变量,通过正则表达式匹配提取链接目标
|
|
|
if expr "$link" : '/.*' > /dev/null; then
|
|
|
# 如果 link 是一个绝对路径(通过判断路径是否以 / 开头来确定是否为绝对路径)
|
|
|
PRG="$link"
|
|
|
# 将 PRG 设置为链接的目标路径,更新 PRG 为实际的路径
|
|
|
else
|
|
|
PRG="`dirname "$PRG"`/$link"
|
|
|
# 否则,根据当前 PRG 的目录和链接目标计算出完整路径并赋值给 PRG,拼接得到实际路径
|
|
|
fi
|
|
|
done
|
|
|
|
|
|
saveddir=`pwd`
|
|
|
# 保存当前工作目录到 saveddir 变量,pwd 命令用于获取当前工作目录路径
|
|
|
M2_HOME=`dirname "$PRG"`/..
|
|
|
# 根据 PRG 计算出 Maven 安装目录的路径并赋值给 M2_HOME,取 PRG 的目录的上一级目录作为 Maven 安装目录
|
|
|
# make it fully qualified
|
|
|
M2_HOME=`cd "$M2_HOME" && pwd`
|
|
|
# 进入 M2_HOME 目录并获取其绝对路径,cd 命令进入目录,pwd 命令获取当前目录路径,更新 M2_HOME 为绝对路径
|
|
|
cd "$saveddir"
|
|
|
# 切换回之前保存的工作目录,恢复之前的工作目录状态
|
|
|
# echo Using m2 at $M2_HOME
|
|
|
# (注释掉的行,原本可能用于输出使用的 M2_HOME 路径,调试或信息展示用途)
|
|
|
fi
|
|
|
|
|
|
# For Cygwin, ensure paths are in UNIX format before anything is touched
|
|
|
if $cygwin ; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME=`cygpath --unix "$M2_HOME"`
|
|
|
# 如果 M2_HOME 不为空(-n 判断变量是否为空字符串),将其转换为 UNIX 格式路径,cygpath 用于转换 Cygwin 路径格式
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
|
|
|
# 如果 JAVA_HOME 不为空,将其转换为 UNIX 格式路径
|
|
|
[ -n "$CLASSPATH" ] &&
|
|
|
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
|
|
|
# 如果 CLASSPATH 不为空,将其转换为 UNIX 格式路径,确保路径格式符合 Cygwin 下的 UNIX 环境要求
|
|
|
fi
|
|
|
|
|
|
# For Mingw, ensure paths are in UNIX format before anything is touched
|
|
|
if $mingw ; then
|
|
|
# 如果是 MinGW 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME="`(cd "$M2_HOME"; pwd)`"
|
|
|
# 如果 M2_HOME 不为空,进入该目录并获取其绝对路径(转换为 UNIX 格式),通过 cd 和 pwd 命令组合实现
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
|
|
|
# 如果 JAVA_HOME 不为空,进入该目录并获取其绝对路径(转换为 UNIX 格式)
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
javaExecutable="`which javac`"
|
|
|
# 使用 which 命令查找 javac 可执行文件的路径并赋值给 javaExecutable 变量,which 用于在系统路径中查找命令的可执行文件位置
|
|
|
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
|
|
|
# 如果找到了 javac 可执行文件且不是 "no"(即有效路径,排除 which 未找到时输出的错误标识)
|
|
|
# readlink(1) is not available as standard on Solaris 10.
|
|
|
readLink=`which readlink`
|
|
|
# 使用 which 命令查找 readlink 命令的路径并赋值给 readLink 变量,readlink 用于获取符号链接指向的实际路径
|
|
|
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
|
|
|
# 如果找到了 readlink 命令且不是 "no"(即有效路径)
|
|
|
if $darwin ; then
|
|
|
# 如果是 Darwin 系统
|
|
|
javaHome="`dirname \"$javaExecutable\"`"
|
|
|
# 获取 javac 可执行文件所在目录并赋值给 javaHome 变量,dirname 用于获取路径的目录部分
|
|
|
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
|
|
|
# 进入 javaHome 目录并获取其绝对路径(-P 选项用于获取物理路径,不包含符号链接),再加上 javac 文件名,更新 javaExecutable 为绝对路径的 javac 可执行文件
|
|
|
else
|
|
|
javaExecutable="`readlink -f \"$javaExecutable\"`"
|
|
|
# 否则(非 Darwin 系统),使用 readlink -f 命令获取 javac 可执行文件的绝对路径并更新 javaExecutable,-f 选项用于获取符号链接的最终目标路径
|
|
|
fi
|
|
|
javaHome="`dirname \"$javaExecutable\"`"
|
|
|
# 获取更新后的 javaExecutable 所在目录并赋值给 javaHome 变量
|
|
|
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
|
|
|
# 从 javaHome 变量中提取 bin 目录的上一级目录路径并赋值给 javaHome 变量,通过正则表达式匹配提取路径部分
|
|
|
JAVA_HOME="$javaHome"
|
|
|
# 将计算出的 JDK 路径设置为 JAVA_HOME 环境变量
|
|
|
export JAVA_HOME
|
|
|
# 导出 JAVA_HOME 环境变量,使其在后续的子进程中也能使用
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVACMD" ] ; then
|
|
|
# 如果 JAVACMD 变量未设置
|
|
|
if [ -n "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量不为空
|
|
|
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
|
# 如果 JAVA_HOME/jre/sh/java 可执行(IBM 的 JDK 在 AIX 上的特殊路径下的 java 可执行文件)
|
|
|
JAVACMD="$JAVA_HOME/jre/sh/java"
|
|
|
# 设置 JAVACMD 为该路径,指定用于运行 Java 程序的命令路径
|
|
|
else
|
|
|
JAVACMD="$JAVA_HOME/bin/java"
|
|
|
# 否则,设置 JAVACMD 为标准的 JAVA_HOME/bin/java 路径,这是常见的 Java 可执行文件路径
|
|
|
fi
|
|
|
else
|
|
|
JAVACMD="`which java`"
|
|
|
# 如果 JAVA_HOME 未设置,使用 which 命令查找 java 可执行文件的路径并设置为 JAVACMD,在系统路径中查找默认的 java 可执行文件
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ ! -x "$JAVACMD" ] ; then
|
|
|
# 如果 JAVACMD 不是可执行文件(-x 判断文件是否可执行)
|
|
|
echo "Error: JAVA_HOME is not defined correctly." >&2
|
|
|
# 向标准错误输出流输出错误信息,提示 JAVA_HOME 定义不正确,>&2 表示输出到标准错误流
|
|
|
echo " We cannot execute $JAVACMD" >&2
|
|
|
# 向标准错误输出流输出无法执行 JAVACMD 的信息
|
|
|
exit 1
|
|
|
# 以错误状态码 1 退出脚本,表示脚本执行出现错误
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
echo "Warning: JAVA_HOME environment variable is not set."
|
|
|
# 输出警告信息,提示 JAVA_HOME 环境变量未设置,可能会影响程序的正确运行
|
|
|
fi
|
|
|
|
|
|
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
|
|
|
# 设置 CLASSWORLDS_LAUNCHER 变量为指定的类名,用于指定使用 org.codehaus.plexus.classworlds.launcher.Launcher 类来启动类加载器,这是 Maven 中用于管理类加载的一种机制
|
|
|
|
|
|
# traverses directory structure from process work directory to filesystem root
|
|
|
# first directory with .mvn subdirectory is considered project base directory
|
|
|
find_maven_basedir() {
|
|
|
# 定义函数 find_maven_basedir,用于查找 Maven 项目的基础目录
|
|
|
# 函数从当前进程的工作目录开始,向上遍历目录结构直到文件系统根目录,找到第一个包含.mvn 子目录的目录作为项目基础目录
|
|
|
|
|
|
if [ -z "$1" ]
|
|
|
then
|
|
|
# 如果函数的第一个参数为空($1 表示函数的第一个参数)
|
|
|
echo "Path not specified to find_maven_basedir"
|
|
|
# 输出错误信息,提示未指定路径给 find_maven_basedir 函数
|
|
|
return 1
|
|
|
# 以错误状态码 1 返回,表示函数执行失败
|
|
|
fi
|
|
|
|
|
|
basedir="$1"
|
|
|
# 将函数的第一个参数赋值给 basedir 变量,作为起始查找的目录
|
|
|
wdir="$1"
|
|
|
# 将函数的第一个参数赋值给 wdir 变量,用于在循环中逐步向上遍历目录
|
|
|
while [ "$wdir" != '/' ] ; do
|
|
|
# 当 wdir 不是根目录时(循环条件,直到遍历到根目录为止)
|
|
|
if [ -d "$wdir"/.mvn ] ; then
|
|
|
# 如果 wdir 目录下存在 .mvn 子目录(-d 判断是否为目录)
|
|
|
basedir=$wdir
|
|
|
# 将 basedir 设置为 wdir,即找到了包含.mvn 子目录的目录,作为项目基础目录
|
|
|
break
|
|
|
# 跳出循环,不再继续向上遍历
|
|
|
fi
|
|
|
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
|
|
|
if [ -d "${wdir}" ]; then
|
|
|
wdir=`cd "$wdir/.."; pwd`
|
|
|
# 如果 wdir 是一个目录,进入上一级目录并获取其路径,更新 wdir 为上一级目录路径,这是一个针对 Solaris 10/Sparc 系统的特定处理(解决某些问题的变通方法)
|
|
|
fi
|
|
|
# end of workaround
|
|
|
done
|
|
|
echo "${basedir}"
|
|
|
# 输出找到的 Maven 项目基础目录路径
|
|
|
}
|
|
|
|
|
|
# concatenates all lines of a file
|
|
|
concat_lines() {
|
|
|
# 定义函数 concat_lines,用于将文件的所有行连接成一行字符串
|
|
|
|
|
|
if [ -f "$1" ]; then
|
|
|
# 如果函数的第一个参数是一个文件(-f 判断是否为文件)
|
|
|
echo "$(tr -s '\n' ' ' < "$1")"
|
|
|
# 使用 tr 命令将文件中的换行符 '\n' 替换为空格 ' ',-s 选项用于压缩连续的多个换行符为一个空格,< "$1" 表示从文件中读取内容,然后输出连接后的内容
|
|
|
fi
|
|
|
}
|
|
|
|
|
|
BASE_DIR=`find_maven_basedir "$(pwd)"`
|
|
|
# 调用 find_maven_basedir 函数,传入当前工作目录路径(通过 pwd 命令获取),获取 Maven 项目基础目录并赋值给 BASE_DIR 变量
|
|
|
if [ -z "$BASE_DIR" ]; then
|
|
|
# 如果 BASE_DIR 为空(即未找到合适的项目基础目录)
|
|
|
exit 1;
|
|
|
# 以错误状态码 1 退出脚本,表示脚本执行失败,因为无法确定 Maven 项目基础目录
|
|
|
fi
|
|
|
|
|
|
##########################################################################################
|
|
|
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
|
|
|
# This allows using the maven
|
|
|
|
|
|
# OS specific support. $var _must_ be set to either true or false.
|
|
|
cygwin=false;
|
|
|
# 定义变量 cygwin 并初始化为 false,表示是否是 Cygwin 系统
|
|
|
darwin=false;
|
|
|
# 定义变量 darwin 并初始化为 false,表示是否是 Darwin(Mac OS)系统
|
|
|
mingw=false
|
|
|
# 定义变量 mingw 并初始化为 false,表示是否是 MinGW 系统
|
|
|
case "`uname`" in
|
|
|
# 根据系统的 uname 命令输出进行匹配
|
|
|
CYGWIN*) cygwin=true ;;
|
|
|
# 如果 uname 输出以 CYGWIN 开头,设置 cygwin 为 true
|
|
|
MINGW*) mingw=true;;
|
|
|
# 如果 uname 输出以 MINGW 开头,设置 mingw 为 true
|
|
|
Darwin*) darwin=true
|
|
|
# 如果是 Darwin 系统,设置 darwin 为 true
|
|
|
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
|
|
|
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
if [ -x "/usr/libexec/java_home" ]; then
|
|
|
# 如果 /usr/libexec/java_home 可执行
|
|
|
export JAVA_HOME="`/usr/libexec/java_home`"
|
|
|
# 使用 /usr/libexec/java_home 命令获取 JDK 路径并设置 JAVA_HOME 环境变量
|
|
|
else
|
|
|
export JAVA_HOME="/Library/Java/Home"
|
|
|
# 否则,设置 JAVA_HOME 为默认的 Mac OS 上 Java 安装路径
|
|
|
fi
|
|
|
fi
|
|
|
;;
|
|
|
esac
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
if [ -r /etc/gentoo-release ] ; then
|
|
|
# 如果 /etc/gentoo-release 文件可读(通常在 Gentoo 系统上)
|
|
|
JAVA_HOME=`java-config --jre-home`
|
|
|
# 使用 java-config --jre-home 命令获取 JDK 路径并设置 JAVA_HOME
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ -z "$M2_HOME" ] ; then
|
|
|
# 如果 M2_HOME 环境变量未设置
|
|
|
## resolve links - $0 may be a link to maven's home
|
|
|
PRG="$0"
|
|
|
# 将当前脚本的路径赋值给 PRG 变量
|
|
|
|
|
|
# need this for relative symlinks
|
|
|
while [ -h "$PRG" ] ; do
|
|
|
# 当 PRG 是一个符号链接时
|
|
|
ls=`ls -ld "$PRG"`
|
|
|
# 使用 ls -ld 命令获取符号链接的详细信息并赋值给 ls 变量
|
|
|
link=`expr "$ls" : '.*-> \(.*\)$'`
|
|
|
# 使用 expr 命令从 ls 变量中提取符号链接指向的目标路径并赋值给 link 变量
|
|
|
if expr "$link" : '/.*' > /dev/null; then
|
|
|
# 如果 link 是一个绝对路径
|
|
|
PRG="$link"
|
|
|
# 将 PRG 设置为链接的目标路径
|
|
|
else
|
|
|
PRG="`dirname "$PRG"`/$link"
|
|
|
# 否则,根据当前 PRG 的目录和链接目标计算出完整路径并赋值给 PRG
|
|
|
fi
|
|
|
done
|
|
|
|
|
|
saveddir=`pwd`
|
|
|
# 保存当前工作目录到 saveddir 变量
|
|
|
|
|
|
M2_HOME=`dirname "$PRG"`/..
|
|
|
# 根据 PRG 计算出 Maven 安装目录的路径并赋值给 M2_HOME
|
|
|
|
|
|
# make it fully qualified
|
|
|
M2_HOME=`cd "$M2_HOME" && pwd`
|
|
|
# 进入 M2_HOME 目录并获取其绝对路径,更新 M2_HOME
|
|
|
|
|
|
cd "$saveddir"
|
|
|
# 切换回之前保存的工作目录
|
|
|
|
|
|
# echo Using m2 at $M2_HOME
|
|
|
# (注释掉的行,原本可能用于输出使用的 M2_HOME 路径)
|
|
|
fi
|
|
|
|
|
|
# For Cygwin, ensure paths are in UNIX format before anything is touched
|
|
|
if $cygwin ; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME=`cygpath --unix "$M2_HOME"`
|
|
|
# 如果 M2_HOME 不为空,将其转换为 UNIX 格式路径
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME=`cygpath --unix "$JAVA_HOME"`
|
|
|
# 如果 JAVA_HOME 不为空,将其转换为 UNIX 格式路径
|
|
|
[ -n "$CLASSPATH" ] &&
|
|
|
CLASSPATH=`cygpath --path --unix "$CLASSPATH"`
|
|
|
# 如果 CLASSPATH 不为空,将其转换为 UNIX 格式路径
|
|
|
fi
|
|
|
|
|
|
# For Mingw, ensure paths are in UNIX format before anything is touched
|
|
|
if $mingw ; then
|
|
|
# 如果是 MinGW 系统
|
|
|
[ -n "$M2_HOME" ] &&
|
|
|
M2_HOME="`(cd "$M2_HOME"; pwd)`"
|
|
|
# 如果 M2_HOME 不为空,进入该目录并获取其绝对路径(转换为 UNIX 格式)
|
|
|
[ -n "$JAVA_HOME" ] &&
|
|
|
JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`"
|
|
|
# 如果 JAVA_HOME 不为空,进入该目录并获取其绝对路径(转换为 UNIX 格式)
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ]; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
javaExecutable="`which javac`"
|
|
|
# 使用 which 命令查找 javac 可执行文件的路径并赋值给 javaExecutable 变量
|
|
|
if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then
|
|
|
# 如果找到了 javac 可执行文件且不是 "no"(即有效路径)
|
|
|
# readlink(1) is not available as standard on Solaris 10.
|
|
|
readLink=`which readlink`
|
|
|
# 使用 which 命令查找 readlink 命令的路径并赋值给 readLink 变量
|
|
|
if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then
|
|
|
# 如果找到了 readlink 命令且不是 "no"(即有效路径)
|
|
|
if $darwin ; then
|
|
|
# 如果是 Darwin 系统
|
|
|
javaHome="`dirname \"$javaExecutable\"`"
|
|
|
# 获取 javac 可执行文件所在目录并赋值给 javaHome 变量
|
|
|
javaExecutable="`cd \"$javaHome\" && pwd -P`/javac"
|
|
|
# 进入 javaHome 目录并获取其绝对路径,再加上 javac 文件名,更新 javaExecutable
|
|
|
else
|
|
|
javaExecutable="`readlink -f \"$javaExecutable\"`"
|
|
|
# 否则(非 Darwin 系统),使用 readlink -f 命令获取 javac 可执行文件的绝对路径并更新 javaExecutable
|
|
|
fi
|
|
|
javaHome="`dirname \"$javaExecutable\"`"
|
|
|
# 获取更新后的 javaExecutable 所在目录并赋值给 javaHome 变量
|
|
|
javaHome=`expr "$javaHome" : '\(.*\)/bin'`
|
|
|
# 从 javaHome 变量中提取 bin 目录的上一级目录路径并赋值给 javaHome 变量
|
|
|
JAVA_HOME="$javaHome"
|
|
|
# 将计算出的 JDK 路径设置为 JAVA_HOME 环境变量
|
|
|
export JAVA_HOME
|
|
|
# 导出 JAVA_HOME 环境变量
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVACMD" ] ; then
|
|
|
# 如果 JAVACMD 变量未设置
|
|
|
if [ -n "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量不为空
|
|
|
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
|
|
# 如果 JAVA_HOME/jre/sh/java 可执行(IBM 的 JDK 在 AIX 上的特殊路径)
|
|
|
JAVACMD="$JAVA_HOME/jre/sh/java"
|
|
|
# 设置 JAVACMD 为该路径
|
|
|
else
|
|
|
JAVACMD="$JAVA_HOME/bin/java"
|
|
|
# 否则,设置 JAVACMD 为标准的 JAVA_HOME/bin/java 路径
|
|
|
fi
|
|
|
else
|
|
|
JAVACMD="`which java`"
|
|
|
# 如果 JAVA_HOME 未设置,使用 which 命令查找 java 可执行文件的路径并设置为 JAVACMD
|
|
|
fi
|
|
|
fi
|
|
|
|
|
|
if [ ! -x "$JAVACMD" ] ; then
|
|
|
# 如果 JAVACMD 不是可执行文件
|
|
|
echo "Error: JAVA_HOME is not defined correctly." >&2
|
|
|
# 向标准错误输出流输出错误信息,提示 JAVA_HOME 定义不正确
|
|
|
echo " We cannot execute $JAVACMD" >&2
|
|
|
# 向标准错误输出流输出无法执行 JAVACMD 的信息
|
|
|
exit 1
|
|
|
# 以错误状态码 1 退出脚本
|
|
|
fi
|
|
|
|
|
|
if [ -z "$JAVA_HOME" ] ; then
|
|
|
# 如果 JAVA_HOME 环境变量未设置
|
|
|
echo "Warning: JAVA_HOME environment variable is not set."
|
|
|
# 输出警告信息,提示 JAVA_HOME 环境变量未设置
|
|
|
fi
|
|
|
|
|
|
CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher
|
|
|
# 设置 CLASSWORLDS_LAUNCHER 变量为指定的类名,用于启动类加载器
|
|
|
|
|
|
# traverses directory structure from process work directory to filesystem root
|
|
|
# first directory with .mvn subdirectory is considered project base directory
|
|
|
find_maven_basedir() {
|
|
|
# 定义函数 find_maven_basedir,用于查找 Maven 项目的基础目录
|
|
|
|
|
|
if [ -z "$1" ]
|
|
|
then
|
|
|
# 如果函数的第一个参数为空
|
|
|
echo "Path not specified to find_maven_basedir"
|
|
|
# 输出错误信息,提示未指定路径
|
|
|
return 1
|
|
|
# 以错误状态码 1 返回
|
|
|
fi
|
|
|
|
|
|
basedir="$1"
|
|
|
# 将函数的第一个参数赋值给 basedir 变量
|
|
|
wdir="$1"
|
|
|
# 将函数的第一个参数赋值给 wdir 变量
|
|
|
while [ "$wdir" != '/' ] ; do
|
|
|
# 当 wdir 不是根目录时
|
|
|
if [ -d "$wdir"/.mvn ] ; then
|
|
|
# 如果 wdir 目录下存在 .mvn 子目录
|
|
|
basedir=$wdir
|
|
|
# 将 basedir 设置为 wdir
|
|
|
break
|
|
|
# 跳出循环
|
|
|
fi
|
|
|
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
|
|
|
if [ -d "${wdir}" ]; then
|
|
|
wdir=`cd "$wdir/.."; pwd`
|
|
|
# 如果 wdir 是一个目录,进入上一级目录并获取其路径,更新 wdir
|
|
|
fi
|
|
|
# end of workaround
|
|
|
done
|
|
|
echo "${basedir}"
|
|
|
# 输出找到的 Maven 项目基础目录路径
|
|
|
}
|
|
|
|
|
|
# concatenates all lines of a file
|
|
|
concat_lines() {
|
|
|
# 定义函数 concat_lines,用于连接文件的所有行
|
|
|
|
|
|
if [ -f "$1" ]; then
|
|
|
# 如果函数的第一个参数是一个文件
|
|
|
echo "$(tr -s '\n' ' ' < "$1")"
|
|
|
# 使用 tr 命令将文件中的换行符替换为空格,并输出连接后的内容
|
|
|
fi
|
|
|
}
|
|
|
|
|
|
BASE_DIR=`find_maven_basedir "$(pwd)"`
|
|
|
# 调用 find_maven_basedir 函数,传入当前工作目录路径,获取 Maven 项目基础目录并赋值给 BASE_DIR 变量
|
|
|
if [ -z "$BASE_DIR" ]; then
|
|
|
# 如果 BASE_DIR 为空
|
|
|
exit 1;
|
|
|
# 以错误状态码 1 退出脚本
|
|
|
fi
|
|
|
|
|
|
##########################################################################################
|
|
|
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
|
|
|
# This allows using the maven wrapper in projects that prohibit checking in binary data.
|
|
|
##########################################################################################
|
|
|
# 以下是关于自动从 Maven 中央仓库下载 maven-wrapper.jar 的扩展部分说明
|
|
|
|
|
|
if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then
|
|
|
# 如果在 Maven 项目基础目录下的 .mvn/wrapper 目录中存在可读取的 maven-wrapper.jar 文件
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Found .mvn/wrapper/maven-wrapper.jar"
|
|
|
# 输出找到 maven-wrapper.jar 文件的信息
|
|
|
fi
|
|
|
else
|
|
|
# 如果不存在 maven-wrapper.jar 文件
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
|
|
|
# 输出未找到文件并开始下载的信息
|
|
|
fi
|
|
|
if [ -n "$MVNW_REPOURL" ]; then
|
|
|
# 如果 MVNW_REPOURL 环境变量不为空
|
|
|
jarUrl="$MVNW_REPOURL/io/takari/maven-wrapper/0.5.5/maven-wrapper-0.5.5.jar"
|
|
|
# 设置 jarUrl 为指定仓库路径下的 maven-wrapper.jar 文件路径
|
|
|
else
|
|
|
jarUrl="https://repo.maven.apache.org/maven2/io/takari/maven-wrapper/0.5.5/maven-wrapper-0.5.5.jar"
|
|
|
# 否则,设置 jarUrl 为 Maven 中央仓库的 maven-wrapper.jar 文件路径
|
|
|
fi
|
|
|
while IFS="=" read key value; do
|
|
|
# 按行读取文件内容,以 = 分割为键值对
|
|
|
case "$key" in (wrapperUrl) jarUrl="$value"; break ;;
|
|
|
# 如果键为 wrapperUrl,将值赋给 jarUrl 并跳出循环
|
|
|
esac
|
|
|
done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties"
|
|
|
# 从 .mvn/wrapper/maven-wrapper.properties 文件中读取内容进行处理
|
|
|
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Downloading from: $jarUrl"
|
|
|
# 输出从哪个路径下载 maven-wrapper.jar 文件的信息
|
|
|
fi
|
|
|
wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar"
|
|
|
# 设置 wrapperJarPath 为要下载到的本地路径
|
|
|
|
|
|
if $cygwin; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"`
|
|
|
# 将 wrapperJarPath 转换为 Windows 格式路径
|
|
|
fi
|
|
|
|
|
|
if command -v wget > /dev/null; then
|
|
|
# 如果 wget 命令存在
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Found wget ... using wget"
|
|
|
# 输出找到 wget 命令并将使用它下载的信息
|
|
|
fi
|
|
|
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
|
|
|
# 如果 MVNW_USERNAME 或 MVNW_PASSWORD 环境变量为空
|
|
|
wget "$jarUrl" -O "$wrapperJarPath"
|
|
|
# 使用 wget 命令从 jarUrl 下载文件并保存到 wrapperJarPath
|
|
|
else
|
|
|
wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath"
|
|
|
# 如果有用户名和密码,使用它们进行认证后下载文件
|
|
|
fi
|
|
|
elif command -v curl > /dev/null; then
|
|
|
# 如果 wget 不可用但 curl 命令存在
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Found curl ... using curl"
|
|
|
# 输出找到 curl 命令并将使用它下载的信息
|
|
|
fi
|
|
|
if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then
|
|
|
# 如果 MVNW_USERNAME 或 MVNW_PASSWORD 环境变量为空
|
|
|
curl -o "$wrapperJarPath" "$jarUrl" -f
|
|
|
# 使用 curl 命令从 jarUrl 下载文件并保存到 wrapperJarPath,-f 表示失败时不显示进度条
|
|
|
else
|
|
|
curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f
|
|
|
# 如果有用户名和密码,使用它们进行认证后下载文件
|
|
|
fi
|
|
|
else
|
|
|
# 如果 wget 和 curl 都不可用
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo "Falling back to using Java to download"
|
|
|
# 输出将使用 Java 进行下载的信息
|
|
|
fi
|
|
|
javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java"
|
|
|
# 设置 javaClass 为 MavenWrapperDownloader.java 文件的路径
|
|
|
|
|
|
# For Cygwin, switch paths to Windows format before running javac
|
|
|
if $cygwin; then
|
|
|
# 如果是 Cygwin 系统
|
|
|
javaClass=`cygpath --path --windows "$javaClass"`
|
|
|
# 将 javaClass 路径转换为 Windows 格式
|
|
|
fi
|
|
|
|
|
|
if [ -e "$javaClass" ]; then
|
|
|
# 如果 MavenWrapperDownloader.java 文件存在
|
|
|
if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
|
|
|
# 如果 MavenWrapperDownloader.class 文件不存在
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo " - Compiling MavenWrapperDownloader.java ..."
|
|
|
# 输出正在编译 MavenWrapperDownloader.java 文件的信息
|
|
|
fi
|
|
|
# Compiling the Java class
|
|
|
("$JAVA_HOME/bin/javac" "$javaClass")
|
|
|
# 使用 javac 命令编译 MavenWrapperDownloader.java 文件
|
|
|
fi
|
|
|
if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then
|
|
|
# 如果编译后的 MavenWrapperDownloader.class 文件存在
|
|
|
# Running the downloader
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo " - Running MavenWrapperDownloader.java ..."
|
|
|
# 输出正在运行 MavenWrapperDownloader.java 程序的信息
|
|
|
fi
|
|
|
("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR")
|
|
|
# 使用 java 命令运行编译后的程序进行下载,传入项目基础目录作为参数
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
fi
|
|
|
##########################################################################################
|
|
|
# End of extension
|
|
|
##########################################################################################
|
|
|
# 自动下载 maven-wrapper.jar 扩展部分结束
|
|
|
|
|
|
export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}
|
|
|
# 导出 MAVEN_PROJECTBASEDIR 环境变量,如果 MAVEN_BASEDIR 未设置,则使用 BASE_DIR 的值
|
|
|
if [ "$MVNW_VERBOSE" = true ]; then
|
|
|
# 如果 MVNW_VERBOSE 环境变量为 true
|
|
|
echo $MAVEN_PROJECTBASEDIR
|
|
|
# 输出 MAVEN_PROJECTBASEDIR 的值
|
|
|
fi
|
|
|
|
|
|
MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS"
|
|
|
# 调用 concat_lines 函数将 .mvn/jvm.config 文件内容拼接成一行,再与原有的 MAVEN_OPTS 拼接,作为新的 JVM 启动参数
|
|
|
|
|
|
# For Cygwin, switch paths to Windows format before running java
|
|
|
if $cygwin; then
|
|
|
# 若为 Cygwin 系统
|
|
|
[ -n "$M2_HOME" ] && M2_HOME=`cygpath --path --windows "$M2_HOME"`
|
|
|
# 若 M2_HOME 不为空,将其转换为 Windows 路径格式
|
|
|
[ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"`
|
|
|
# 若 JAVA_HOME 不为空,将其转换为 Windows 路径格式
|
|
|
[ -n "$CLASSPATH" ] && CLASSPATH=`cygpath --path --windows "$CLASSPATH"`
|
|
|
# 若 CLASSPATH 不为空,将其转换为 Windows 路径格式
|
|
|
[ -n "$MAVEN_PROJECTBASEDIR" ] && MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"`
|
|
|
# 若 MAVEN_PROJECTBASEDIR 不为空,将其转换为 Windows 路径格式
|
|
|
fi
|
|
|
|
|
|
# Provide a "standardized" way to retrieve the CLI args that will
|
|
|
# work with both Windows and non-Windows executions.
|
|
|
MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@"
|
|
|
# 将 MAVEN_CONFIG 环境变量的值和传递给脚本的所有参数拼接,存储到 MAVEN_CMD_LINE_ARGS 变量,用于统一管理命令行参数
|
|
|
export MAVEN_CMD_LINE_ARGS
|
|
|
# 导出 MAVEN_CMD_LINE_ARGS 环境变量,以便后续使用
|
|
|
|
|
|
WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
|
|
|
# 设置 WRAPPER_LAUNCHER 为 Maven 包装器的主类,用于启动 Maven 包装器
|
|
|
|
|
|
exec "$JAVACMD" \
|
|
|
# 使用 exec 命令执行 Java 命令,替换当前 shell 进程
|
|
|
$MAVEN_OPTS \
|
|
|
# 传递 MAVEN_OPTS 作为 Java 虚拟机的启动参数
|
|
|
-classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \
|
|
|
# 设置类路径为 maven-wrapper.jar 文件所在路径
|
|
|
"-Dmaven.home=${M2_HOME}" "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \
|
|
|
# 设置两个系统属性,分别指定 Maven 主目录和多模块项目目录
|
|
|
${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@"
|
|
|
# 执行 Maven 包装器主类,并传递 MAVEN_CONFIG 和所有命令行参数,正式启动 Maven 构建过程 |