Sync docs from v2.1.10.RELEASE to gh-pages
35
spring-cloud-build/2.1.10.RELEASE/css/highlight.css
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
code highlight CSS resemblign the Eclipse IDE default color schema
|
||||||
|
@author Costin Leau
|
||||||
|
*/
|
||||||
|
|
||||||
|
.hl-keyword {
|
||||||
|
color: #7F0055;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-comment {
|
||||||
|
color: #3F5F5F;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-multiline-comment {
|
||||||
|
color: #3F5FBF;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-tag {
|
||||||
|
color: #3F7F7F;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-attribute {
|
||||||
|
color: #7F007F;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-value {
|
||||||
|
color: #2A00FF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-string {
|
||||||
|
color: #2A00FF;
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
@IMPORT url("manual.css");
|
||||||
|
|
||||||
|
body.firstpage {
|
||||||
|
background: url("../images/background.png") no-repeat center top;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.part h1 {
|
||||||
|
border-top: none;
|
||||||
|
}
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
@IMPORT url("manual.css");
|
||||||
|
|
||||||
|
body {
|
||||||
|
background: url("../images/background.png") no-repeat center top;
|
||||||
|
}
|
||||||
|
|
||||||
342
spring-cloud-build/2.1.10.RELEASE/css/manual.css
Normal file
@@ -0,0 +1,342 @@
|
|||||||
|
@IMPORT url("highlight.css");
|
||||||
|
|
||||||
|
html {
|
||||||
|
padding: 0pt;
|
||||||
|
margin: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
color: #333333;
|
||||||
|
margin: 15px 30px;
|
||||||
|
font-family: Helvetica, Arial, Freesans, Clean, Sans-serif;
|
||||||
|
line-height: 1.6;
|
||||||
|
-webkit-font-smoothing: antialiased;
|
||||||
|
}
|
||||||
|
|
||||||
|
code {
|
||||||
|
font-size: 16px;
|
||||||
|
font-family: Consolas, "Liberation Mono", Courier, monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
:not(a) > code {
|
||||||
|
color: #6D180B;
|
||||||
|
}
|
||||||
|
|
||||||
|
:not(pre) > code {
|
||||||
|
background-color: #F2F2F2;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 1px 3px 0;
|
||||||
|
text-shadow: none;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
body > *:first-child {
|
||||||
|
margin-top: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div {
|
||||||
|
margin: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
hr {
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
background: #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3, h4, h5, h6 {
|
||||||
|
color: #000000;
|
||||||
|
cursor: text;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 30px 0 10px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3 {
|
||||||
|
margin: 40px 0 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
margin: 70px 0 30px;
|
||||||
|
padding-top: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.part h1 {
|
||||||
|
border-top: 1px dotted #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h1 code {
|
||||||
|
font-size: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2, h2 code {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h3, h3 code {
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h4, h1 code, h5, h5 code, h6, h6 code {
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.book, div.chapter, div.appendix, div.part, div.preface {
|
||||||
|
min-width: 300px;
|
||||||
|
max-width: 1200px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.releaseinfo {
|
||||||
|
font-weight: bold;
|
||||||
|
margin-bottom: 40px;
|
||||||
|
margin-top: 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.authorgroup {
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.copyright {
|
||||||
|
line-height: 1;
|
||||||
|
margin-bottom: -5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.legalnotice p {
|
||||||
|
font-style: italic;
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.titlepage + p, div.titlepage + p {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre {
|
||||||
|
line-height: 1.0;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #4183C4;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin: 15px 0;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul, ol {
|
||||||
|
padding-left: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
li p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table {
|
||||||
|
margin: 1em;
|
||||||
|
padding: 0.5em;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table table, div.informaltable table {
|
||||||
|
display: table;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table td {
|
||||||
|
padding-left: 7px;
|
||||||
|
padding-right: 7px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
line-height: 1.4;
|
||||||
|
padding: 0 20px;
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 3px 3px 3px 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar p.title {
|
||||||
|
color: #6D180B;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre.programlisting, pre.screen {
|
||||||
|
font-size: 15px;
|
||||||
|
padding: 6px 10px;
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 3px 3px 3px 3px;
|
||||||
|
clear: both;
|
||||||
|
overflow: auto;
|
||||||
|
line-height: 1.4;
|
||||||
|
font-family: Consolas, "Liberation Mono", Courier, monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
border-collapse: collapse;
|
||||||
|
border-spacing: 0;
|
||||||
|
border: 1px solid #DDDDDD !important;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
border-collapse: separate !important;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
table thead {
|
||||||
|
background: #F5F5F5;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr {
|
||||||
|
border: none;
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
table th {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
table th, table td {
|
||||||
|
border: none !important;
|
||||||
|
padding: 6px 13px;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr:nth-child(2n) {
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
}
|
||||||
|
|
||||||
|
td p {
|
||||||
|
margin: 0 0 15px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table-contents td p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important *, div.note *, div.tip *, div.warning *, div.navheader *, div.navfooter *, div.calloutlist * {
|
||||||
|
border: none !important;
|
||||||
|
background: none !important;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important p, div.note p, div.tip p, div.warning p {
|
||||||
|
color: #6F6F6F;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important code, div.note code, div.tip code, div.warning code {
|
||||||
|
background-color: #F2F2F2 !important;
|
||||||
|
border: 1px solid #CCCCCC !important;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
padding: 1px 3px 0 !important;
|
||||||
|
text-shadow: none !important;
|
||||||
|
white-space: nowrap !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note th, .tip th, .warning th {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note tr:first-child td, .tip tr:first-child td, .warning tr:first-child td {
|
||||||
|
border-right: 1px solid #CCCCCC !important;
|
||||||
|
padding-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.calloutlist p, div.calloutlist td {
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.calloutlist > table > tbody > tr > td:first-child {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 30px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important, div.note, div.tip, div.warning {
|
||||||
|
margin-left: 0px !important;
|
||||||
|
margin-right: 20px !important;
|
||||||
|
margin-top: 20px;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
padding-top: 10px;
|
||||||
|
padding-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc {
|
||||||
|
line-height: 1.2;
|
||||||
|
}
|
||||||
|
|
||||||
|
dl, dt {
|
||||||
|
margin-top: 1px;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dt {
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 30px 0 10px 0;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dd > dl > dt {
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 20px 0 10px 0;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dd > dl > dd > dl > dt {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
|
margin: 10px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
tbody.footnotes * {
|
||||||
|
border: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.footnote p {
|
||||||
|
margin: 0;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.footnote p sup {
|
||||||
|
margin-right: 6px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.navheader {
|
||||||
|
border-bottom: 1px solid #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.navfooter {
|
||||||
|
border-top: 1px solid #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title {
|
||||||
|
margin-left: -1em;
|
||||||
|
padding-left: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title > a {
|
||||||
|
position: absolute;
|
||||||
|
visibility: hidden;
|
||||||
|
display: block;
|
||||||
|
font-size: 0.85em;
|
||||||
|
margin-top: 0.05em;
|
||||||
|
margin-left: -1em;
|
||||||
|
vertical-align: text-top;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title > a:before {
|
||||||
|
content: "\00A7";
|
||||||
|
}
|
||||||
|
|
||||||
|
.title:hover > a, .title > a:hover, .title:hover > a:hover {
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title:focus > a, .title > a:focus, .title:focus > a:focus {
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
374
spring-cloud-build/2.1.10.RELEASE/ghpages.sh
Normal file
@@ -0,0 +1,374 @@
|
|||||||
|
#!/bin/bash -x
|
||||||
|
|
||||||
|
# Usage: (cd <project root>; ghpages.sh -v <version> -b -c)
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Set default props like MAVEN_PATH, ROOT_FOLDER etc.
|
||||||
|
function set_default_props() {
|
||||||
|
# The script should be executed from the root folder
|
||||||
|
ROOT_FOLDER=`pwd`
|
||||||
|
echo "Current folder is ${ROOT_FOLDER}"
|
||||||
|
|
||||||
|
if [[ ! -e "${ROOT_FOLDER}/.git" ]]; then
|
||||||
|
echo "You're not in the root folder of the project!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Prop that will let commit the changes
|
||||||
|
COMMIT_CHANGES="no"
|
||||||
|
MAVEN_PATH=${MAVEN_PATH:-}
|
||||||
|
if [ -e "${ROOT_FOLDER}/mvnw" ]; then
|
||||||
|
MAVEN_EXEC="$ROOT_FOLDER/mvnw"
|
||||||
|
else
|
||||||
|
MAVEN_EXEC="${MAVEN_PATH}mvn"
|
||||||
|
fi
|
||||||
|
echo "Path to Maven is [${MAVEN_EXEC}]"
|
||||||
|
if [ -z $REPO_NAME ]; then
|
||||||
|
REPO_NAME=$(git remote -v | grep origin | head -1 | sed -e 's!.*/!!' -e 's/ .*//' -e 's/\.git.*//')
|
||||||
|
fi
|
||||||
|
echo "Repo name is [${REPO_NAME}]"
|
||||||
|
SPRING_CLOUD_STATIC_REPO=${SPRING_CLOUD_STATIC_REPO:-git@github.com:spring-cloud/spring-cloud-static.git}
|
||||||
|
echo "Spring Cloud Static repo is [${SPRING_CLOUD_STATIC_REPO}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Adds the oauth token if present to the remote url
|
||||||
|
function add_oauth_token_to_remote_url() {
|
||||||
|
remote=`git config remote.origin.url | sed -e 's/^git:/https:/'`
|
||||||
|
echo "Current remote [${remote}]"
|
||||||
|
if [[ "${RELEASER_GIT_OAUTH_TOKEN}" != "" && ${remote} != *"@"* ]]; then
|
||||||
|
echo "OAuth token found. Will reuse it to push the code"
|
||||||
|
withToken=${remote/https:\/\//https://${RELEASER_GIT_OAUTH_TOKEN}@}
|
||||||
|
git remote set-url --push origin "${withToken}"
|
||||||
|
else
|
||||||
|
echo "No OAuth token found"
|
||||||
|
git remote set-url --push origin `git config remote.origin.url | sed -e 's/^git:/https:/'`
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check if gh-pages exists and docs have been built
|
||||||
|
function check_if_anything_to_sync() {
|
||||||
|
add_oauth_token_to_remote_url
|
||||||
|
if ! (git remote set-branches --add origin gh-pages && git fetch -q) && [[ "${RELEASE_TRAIN}" != "yes" ]] ; then
|
||||||
|
echo "No gh-pages, so not syncing"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! [ -d docs/target/generated-docs ] && ! [ "${BUILD}" == "yes" ]; then
|
||||||
|
echo "No gh-pages sources in docs/target/generated-docs, so not syncing"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function retrieve_current_branch() {
|
||||||
|
# Code getting the name of the current branch. For master we want to publish as we did until now
|
||||||
|
# https://stackoverflow.com/questions/1593051/how-to-programmatically-determine-the-current-checked-out-git-branch
|
||||||
|
# If there is a branch already passed will reuse it - otherwise will try to find it
|
||||||
|
CURRENT_BRANCH=${BRANCH}
|
||||||
|
if [[ -z "${CURRENT_BRANCH}" ]] ; then
|
||||||
|
CURRENT_BRANCH=$(git symbolic-ref -q HEAD)
|
||||||
|
CURRENT_BRANCH=${CURRENT_BRANCH##refs/heads/}
|
||||||
|
CURRENT_BRANCH=${CURRENT_BRANCH:-HEAD}
|
||||||
|
fi
|
||||||
|
echo "Current branch is [${CURRENT_BRANCH}]"
|
||||||
|
git checkout ${CURRENT_BRANCH} || echo "Failed to check the branch... continuing with the script"
|
||||||
|
PREVIOUS_BRANCH=${CURRENT_BRANCH}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Switches to the provided value of the release version. We always prefix it with `v`
|
||||||
|
function switch_to_tag() {
|
||||||
|
if [[ "${RELEASE_TRAIN}" != "yes" ]] ; then
|
||||||
|
git checkout v${VERSION}
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Build the docs if switch is on
|
||||||
|
function build_docs_if_applicable() {
|
||||||
|
if [[ "${BUILD}" == "yes" ]] ; then
|
||||||
|
./mvnw clean install -P docs -pl docs -DskipTests
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Get the name of the `docs.main` property
|
||||||
|
# Get whitelisted branches - assumes that a `docs` module is available under `docs` profile
|
||||||
|
function retrieve_doc_properties() {
|
||||||
|
MAIN_ADOC_VALUE=$("${MAVEN_EXEC}" -q \
|
||||||
|
-Dexec.executable="echo" \
|
||||||
|
-Dexec.args='${docs.main}' \
|
||||||
|
org.codehaus.mojo:exec-maven-plugin:1.3.1:exec \
|
||||||
|
-P docs \
|
||||||
|
-pl docs | tail -1 )
|
||||||
|
echo "Extracted 'main.adoc' from Maven build [${MAIN_ADOC_VALUE}]"
|
||||||
|
|
||||||
|
|
||||||
|
WHITELIST_PROPERTY=${WHITELIST_PROPERTY:-"docs.whitelisted.branches"}
|
||||||
|
WHITELISTED_BRANCHES_VALUE=$("${MAVEN_EXEC}" -q \
|
||||||
|
-Dexec.executable="echo" \
|
||||||
|
-Dexec.args="\${${WHITELIST_PROPERTY}}" \
|
||||||
|
org.codehaus.mojo:exec-maven-plugin:1.3.1:exec \
|
||||||
|
-P docs \
|
||||||
|
-pl docs | tail -1 )
|
||||||
|
echo "Extracted '${WHITELIST_PROPERTY}' from Maven build [${WHITELISTED_BRANCHES_VALUE}]"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Stash any outstanding changes
|
||||||
|
function stash_changes() {
|
||||||
|
git diff-index --quiet HEAD && dirty=$? || (echo "Failed to check if the current repo is dirty. Assuming that it is." && dirty="1")
|
||||||
|
if [ "$dirty" != "0" ]; then git stash; fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Switch to gh-pages branch to sync it with current branch
|
||||||
|
function add_docs_from_target() {
|
||||||
|
local DESTINATION_REPO_FOLDER
|
||||||
|
if [[ -z "${DESTINATION}" && -z "${CLONE}" ]] ; then
|
||||||
|
DESTINATION_REPO_FOLDER=${ROOT_FOLDER}
|
||||||
|
elif [[ "${CLONE}" == "yes" ]]; then
|
||||||
|
mkdir -p ${ROOT_FOLDER}/target
|
||||||
|
local clonedStatic=${ROOT_FOLDER}/target/spring-cloud-static
|
||||||
|
if [[ ! -e "${clonedStatic}/.git" ]]; then
|
||||||
|
echo "Cloning Spring Cloud Static to target"
|
||||||
|
git clone ${SPRING_CLOUD_STATIC_REPO} ${clonedStatic} && cd ${clonedStatic} && git checkout gh-pages
|
||||||
|
else
|
||||||
|
echo "Spring Cloud Static already cloned - will pull changes"
|
||||||
|
cd ${clonedStatic} && git checkout gh-pages && git pull origin gh-pages
|
||||||
|
fi
|
||||||
|
if [[ -z "${RELEASE_TRAIN}" ]] ; then
|
||||||
|
DESTINATION_REPO_FOLDER=${clonedStatic}/${REPO_NAME}
|
||||||
|
else
|
||||||
|
DESTINATION_REPO_FOLDER=${clonedStatic}
|
||||||
|
fi
|
||||||
|
mkdir -p ${DESTINATION_REPO_FOLDER}
|
||||||
|
else
|
||||||
|
if [[ ! -e "${DESTINATION}/.git" ]]; then
|
||||||
|
echo "[${DESTINATION}] is not a git repository"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [[ -z "${RELEASE_TRAIN}" ]] ; then
|
||||||
|
DESTINATION_REPO_FOLDER=${DESTINATION}/${REPO_NAME}
|
||||||
|
else
|
||||||
|
DESTINATION_REPO_FOLDER=${DESTINATION}
|
||||||
|
fi
|
||||||
|
mkdir -p ${DESTINATION_REPO_FOLDER}
|
||||||
|
echo "Destination was provided [${DESTINATION}]"
|
||||||
|
fi
|
||||||
|
cd ${DESTINATION_REPO_FOLDER}
|
||||||
|
git checkout gh-pages
|
||||||
|
git pull origin gh-pages
|
||||||
|
|
||||||
|
# Add git branches
|
||||||
|
###################################################################
|
||||||
|
if [[ -z "${VERSION}" && -z "${RELEASE_TRAIN}" ]] ; then
|
||||||
|
copy_docs_for_current_version
|
||||||
|
else
|
||||||
|
copy_docs_for_provided_version
|
||||||
|
fi
|
||||||
|
commit_changes_if_applicable
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Copies the docs by using the retrieved properties from Maven build
|
||||||
|
function copy_docs_for_current_version() {
|
||||||
|
if [[ "${CURRENT_BRANCH}" == "master" ]] ; then
|
||||||
|
echo -e "Current branch is master - will copy the current docs only to the root folder"
|
||||||
|
for f in docs/target/generated-docs/*; do
|
||||||
|
file=${f#docs/target/generated-docs/*}
|
||||||
|
if ! git ls-files -i -o --exclude-standard --directory | grep -q ^$file$; then
|
||||||
|
# Not ignored...
|
||||||
|
cp -rf $f ${ROOT_FOLDER}/
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
git add -A ${ROOT_FOLDER}
|
||||||
|
COMMIT_CHANGES="yes"
|
||||||
|
else
|
||||||
|
echo -e "Current branch is [${CURRENT_BRANCH}]"
|
||||||
|
# https://stackoverflow.com/questions/29300806/a-bash-script-to-check-if-a-string-is-present-in-a-comma-separated-list-of-strin
|
||||||
|
if [[ ",${WHITELISTED_BRANCHES_VALUE}," = *",${CURRENT_BRANCH},"* ]] ; then
|
||||||
|
mkdir -p ${ROOT_FOLDER}/${CURRENT_BRANCH}
|
||||||
|
echo -e "Branch [${CURRENT_BRANCH}] is whitelisted! Will copy the current docs to the [${CURRENT_BRANCH}] folder"
|
||||||
|
for f in docs/target/generated-docs/*; do
|
||||||
|
file=${f#docs/target/generated-docs/*}
|
||||||
|
if ! git ls-files -i -o --exclude-standard --directory | grep -q ^$file$; then
|
||||||
|
# Not ignored...
|
||||||
|
# We want users to access 1.0.0.RELEASE/ instead of 1.0.0.RELEASE/spring-cloud.sleuth.html
|
||||||
|
if [[ "${file}" == "${MAIN_ADOC_VALUE}.html" ]] ; then
|
||||||
|
# We don't want to copy the spring-cloud-sleuth.html
|
||||||
|
# we want it to be converted to index.html
|
||||||
|
cp -rf $f ${ROOT_FOLDER}/${CURRENT_BRANCH}/index.html
|
||||||
|
git add -A ${ROOT_FOLDER}/${CURRENT_BRANCH}/index.html
|
||||||
|
else
|
||||||
|
cp -rf $f ${ROOT_FOLDER}/${CURRENT_BRANCH}
|
||||||
|
git add -A ${ROOT_FOLDER}/${CURRENT_BRANCH}/$file || echo "Failed to add the file [$file]"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
COMMIT_CHANGES="yes"
|
||||||
|
else
|
||||||
|
echo -e "Branch [${CURRENT_BRANCH}] is not on the white list! Check out the Maven [${WHITELIST_PROPERTY}] property in
|
||||||
|
[docs] module available under [docs] profile. Won't commit any changes to gh-pages for this branch."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Copies the docs by using the explicitly provided version
|
||||||
|
function copy_docs_for_provided_version() {
|
||||||
|
local FOLDER=${DESTINATION_REPO_FOLDER}/${VERSION}
|
||||||
|
mkdir -p ${FOLDER}
|
||||||
|
echo -e "Current tag is [v${VERSION}] Will copy the current docs to the [${FOLDER}] folder"
|
||||||
|
for f in ${ROOT_FOLDER}/docs/target/generated-docs/*; do
|
||||||
|
file=${f#${ROOT_FOLDER}/docs/target/generated-docs/*}
|
||||||
|
copy_docs_for_branch ${file} ${FOLDER}
|
||||||
|
done
|
||||||
|
COMMIT_CHANGES="yes"
|
||||||
|
CURRENT_BRANCH="v${VERSION}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Copies the docs from target to the provided destination
|
||||||
|
# Params:
|
||||||
|
# $1 - file from target
|
||||||
|
# $2 - destination to which copy the files
|
||||||
|
function copy_docs_for_branch() {
|
||||||
|
local file=$1
|
||||||
|
local destination=$2
|
||||||
|
if ! git ls-files -i -o --exclude-standard --directory | grep -q ^${file}$; then
|
||||||
|
# Not ignored...
|
||||||
|
# We want users to access 1.0.0.RELEASE/ instead of 1.0.0.RELEASE/spring-cloud.sleuth.html
|
||||||
|
if [[ ("${file}" == "${MAIN_ADOC_VALUE}.html") || ("${file}" == "${REPO_NAME}.html") ]] ; then
|
||||||
|
# We don't want to copy the spring-cloud-sleuth.html
|
||||||
|
# we want it to be converted to index.html
|
||||||
|
cp -rf $f ${destination}/index.html
|
||||||
|
else
|
||||||
|
cp -rf $f ${destination}
|
||||||
|
fi
|
||||||
|
git add -A ${destination}
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function commit_changes_if_applicable() {
|
||||||
|
if [[ "${COMMIT_CHANGES}" == "yes" ]] ; then
|
||||||
|
COMMIT_SUCCESSFUL="no"
|
||||||
|
git commit -a -m "Sync docs from ${CURRENT_BRANCH} to gh-pages" && COMMIT_SUCCESSFUL="yes" || echo "Failed to commit changes"
|
||||||
|
|
||||||
|
# Uncomment the following push if you want to auto push to
|
||||||
|
# the gh-pages branch whenever you commit to master locally.
|
||||||
|
# This is a little extreme. Use with care!
|
||||||
|
###################################################################
|
||||||
|
if [[ "${COMMIT_SUCCESSFUL}" == "yes" ]] ; then
|
||||||
|
add_oauth_token_to_remote_url
|
||||||
|
git push origin gh-pages
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Switch back to the previous branch and exit block
|
||||||
|
function checkout_previous_branch() {
|
||||||
|
# If -version was provided we need to come back to root project
|
||||||
|
cd ${ROOT_FOLDER}
|
||||||
|
git checkout ${PREVIOUS_BRANCH} || echo "Failed to check the branch... continuing with the script"
|
||||||
|
if [ "$dirty" != "0" ]; then git stash pop; fi
|
||||||
|
exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Assert if properties have been properly passed
|
||||||
|
function assert_properties() {
|
||||||
|
echo "VERSION [${VERSION}], RELEASE_TRAIN [${RELEASE_TRAIN}], DESTINATION [${DESTINATION}], CLONE [${CLONE}]"
|
||||||
|
if [[ "${VERSION}" != "" && (-z "${DESTINATION}" && -z "${CLONE}") ]] ; then echo "Version was set but destination / clone was not!"; exit 1;fi
|
||||||
|
if [[ ("${DESTINATION}" != "" && "${CLONE}" != "") && -z "${VERSION}" ]] ; then echo "Destination / clone was set but version was not!"; exit 1;fi
|
||||||
|
if [[ "${DESTINATION}" != "" && "${CLONE}" == "yes" ]] ; then echo "Destination and clone was set. Pick one!"; exit 1;fi
|
||||||
|
if [[ "${RELEASE_TRAIN}" != "" && -z "${VERSION}" ]] ; then echo "Release train was set but no version was passed!"; exit 1;fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Prints the usage
|
||||||
|
function print_usage() {
|
||||||
|
cat <<EOF
|
||||||
|
The idea of this script is to update gh-pages branch with the generated docs. Without any options
|
||||||
|
the script will work in the following manner:
|
||||||
|
|
||||||
|
- if there's no gh-pages / target for docs module then the script ends
|
||||||
|
- for master branch the generated docs are copied to the root of gh-pages branch
|
||||||
|
- for any other branch (if that branch is whitelisted) a subfolder with branch name is created
|
||||||
|
and docs are copied there
|
||||||
|
- if the version switch is passed (-v) then a tag with (v) prefix will be retrieved and a folder
|
||||||
|
with that version number will be created in the gh-pages branch. WARNING! No whitelist verification will take place
|
||||||
|
- if the destination switch is passed (-d) then the script will check if the provided dir is a git repo and then will
|
||||||
|
switch to gh-pages of that repo and copy the generated docs to `docs/<project-name>/<version>`
|
||||||
|
- if the destination switch is passed (-d) then the script will check if the provided dir is a git repo and then will
|
||||||
|
switch to gh-pages of that repo and copy the generated docs to `docs/<project-name>/<version>`
|
||||||
|
- if the release train switch is passed (-r) then the script will check if the provided dir is a git repo and then will
|
||||||
|
switch to gh-pages of that repo and copy the generated docs to `docs/<version>`
|
||||||
|
|
||||||
|
USAGE:
|
||||||
|
|
||||||
|
You can use the following options:
|
||||||
|
|
||||||
|
-v|--version - the script will apply the whole procedure for a particular library version
|
||||||
|
-r|--releasetrain - instead of nesting the docs under the project_name/version folder the docs will end up in version
|
||||||
|
-d|--destination - the root of destination folder where the docs should be copied. You have to use the full path.
|
||||||
|
E.g. point to spring-cloud-static folder. Can't be used with (-c)
|
||||||
|
-b|--build - will run the standard build process after checking out the branch
|
||||||
|
-c|--clone - will automatically clone the spring-cloud-static repo instead of providing the destination.
|
||||||
|
Obviously can't be used with (-d)
|
||||||
|
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# ==========================================
|
||||||
|
# ____ ____ _____ _____ _____ _______
|
||||||
|
# / ____|/ ____| __ \|_ _| __ \__ __|
|
||||||
|
# | (___ | | | |__) | | | | |__) | | |
|
||||||
|
# \___ \| | | _ / | | | ___/ | |
|
||||||
|
# ____) | |____| | \ \ _| |_| | | |
|
||||||
|
# |_____/ \_____|_| \_\_____|_| |_|
|
||||||
|
#
|
||||||
|
# ==========================================
|
||||||
|
|
||||||
|
while [[ $# > 0 ]]
|
||||||
|
do
|
||||||
|
key="$1"
|
||||||
|
case ${key} in
|
||||||
|
-v|--version)
|
||||||
|
VERSION="$2"
|
||||||
|
shift # past argument
|
||||||
|
;;
|
||||||
|
-r|--releasetrain)
|
||||||
|
RELEASE_TRAIN="yes"
|
||||||
|
;;
|
||||||
|
-d|--destination)
|
||||||
|
DESTINATION="$2"
|
||||||
|
shift # past argument
|
||||||
|
;;
|
||||||
|
-b|--build)
|
||||||
|
BUILD="yes"
|
||||||
|
;;
|
||||||
|
-c|--clone)
|
||||||
|
CLONE="yes"
|
||||||
|
;;
|
||||||
|
-h|--help)
|
||||||
|
print_usage
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Invalid option: [$1]"
|
||||||
|
print_usage
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift # past argument or value
|
||||||
|
done
|
||||||
|
|
||||||
|
assert_properties
|
||||||
|
set_default_props
|
||||||
|
check_if_anything_to_sync
|
||||||
|
retrieve_current_branch
|
||||||
|
if echo $VERSION | egrep -q 'SNAPSHOT' || [[ -z "${VERSION}" ]]; then
|
||||||
|
CLONE=""
|
||||||
|
VERSION=""
|
||||||
|
echo "You've provided a version variable but it's a snapshot one. Due to this will not clone spring-cloud-static and publish docs over there"
|
||||||
|
else
|
||||||
|
switch_to_tag
|
||||||
|
fi
|
||||||
|
build_docs_if_applicable
|
||||||
|
retrieve_doc_properties
|
||||||
|
stash_changes
|
||||||
|
add_docs_from_target
|
||||||
|
checkout_previous_branch
|
||||||
BIN
spring-cloud-build/2.1.10.RELEASE/images/background.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/callouts/1.png
Normal file
|
After Width: | Height: | Size: 329 B |
BIN
spring-cloud-build/2.1.10.RELEASE/images/callouts/2.png
Normal file
|
After Width: | Height: | Size: 353 B |
BIN
spring-cloud-build/2.1.10.RELEASE/images/callouts/3.png
Normal file
|
After Width: | Height: | Size: 350 B |
BIN
spring-cloud-build/2.1.10.RELEASE/images/caution.png
Normal file
|
After Width: | Height: | Size: 2.0 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/important.png
Normal file
|
After Width: | Height: | Size: 2.0 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/intellij-checkstyle.png
Normal file
|
After Width: | Height: | Size: 106 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/intellij-code-style.png
Normal file
|
After Width: | Height: | Size: 85 KiB |
|
After Width: | Height: | Size: 105 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/logo.png
Normal file
|
After Width: | Height: | Size: 4.3 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/note.png
Normal file
|
After Width: | Height: | Size: 2.2 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/images/tip.png
Normal file
|
After Width: | Height: | Size: 931 B |
BIN
spring-cloud-build/2.1.10.RELEASE/images/warning.png
Normal file
|
After Width: | Height: | Size: 2.1 KiB |
35
spring-cloud-build/2.1.10.RELEASE/multi/css/highlight.css
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
code highlight CSS resemblign the Eclipse IDE default color schema
|
||||||
|
@author Costin Leau
|
||||||
|
*/
|
||||||
|
|
||||||
|
.hl-keyword {
|
||||||
|
color: #7F0055;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-comment {
|
||||||
|
color: #3F5F5F;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-multiline-comment {
|
||||||
|
color: #3F5FBF;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-tag {
|
||||||
|
color: #3F7F7F;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-attribute {
|
||||||
|
color: #7F007F;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-value {
|
||||||
|
color: #2A00FF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-string {
|
||||||
|
color: #2A00FF;
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
@IMPORT url("manual.css");
|
||||||
|
|
||||||
|
body.firstpage {
|
||||||
|
background: url("../images/background.png") no-repeat center top;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.part h1 {
|
||||||
|
border-top: none;
|
||||||
|
}
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
@IMPORT url("manual.css");
|
||||||
|
|
||||||
|
body {
|
||||||
|
background: url("../images/background.png") no-repeat center top;
|
||||||
|
}
|
||||||
|
|
||||||
342
spring-cloud-build/2.1.10.RELEASE/multi/css/manual.css
Normal file
@@ -0,0 +1,342 @@
|
|||||||
|
@IMPORT url("highlight.css");
|
||||||
|
|
||||||
|
html {
|
||||||
|
padding: 0pt;
|
||||||
|
margin: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
color: #333333;
|
||||||
|
margin: 15px 30px;
|
||||||
|
font-family: Helvetica, Arial, Freesans, Clean, Sans-serif;
|
||||||
|
line-height: 1.6;
|
||||||
|
-webkit-font-smoothing: antialiased;
|
||||||
|
}
|
||||||
|
|
||||||
|
code {
|
||||||
|
font-size: 16px;
|
||||||
|
font-family: Consolas, "Liberation Mono", Courier, monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
:not(a) > code {
|
||||||
|
color: #6D180B;
|
||||||
|
}
|
||||||
|
|
||||||
|
:not(pre) > code {
|
||||||
|
background-color: #F2F2F2;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 1px 3px 0;
|
||||||
|
text-shadow: none;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
body > *:first-child {
|
||||||
|
margin-top: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div {
|
||||||
|
margin: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
hr {
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
background: #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3, h4, h5, h6 {
|
||||||
|
color: #000000;
|
||||||
|
cursor: text;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 30px 0 10px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3 {
|
||||||
|
margin: 40px 0 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
margin: 70px 0 30px;
|
||||||
|
padding-top: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.part h1 {
|
||||||
|
border-top: 1px dotted #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h1 code {
|
||||||
|
font-size: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2, h2 code {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h3, h3 code {
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h4, h1 code, h5, h5 code, h6, h6 code {
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.book, div.chapter, div.appendix, div.part, div.preface {
|
||||||
|
min-width: 300px;
|
||||||
|
max-width: 1200px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.releaseinfo {
|
||||||
|
font-weight: bold;
|
||||||
|
margin-bottom: 40px;
|
||||||
|
margin-top: 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.authorgroup {
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.copyright {
|
||||||
|
line-height: 1;
|
||||||
|
margin-bottom: -5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.legalnotice p {
|
||||||
|
font-style: italic;
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.titlepage + p, div.titlepage + p {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre {
|
||||||
|
line-height: 1.0;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #4183C4;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin: 15px 0;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul, ol {
|
||||||
|
padding-left: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
li p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table {
|
||||||
|
margin: 1em;
|
||||||
|
padding: 0.5em;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table table, div.informaltable table {
|
||||||
|
display: table;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table td {
|
||||||
|
padding-left: 7px;
|
||||||
|
padding-right: 7px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
line-height: 1.4;
|
||||||
|
padding: 0 20px;
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 3px 3px 3px 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar p.title {
|
||||||
|
color: #6D180B;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre.programlisting, pre.screen {
|
||||||
|
font-size: 15px;
|
||||||
|
padding: 6px 10px;
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 3px 3px 3px 3px;
|
||||||
|
clear: both;
|
||||||
|
overflow: auto;
|
||||||
|
line-height: 1.4;
|
||||||
|
font-family: Consolas, "Liberation Mono", Courier, monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
border-collapse: collapse;
|
||||||
|
border-spacing: 0;
|
||||||
|
border: 1px solid #DDDDDD !important;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
border-collapse: separate !important;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
table thead {
|
||||||
|
background: #F5F5F5;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr {
|
||||||
|
border: none;
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
table th {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
table th, table td {
|
||||||
|
border: none !important;
|
||||||
|
padding: 6px 13px;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr:nth-child(2n) {
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
}
|
||||||
|
|
||||||
|
td p {
|
||||||
|
margin: 0 0 15px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table-contents td p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important *, div.note *, div.tip *, div.warning *, div.navheader *, div.navfooter *, div.calloutlist * {
|
||||||
|
border: none !important;
|
||||||
|
background: none !important;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important p, div.note p, div.tip p, div.warning p {
|
||||||
|
color: #6F6F6F;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important code, div.note code, div.tip code, div.warning code {
|
||||||
|
background-color: #F2F2F2 !important;
|
||||||
|
border: 1px solid #CCCCCC !important;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
padding: 1px 3px 0 !important;
|
||||||
|
text-shadow: none !important;
|
||||||
|
white-space: nowrap !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note th, .tip th, .warning th {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note tr:first-child td, .tip tr:first-child td, .warning tr:first-child td {
|
||||||
|
border-right: 1px solid #CCCCCC !important;
|
||||||
|
padding-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.calloutlist p, div.calloutlist td {
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.calloutlist > table > tbody > tr > td:first-child {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 30px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important, div.note, div.tip, div.warning {
|
||||||
|
margin-left: 0px !important;
|
||||||
|
margin-right: 20px !important;
|
||||||
|
margin-top: 20px;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
padding-top: 10px;
|
||||||
|
padding-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc {
|
||||||
|
line-height: 1.2;
|
||||||
|
}
|
||||||
|
|
||||||
|
dl, dt {
|
||||||
|
margin-top: 1px;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dt {
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 30px 0 10px 0;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dd > dl > dt {
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 20px 0 10px 0;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dd > dl > dd > dl > dt {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
|
margin: 10px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
tbody.footnotes * {
|
||||||
|
border: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.footnote p {
|
||||||
|
margin: 0;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.footnote p sup {
|
||||||
|
margin-right: 6px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.navheader {
|
||||||
|
border-bottom: 1px solid #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.navfooter {
|
||||||
|
border-top: 1px solid #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title {
|
||||||
|
margin-left: -1em;
|
||||||
|
padding-left: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title > a {
|
||||||
|
position: absolute;
|
||||||
|
visibility: hidden;
|
||||||
|
display: block;
|
||||||
|
font-size: 0.85em;
|
||||||
|
margin-top: 0.05em;
|
||||||
|
margin-left: -1em;
|
||||||
|
vertical-align: text-top;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title > a:before {
|
||||||
|
content: "\00A7";
|
||||||
|
}
|
||||||
|
|
||||||
|
.title:hover > a, .title > a:hover, .title:hover > a:hover {
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title:focus > a, .title > a:focus, .title:focus > a:focus {
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/background.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/callouts/1.png
Normal file
|
After Width: | Height: | Size: 329 B |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/callouts/2.png
Normal file
|
After Width: | Height: | Size: 353 B |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/callouts/3.png
Normal file
|
After Width: | Height: | Size: 350 B |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/caution.png
Normal file
|
After Width: | Height: | Size: 2.0 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/important.png
Normal file
|
After Width: | Height: | Size: 2.0 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/logo.png
Normal file
|
After Width: | Height: | Size: 4.3 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/note.png
Normal file
|
After Width: | Height: | Size: 2.2 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/tip.png
Normal file
|
After Width: | Height: | Size: 931 B |
BIN
spring-cloud-build/2.1.10.RELEASE/multi/images/warning.png
Normal file
|
After Width: | Height: | Size: 2.1 KiB |
@@ -0,0 +1,3 @@
|
|||||||
|
<html><head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
||||||
|
<title>1. Building and Deploying</title><link rel="stylesheet" type="text/css" href="css/manual-multipage.css"><meta name="generator" content="DocBook XSL Stylesheets V1.79.1"><link rel="home" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="up" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="prev" href="multi_pr01.html" title=""><link rel="next" href="multi__contributing.html" title="2. Contributing"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">1. Building and Deploying</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="multi_pr01.html">Prev</a> </td><th width="60%" align="center"> </th><td width="20%" align="right"> <a accesskey="n" href="multi__contributing.html">Next</a></td></tr></table><hr></div><div class="chapter"><div class="titlepage"><div><div><h1 class="title"><a name="_building_and_deploying" href="#_building_and_deploying"></a>1. Building and Deploying</h1></div></div></div><p>To install locally:</p><pre class="screen">$ mvn install -s .settings.xml</pre><p>and to deploy snapshots to repo.spring.io:</p><pre class="screen">$ mvn deploy -DaltSnapshotDeploymentRepository=repo.spring.io::default::https://repo.spring.io/libs-snapshot-local</pre><p>for a RELEASE build use</p><pre class="screen">$ mvn deploy -DaltReleaseDeploymentRepository=repo.spring.io::default::https://repo.spring.io/libs-release-local</pre><p>and for jcenter use</p><pre class="screen">$ mvn deploy -DaltReleaseDeploymentRepository=bintray::default::https://api.bintray.com/maven/spring/jars/org.springframework.cloud:build</pre><p>and for Maven Central use</p><pre class="screen">$ mvn deploy -P central -DaltReleaseDeploymentRepository=sonatype-nexus-staging::default::https://oss.sonatype.org/service/local/staging/deploy/maven2</pre><p>(the "central" profile is available for all projects in Spring Cloud and it sets up the gpg jar signing, and the repository has to be specified separately for this project because it is a parent of the starter parent which users in turn have as their own parent).</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="multi_pr01.html">Prev</a> </td><td width="20%" align="center"> </td><td width="40%" align="right"> <a accesskey="n" href="multi__contributing.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top"> </td><td width="20%" align="center"><a accesskey="h" href="multi_spring-cloud-build.html">Home</a></td><td width="40%" align="right" valign="top"> 2. Contributing</td></tr></table></div></body></html>
|
||||||
@@ -0,0 +1,27 @@
|
|||||||
|
<html><head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
||||||
|
<title>3. Reusing the documentation</title><link rel="stylesheet" type="text/css" href="css/manual-multipage.css"><meta name="generator" content="DocBook XSL Stylesheets V1.79.1"><link rel="home" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="up" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="prev" href="multi__contributing.html" title="2. Contributing"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">3. Reusing the documentation</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="multi__contributing.html">Prev</a> </td><th width="60%" align="center"> </th><td width="20%" align="right"> </td></tr></table><hr></div><div class="chapter"><div class="titlepage"><div><div><h1 class="title"><a name="_reusing_the_documentation" href="#_reusing_the_documentation"></a>3. Reusing the documentation</h1></div></div></div><p>Spring Cloud Build publishes its <code class="literal">spring-cloud-build-docs</code> module that contains
|
||||||
|
helpful scripts (e.g. README generation ruby script) and css, xslt and images
|
||||||
|
for the Spring Cloud documentation. If you want to follow the same convention
|
||||||
|
approach of generating documentation just add these plugins to your <code class="literal">docs</code> module</p><pre class="programlisting"><span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><profiles></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><profile></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><id></span>docs<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></id></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><build></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><plugins></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><plugin></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><groupId></span>org.apache.maven.plugins<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></groupId></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><artifactId></span>maven-dependency-plugin<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></artifactId></span> <a name="CO4-1" href="#CO4-1"></a><span><img src="images/callouts/1.png" alt="1" border="0"></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></plugin></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><plugin></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><groupId></span>org.asciidoctor<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></groupId></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><artifactId></span>asciidoctor-maven-plugin<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></artifactId></span> <a name="CO4-2" href="#CO4-2"></a><span><img src="images/callouts/2.png" alt="2" border="0"></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></plugin></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><plugin></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><groupId></span>org.apache.maven.plugins<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></groupId></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><artifactId></span>maven-antrun-plugin<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></artifactId></span> <a name="CO4-3" href="#CO4-3"></a><span><img src="images/callouts/3.png" alt="3" border="0"></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"><inherited></span>false<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></inherited></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></plugin></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></plugins></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></build></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></profile></span>
|
||||||
|
<span xmlns:d="http://docbook.org/ns/docbook" class="hl-tag"></profiles></span></pre><div class="calloutlist"><table border="0" summary="Callout list"><tr><td width="5%" valign="top" align="left"><p><a href="#CO4-1"><span><img src="images/callouts/1.png" alt="1" border="0"></span></a> </p></td><td valign="top" align="left"><p>This plugin downloads and unpacks the resources of the <code class="literal">spring-cloud-build-docs</code> module</p></td></tr><tr><td width="5%" valign="top" align="left"><p><a href="#CO4-2"><span><img src="images/callouts/2.png" alt="2" border="0"></span></a> </p></td><td valign="top" align="left"><p>This plugin is required to parse the Asciidoctor documentation</p></td></tr><tr><td width="5%" valign="top" align="left"><p><a href="#CO4-3"><span><img src="images/callouts/3.png" alt="3" border="0"></span></a> </p></td><td valign="top" align="left"><p>This plugin is required to copy resources into proper final destinations and to generate main README.adoc</p></td></tr></table></div><div class="important" style="margin-left: 0.5in; margin-right: 0.5in;"><table border="0" summary="Important"><tr><td rowspan="2" align="center" valign="top" width="25"><img alt="[Important]" src="images/important.png"></td><th align="left">Important</th></tr><tr><td align="left" valign="top"><p>The order of plugin declaration is important!</p></td></tr></table></div></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="multi__contributing.html">Prev</a> </td><td width="20%" align="center"> </td><td width="40%" align="right"> </td></tr><tr><td width="40%" align="left" valign="top">2. Contributing </td><td width="20%" align="center"><a accesskey="h" href="multi_spring-cloud-build.html">Home</a></td><td width="40%" align="right" valign="top"> </td></tr></table></div></body></html>
|
||||||
4
spring-cloud-build/2.1.10.RELEASE/multi/multi_pr01.html
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
<html><head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
||||||
|
<title></title><link rel="stylesheet" type="text/css" href="css/manual-multipage.css"><meta name="generator" content="DocBook XSL Stylesheets V1.79.1"><link rel="home" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="up" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="prev" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="next" href="multi__building_and_deploying.html" title="1. Building and Deploying"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center"></th></tr><tr><td width="20%" align="left"><a accesskey="p" href="multi_spring-cloud-build.html">Prev</a> </td><th width="60%" align="center"> </th><td width="20%" align="right"> <a accesskey="n" href="multi__building_and_deploying.html">Next</a></td></tr></table><hr></div><div class="preface"><div class="titlepage"><div><div><h1 class="title"><a name="d0e9" href="#d0e9"></a></h1></div></div></div><p><span class="inlinemediaobject"></span></p><p>Spring Cloud Build is a common utility project for Spring Cloud
|
||||||
|
to use for plugin and dependency management.</p></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="multi_spring-cloud-build.html">Prev</a> </td><td width="20%" align="center"> </td><td width="40%" align="right"> <a accesskey="n" href="multi__building_and_deploying.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top">Spring Cloud Build </td><td width="20%" align="center"><a accesskey="h" href="multi_spring-cloud-build.html">Home</a></td><td width="40%" align="right" valign="top"> 1. Building and Deploying</td></tr></table></div></body></html>
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
<html><head>
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
|
||||||
|
<title>Spring Cloud Build</title><link rel="stylesheet" type="text/css" href="css/manual-multipage.css"><meta name="generator" content="DocBook XSL Stylesheets V1.79.1"><link rel="home" href="multi_spring-cloud-build.html" title="Spring Cloud Build"><link rel="next" href="multi_pr01.html" title=""></head><body class="firstpage" bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">Spring Cloud Build</th></tr><tr><td width="20%" align="left"> </td><th width="60%" align="center"> </th><td width="20%" align="right"> <a accesskey="n" href="multi_pr01.html">Next</a></td></tr></table><hr></div><div lang="en" class="book"><div class="titlepage"><div><div><h1 class="title"><a name="d0e3"></a>Spring Cloud Build</h1></div></div><hr></div><div class="toc"><p><b>Table of Contents</b></p><dl class="toc"><dt><span class="preface"><a href="multi_pr01.html"></a></span></dt><dt><span class="chapter"><a href="multi__building_and_deploying.html">1. Building and Deploying</a></span></dt><dt><span class="chapter"><a href="multi__contributing.html">2. Contributing</a></span></dt><dd><dl><dt><span class="section"><a href="multi__contributing.html#_sign_the_contributor_license_agreement">2.1. Sign the Contributor License Agreement</a></span></dt><dt><span class="section"><a href="multi__contributing.html#_code_of_conduct">2.2. Code of Conduct</a></span></dt><dt><span class="section"><a href="multi__contributing.html#_code_conventions_and_housekeeping">2.3. Code Conventions and Housekeeping</a></span></dt><dt><span class="section"><a href="multi__contributing.html#_checkstyle">2.4. Checkstyle</a></span></dt><dd><dl><dt><span class="section"><a href="multi__contributing.html#_checkstyle_configuration">2.4.1. Checkstyle configuration</a></span></dt></dl></dd><dt><span class="section"><a href="multi__contributing.html#_ide_setup">2.5. IDE setup</a></span></dt><dd><dl><dt><span class="section"><a href="multi__contributing.html#_intellij_idea">2.5.1. Intellij IDEA</a></span></dt></dl></dd></dl></dd><dt><span class="chapter"><a href="multi__reusing_the_documentation.html">3. Reusing the documentation</a></span></dt></dl></div></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"> </td><td width="20%" align="center"> </td><td width="40%" align="right"> <a accesskey="n" href="multi_pr01.html">Next</a></td></tr><tr><td width="40%" align="left" valign="top"> </td><td width="20%" align="center"> </td><td width="40%" align="right" valign="top"> </td></tr></table></div></body></html>
|
||||||
35
spring-cloud-build/2.1.10.RELEASE/single/css/highlight.css
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
code highlight CSS resemblign the Eclipse IDE default color schema
|
||||||
|
@author Costin Leau
|
||||||
|
*/
|
||||||
|
|
||||||
|
.hl-keyword {
|
||||||
|
color: #7F0055;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-comment {
|
||||||
|
color: #3F5F5F;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-multiline-comment {
|
||||||
|
color: #3F5FBF;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-tag {
|
||||||
|
color: #3F7F7F;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-attribute {
|
||||||
|
color: #7F007F;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-value {
|
||||||
|
color: #2A00FF;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hl-string {
|
||||||
|
color: #2A00FF;
|
||||||
|
}
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
@IMPORT url("manual.css");
|
||||||
|
|
||||||
|
body.firstpage {
|
||||||
|
background: url("../images/background.png") no-repeat center top;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.part h1 {
|
||||||
|
border-top: none;
|
||||||
|
}
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
@IMPORT url("manual.css");
|
||||||
|
|
||||||
|
body {
|
||||||
|
background: url("../images/background.png") no-repeat center top;
|
||||||
|
}
|
||||||
|
|
||||||
342
spring-cloud-build/2.1.10.RELEASE/single/css/manual.css
Normal file
@@ -0,0 +1,342 @@
|
|||||||
|
@IMPORT url("highlight.css");
|
||||||
|
|
||||||
|
html {
|
||||||
|
padding: 0pt;
|
||||||
|
margin: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
color: #333333;
|
||||||
|
margin: 15px 30px;
|
||||||
|
font-family: Helvetica, Arial, Freesans, Clean, Sans-serif;
|
||||||
|
line-height: 1.6;
|
||||||
|
-webkit-font-smoothing: antialiased;
|
||||||
|
}
|
||||||
|
|
||||||
|
code {
|
||||||
|
font-size: 16px;
|
||||||
|
font-family: Consolas, "Liberation Mono", Courier, monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
:not(a) > code {
|
||||||
|
color: #6D180B;
|
||||||
|
}
|
||||||
|
|
||||||
|
:not(pre) > code {
|
||||||
|
background-color: #F2F2F2;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 1px 3px 0;
|
||||||
|
text-shadow: none;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
body > *:first-child {
|
||||||
|
margin-top: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div {
|
||||||
|
margin: 0pt;
|
||||||
|
}
|
||||||
|
|
||||||
|
hr {
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
background: #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3, h4, h5, h6 {
|
||||||
|
color: #000000;
|
||||||
|
cursor: text;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 30px 0 10px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h2, h3 {
|
||||||
|
margin: 40px 0 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
margin: 70px 0 30px;
|
||||||
|
padding-top: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.part h1 {
|
||||||
|
border-top: 1px dotted #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1, h1 code {
|
||||||
|
font-size: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2, h2 code {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h3, h3 code {
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h4, h1 code, h5, h5 code, h6, h6 code {
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.book, div.chapter, div.appendix, div.part, div.preface {
|
||||||
|
min-width: 300px;
|
||||||
|
max-width: 1200px;
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.releaseinfo {
|
||||||
|
font-weight: bold;
|
||||||
|
margin-bottom: 40px;
|
||||||
|
margin-top: 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.authorgroup {
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
p.copyright {
|
||||||
|
line-height: 1;
|
||||||
|
margin-bottom: -5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.legalnotice p {
|
||||||
|
font-style: italic;
|
||||||
|
font-size: 14px;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.titlepage + p, div.titlepage + p {
|
||||||
|
margin-top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre {
|
||||||
|
line-height: 1.0;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #4183C4;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin: 15px 0;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
ul, ol {
|
||||||
|
padding-left: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
li p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table {
|
||||||
|
margin: 1em;
|
||||||
|
padding: 0.5em;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table table, div.informaltable table {
|
||||||
|
display: table;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table td {
|
||||||
|
padding-left: 7px;
|
||||||
|
padding-right: 7px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
line-height: 1.4;
|
||||||
|
padding: 0 20px;
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 3px 3px 3px 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar p.title {
|
||||||
|
color: #6D180B;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre.programlisting, pre.screen {
|
||||||
|
font-size: 15px;
|
||||||
|
padding: 6px 10px;
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
border: 1px solid #CCCCCC;
|
||||||
|
border-radius: 3px 3px 3px 3px;
|
||||||
|
clear: both;
|
||||||
|
overflow: auto;
|
||||||
|
line-height: 1.4;
|
||||||
|
font-family: Consolas, "Liberation Mono", Courier, monospace;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
border-collapse: collapse;
|
||||||
|
border-spacing: 0;
|
||||||
|
border: 1px solid #DDDDDD !important;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
border-collapse: separate !important;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
table thead {
|
||||||
|
background: #F5F5F5;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr {
|
||||||
|
border: none;
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
table th {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
table th, table td {
|
||||||
|
border: none !important;
|
||||||
|
padding: 6px 13px;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr:nth-child(2n) {
|
||||||
|
background-color: #F8F8F8;
|
||||||
|
}
|
||||||
|
|
||||||
|
td p {
|
||||||
|
margin: 0 0 15px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.table-contents td p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important *, div.note *, div.tip *, div.warning *, div.navheader *, div.navfooter *, div.calloutlist * {
|
||||||
|
border: none !important;
|
||||||
|
background: none !important;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important p, div.note p, div.tip p, div.warning p {
|
||||||
|
color: #6F6F6F;
|
||||||
|
line-height: 1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important code, div.note code, div.tip code, div.warning code {
|
||||||
|
background-color: #F2F2F2 !important;
|
||||||
|
border: 1px solid #CCCCCC !important;
|
||||||
|
border-radius: 4px !important;
|
||||||
|
padding: 1px 3px 0 !important;
|
||||||
|
text-shadow: none !important;
|
||||||
|
white-space: nowrap !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note th, .tip th, .warning th {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.note tr:first-child td, .tip tr:first-child td, .warning tr:first-child td {
|
||||||
|
border-right: 1px solid #CCCCCC !important;
|
||||||
|
padding-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.calloutlist p, div.calloutlist td {
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.calloutlist > table > tbody > tr > td:first-child {
|
||||||
|
padding-left: 10px;
|
||||||
|
width: 30px !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.important, div.note, div.tip, div.warning {
|
||||||
|
margin-left: 0px !important;
|
||||||
|
margin-right: 20px !important;
|
||||||
|
margin-top: 20px;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
padding-top: 10px;
|
||||||
|
padding-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc {
|
||||||
|
line-height: 1.2;
|
||||||
|
}
|
||||||
|
|
||||||
|
dl, dt {
|
||||||
|
margin-top: 1px;
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dt {
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 30px 0 10px 0;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dd > dl > dt {
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: 20px 0 10px 0;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.toc > dl > dd > dl > dd > dl > dt {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
|
margin: 10px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
tbody.footnotes * {
|
||||||
|
border: none !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.footnote p {
|
||||||
|
margin: 0;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.footnote p sup {
|
||||||
|
margin-right: 6px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.navheader {
|
||||||
|
border-bottom: 1px solid #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
div.navfooter {
|
||||||
|
border-top: 1px solid #CCCCCC;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title {
|
||||||
|
margin-left: -1em;
|
||||||
|
padding-left: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title > a {
|
||||||
|
position: absolute;
|
||||||
|
visibility: hidden;
|
||||||
|
display: block;
|
||||||
|
font-size: 0.85em;
|
||||||
|
margin-top: 0.05em;
|
||||||
|
margin-left: -1em;
|
||||||
|
vertical-align: text-top;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title > a:before {
|
||||||
|
content: "\00A7";
|
||||||
|
}
|
||||||
|
|
||||||
|
.title:hover > a, .title > a:hover, .title:hover > a:hover {
|
||||||
|
visibility: visible;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title:focus > a, .title > a:focus, .title:focus > a:focus {
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/background.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/callouts/1.png
Normal file
|
After Width: | Height: | Size: 329 B |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/callouts/2.png
Normal file
|
After Width: | Height: | Size: 353 B |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/callouts/3.png
Normal file
|
After Width: | Height: | Size: 350 B |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/caution.png
Normal file
|
After Width: | Height: | Size: 2.0 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/important.png
Normal file
|
After Width: | Height: | Size: 2.0 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/logo.png
Normal file
|
After Width: | Height: | Size: 4.3 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/note.png
Normal file
|
After Width: | Height: | Size: 2.2 KiB |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/tip.png
Normal file
|
After Width: | Height: | Size: 931 B |
BIN
spring-cloud-build/2.1.10.RELEASE/single/images/warning.png
Normal file
|
After Width: | Height: | Size: 2.1 KiB |
113
spring-cloud-build/2.1.10.RELEASE/single/spring-cloud-build.html
Normal file
117
spring-cloud-build/2.1.10.RELEASE/spring-cloud-build.html
Normal file
@@ -0,0 +1,117 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<!--[if IE]><meta http-equiv="X-UA-Compatible" content="IE=edge"><![endif]-->
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<meta name="generator" content="Asciidoctor 1.5.7.1">
|
||||||
|
<title>spring-cloud-build</title>
|
||||||
|
<link rel="stylesheet" href="css/manual-singlepage.css">
|
||||||
|
<style>
|
||||||
|
.hidden {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.switch {
|
||||||
|
border-width: 1px 1px 0 1px;
|
||||||
|
border-style: solid;
|
||||||
|
border-color: #7a2518;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.switch--item {
|
||||||
|
padding: 10px;
|
||||||
|
background-color: #ffffff;
|
||||||
|
color: #7a2518;
|
||||||
|
display: inline-block;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.switch--item.selected {
|
||||||
|
background-color: #7a2519;
|
||||||
|
color: #ffffff;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<script src="http://cdnjs.cloudflare.com/ajax/libs/zepto/1.2.0/zepto.min.js"></script>
|
||||||
|
<script type="text/javascript">
|
||||||
|
function addBlockSwitches() {
|
||||||
|
$('.primary').each(function() {
|
||||||
|
primary = $(this);
|
||||||
|
createSwitchItem(primary, createBlockSwitch(primary)).item.addClass("selected");
|
||||||
|
primary.children('.title').remove();
|
||||||
|
});
|
||||||
|
$('.secondary').each(function(idx, node) {
|
||||||
|
secondary = $(node);
|
||||||
|
primary = findPrimary(secondary);
|
||||||
|
switchItem = createSwitchItem(secondary, primary.children('.switch'));
|
||||||
|
switchItem.content.addClass('hidden');
|
||||||
|
findPrimary(secondary).append(switchItem.content);
|
||||||
|
secondary.remove();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function createBlockSwitch(primary) {
|
||||||
|
blockSwitch = $('<div class="switch"></div>');
|
||||||
|
primary.prepend(blockSwitch);
|
||||||
|
return blockSwitch;
|
||||||
|
}
|
||||||
|
|
||||||
|
function findPrimary(secondary) {
|
||||||
|
candidate = secondary.prev();
|
||||||
|
while (!candidate.is('.primary')) {
|
||||||
|
candidate = candidate.prev();
|
||||||
|
}
|
||||||
|
return candidate;
|
||||||
|
}
|
||||||
|
|
||||||
|
function createSwitchItem(block, blockSwitch) {
|
||||||
|
blockName = block.children('.title').text();
|
||||||
|
content = block.children('.content').first().append(block.next('.colist'));
|
||||||
|
item = $('<div class="switch--item">' + blockName + '</div>');
|
||||||
|
item.on('click', '', content, function(e) {
|
||||||
|
$(this).addClass('selected');
|
||||||
|
$(this).siblings().removeClass('selected');
|
||||||
|
e.data.siblings('.content').addClass('hidden');
|
||||||
|
e.data.removeClass('hidden');
|
||||||
|
});
|
||||||
|
blockSwitch.append(item);
|
||||||
|
return {'item': item, 'content': content};
|
||||||
|
}
|
||||||
|
|
||||||
|
$(addBlockSwitches);
|
||||||
|
</script>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body class="article">
|
||||||
|
<div id="header">
|
||||||
|
<h1>spring-cloud-build</h1>
|
||||||
|
</div>
|
||||||
|
<div id="content">
|
||||||
|
<div id="preamble">
|
||||||
|
<div class="sectionbody">
|
||||||
|
<div class="paragraph">
|
||||||
|
<p>2.1.10.RELEASE</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="sect1">
|
||||||
|
<h2 id="_pick_the_documentation_option">Pick The Documentation Option</h2>
|
||||||
|
<div class="sectionbody">
|
||||||
|
<div class="ulist">
|
||||||
|
<ul>
|
||||||
|
<li>
|
||||||
|
<p><a href="single/spring-cloud-build.html">Single HTML</a></p>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<p><a href="multi/multi_spring-cloud-build.html">Multi HTML</a></p>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prettify/r298/prettify.min.css">
|
||||||
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/prettify/r298/prettify.min.js"></script>
|
||||||
|
<script>prettyPrint()</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
330
spring-cloud-build/2.1.10.RELEASE/spring-cloud-build.xml
Normal file
@@ -0,0 +1,330 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<?asciidoc-toc?>
|
||||||
|
<?asciidoc-numbered?>
|
||||||
|
<book xmlns="http://docbook.org/ns/docbook" xmlns:xl="http://www.w3.org/1999/xlink" version="5.0" xml:lang="en">
|
||||||
|
<info>
|
||||||
|
<title>Spring Cloud Build</title>
|
||||||
|
<date>2020-01-31</date>
|
||||||
|
</info>
|
||||||
|
<preface>
|
||||||
|
<title></title>
|
||||||
|
<simpara><inlinemediaobject>
|
||||||
|
<imageobject>
|
||||||
|
<imagedata fileref="https://circleci.com/gh/spring-cloud/spring-cloud-build.svg?style=svg"/>
|
||||||
|
</imageobject>
|
||||||
|
<textobject><phrase>spring cloud build</phrase></textobject>
|
||||||
|
</inlinemediaobject></simpara>
|
||||||
|
<simpara>Spring Cloud Build is a common utility project for Spring Cloud
|
||||||
|
to use for plugin and dependency management.</simpara>
|
||||||
|
</preface>
|
||||||
|
<chapter xml:id="_building_and_deploying">
|
||||||
|
<title>Building and Deploying</title>
|
||||||
|
<simpara>To install locally:</simpara>
|
||||||
|
<screen>$ mvn install -s .settings.xml</screen>
|
||||||
|
<simpara>and to deploy snapshots to repo.spring.io:</simpara>
|
||||||
|
<screen>$ mvn deploy -DaltSnapshotDeploymentRepository=repo.spring.io::default::https://repo.spring.io/libs-snapshot-local</screen>
|
||||||
|
<simpara>for a RELEASE build use</simpara>
|
||||||
|
<screen>$ mvn deploy -DaltReleaseDeploymentRepository=repo.spring.io::default::https://repo.spring.io/libs-release-local</screen>
|
||||||
|
<simpara>and for jcenter use</simpara>
|
||||||
|
<screen>$ mvn deploy -DaltReleaseDeploymentRepository=bintray::default::https://api.bintray.com/maven/spring/jars/org.springframework.cloud:build</screen>
|
||||||
|
<simpara>and for Maven Central use</simpara>
|
||||||
|
<screen>$ mvn deploy -P central -DaltReleaseDeploymentRepository=sonatype-nexus-staging::default::https://oss.sonatype.org/service/local/staging/deploy/maven2</screen>
|
||||||
|
<simpara>(the "central" profile is available for all projects in Spring Cloud and it sets up the gpg jar signing, and the repository has to be specified separately for this project because it is a parent of the starter parent which users in turn have as their own parent).</simpara>
|
||||||
|
</chapter>
|
||||||
|
<chapter xml:id="_contributing">
|
||||||
|
<title>Contributing</title>
|
||||||
|
<simpara>Spring Cloud is released under the non-restrictive Apache 2.0 license,
|
||||||
|
and follows a very standard Github development process, using Github
|
||||||
|
tracker for issues and merging pull requests into master. If you want
|
||||||
|
to contribute even something trivial please do not hesitate, but
|
||||||
|
follow the guidelines below.</simpara>
|
||||||
|
<section xml:id="_sign_the_contributor_license_agreement">
|
||||||
|
<title>Sign the Contributor License Agreement</title>
|
||||||
|
<simpara>Before we accept a non-trivial patch or pull request we will need you to sign the
|
||||||
|
<link xl:href="https://cla.pivotal.io/sign/spring">Contributor License Agreement</link>.
|
||||||
|
Signing the contributor’s agreement does not grant anyone commit rights to the main
|
||||||
|
repository, but it does mean that we can accept your contributions, and you will get an
|
||||||
|
author credit if we do. Active contributors might be asked to join the core team, and
|
||||||
|
given the ability to merge pull requests.</simpara>
|
||||||
|
</section>
|
||||||
|
<section xml:id="_code_of_conduct">
|
||||||
|
<title>Code of Conduct</title>
|
||||||
|
<simpara>This project adheres to the Contributor Covenant <link xl:href="https://github.com/spring-cloud/spring-cloud-build/blob/master/docs/src/main/asciidoc/code-of-conduct.adoc">code of
|
||||||
|
conduct</link>. By participating, you are expected to uphold this code. Please report
|
||||||
|
unacceptable behavior to <link xl:href="mailto:spring-code-of-conduct@pivotal.io">spring-code-of-conduct@pivotal.io</link>.</simpara>
|
||||||
|
</section>
|
||||||
|
<section xml:id="_code_conventions_and_housekeeping">
|
||||||
|
<title>Code Conventions and Housekeeping</title>
|
||||||
|
<simpara>None of these is essential for a pull request, but they will all help. They can also be
|
||||||
|
added after the original pull request but before a merge.</simpara>
|
||||||
|
<itemizedlist>
|
||||||
|
<listitem>
|
||||||
|
<simpara>Use the Spring Framework code format conventions. If you use Eclipse
|
||||||
|
you can import formatter settings using the
|
||||||
|
<literal>eclipse-code-formatter.xml</literal> file from the
|
||||||
|
<link xl:href="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-dependencies-parent/eclipse-code-formatter.xml">Spring
|
||||||
|
Cloud Build</link> project. If using IntelliJ, you can use the
|
||||||
|
<link xl:href="https://plugins.jetbrains.com/plugin/6546">Eclipse Code Formatter
|
||||||
|
Plugin</link> to import the same file.</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>Make sure all new <literal>.java</literal> files to have a simple Javadoc class comment with at least an
|
||||||
|
<literal>@author</literal> tag identifying you, and preferably at least a paragraph on what the class is
|
||||||
|
for.</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>Add the ASF license header comment to all new <literal>.java</literal> files (copy from existing files
|
||||||
|
in the project)</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>Add yourself as an <literal>@author</literal> to the .java files that you modify substantially (more
|
||||||
|
than cosmetic changes).</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>Add some Javadocs and, if you change the namespace, some XSD doc elements.</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>A few unit tests would help a lot as well — someone has to do it.</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>If no-one else is using your branch, please rebase it against the current master (or
|
||||||
|
other target branch in the main project).</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara>When writing a commit message please follow <link xl:href="https://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html">these conventions</link>,
|
||||||
|
if you are fixing an existing issue please add <literal>Fixes gh-XXXX</literal> at the end of the commit
|
||||||
|
message (where XXXX is the issue number).</simpara>
|
||||||
|
</listitem>
|
||||||
|
</itemizedlist>
|
||||||
|
</section>
|
||||||
|
<section xml:id="_checkstyle">
|
||||||
|
<title>Checkstyle</title>
|
||||||
|
<simpara>Spring Cloud Build comes with a set of checkstyle rules. You can find them in the <literal>spring-cloud-build-tools</literal> module. The most notable files under the module are:</simpara>
|
||||||
|
<formalpara>
|
||||||
|
<title>spring-cloud-build-tools/</title>
|
||||||
|
<para>
|
||||||
|
<screen>└── src
|
||||||
|
├── checkstyle
|
||||||
|
│ └── checkstyle-suppressions.xml <co xml:id="CO1-1"/>
|
||||||
|
└── main
|
||||||
|
└── resources
|
||||||
|
├── checkstyle-header.txt <co xml:id="CO1-2"/>
|
||||||
|
└── checkstyle.xml <co xml:id="CO1-3"/></screen>
|
||||||
|
</para>
|
||||||
|
</formalpara>
|
||||||
|
<calloutlist>
|
||||||
|
<callout arearefs="CO1-3">
|
||||||
|
<para>Default Checkstyle rules</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO1-2">
|
||||||
|
<para>File header setup</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO1-1">
|
||||||
|
<para>Default suppression rules</para>
|
||||||
|
</callout>
|
||||||
|
</calloutlist>
|
||||||
|
<section xml:id="_checkstyle_configuration">
|
||||||
|
<title>Checkstyle configuration</title>
|
||||||
|
<simpara>Checkstyle rules are <emphasis role="strong">disabled by default</emphasis>. To add checkstyle to your project just define the following properties and plugins.</simpara>
|
||||||
|
<formalpara>
|
||||||
|
<title>pom.xml</title>
|
||||||
|
<para>
|
||||||
|
<screen><properties>
|
||||||
|
<maven-checkstyle-plugin.failsOnError>true</maven-checkstyle-plugin.failsOnError> <co xml:id="CO2-1"/>
|
||||||
|
<maven-checkstyle-plugin.failsOnViolation>true
|
||||||
|
</maven-checkstyle-plugin.failsOnViolation> <co xml:id="CO2-2"/>
|
||||||
|
<maven-checkstyle-plugin.includeTestSourceDirectory>true
|
||||||
|
</maven-checkstyle-plugin.includeTestSourceDirectory> <co xml:id="CO2-3"/>
|
||||||
|
</properties>
|
||||||
|
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin> <co xml:id="CO2-4"/>
|
||||||
|
<groupId>io.spring.javaformat</groupId>
|
||||||
|
<artifactId>spring-javaformat-maven-plugin</artifactId>
|
||||||
|
</plugin>
|
||||||
|
<plugin> <co xml:id="CO2-5"/>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
|
||||||
|
<reporting>
|
||||||
|
<plugins>
|
||||||
|
<plugin> <co xml:id="CO2-6"/>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-checkstyle-plugin</artifactId>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</reporting>
|
||||||
|
</build></screen>
|
||||||
|
</para>
|
||||||
|
</formalpara>
|
||||||
|
<calloutlist>
|
||||||
|
<callout arearefs="CO2-1">
|
||||||
|
<para>Fails the build upon Checkstyle errors</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO2-2">
|
||||||
|
<para>Fails the build upon Checkstyle violations</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO2-3">
|
||||||
|
<para>Checkstyle analyzes also the test sources</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO2-4">
|
||||||
|
<para>Add the Spring Java Format plugin that will reformat your code to pass most of the Checkstyle formatting rules</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO2-5 CO2-6">
|
||||||
|
<para>Add checkstyle plugin to your build and reporting phases</para>
|
||||||
|
</callout>
|
||||||
|
</calloutlist>
|
||||||
|
<simpara>If you need to suppress some rules (e.g. line length needs to be longer), then it’s enough for you to define a file under <literal>${project.root}/src/checkstyle/checkstyle-suppressions.xml</literal> with your suppressions. Example:</simpara>
|
||||||
|
<formalpara>
|
||||||
|
<title>projectRoot/src/checkstyle/checkstyle-suppresions.xml</title>
|
||||||
|
<para>
|
||||||
|
<screen><?xml version="1.0"?>
|
||||||
|
<!DOCTYPE suppressions PUBLIC
|
||||||
|
"-//Puppy Crawl//DTD Suppressions 1.1//EN"
|
||||||
|
"https://www.puppycrawl.com/dtds/suppressions_1_1.dtd">
|
||||||
|
<suppressions>
|
||||||
|
<suppress files=".*ConfigServerApplication\.java" checks="HideUtilityClassConstructor"/>
|
||||||
|
<suppress files=".*ConfigClientWatch\.java" checks="LineLengthCheck"/>
|
||||||
|
</suppressions></screen>
|
||||||
|
</para>
|
||||||
|
</formalpara>
|
||||||
|
<simpara>It’s advisable to copy the <literal>${spring-cloud-build.rootFolder}/.editorconfig</literal> and <literal>${spring-cloud-build.rootFolder}/.springformat</literal> to your project. That way, some default formatting rules will be applied. You can do so by running this script:</simpara>
|
||||||
|
<programlisting language="bash" linenumbering="unnumbered">$ curl https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/.editorconfig -o .editorconfig
|
||||||
|
$ touch .springformat</programlisting>
|
||||||
|
</section>
|
||||||
|
</section>
|
||||||
|
<section xml:id="_ide_setup">
|
||||||
|
<title>IDE setup</title>
|
||||||
|
<section xml:id="_intellij_idea">
|
||||||
|
<title>Intellij IDEA</title>
|
||||||
|
<simpara>In order to setup Intellij you should import our coding conventions, inspection profiles and set up the checkstyle plugin.
|
||||||
|
The following files can be found in the <link xl:href="https://github.com/spring-cloud/spring-cloud-build/tree/master/spring-cloud-build-tools">Spring Cloud Build</link> project.</simpara>
|
||||||
|
<formalpara>
|
||||||
|
<title>spring-cloud-build-tools/</title>
|
||||||
|
<para>
|
||||||
|
<screen>└── src
|
||||||
|
├── checkstyle
|
||||||
|
│ └── checkstyle-suppressions.xml <co xml:id="CO3-1"/>
|
||||||
|
└── main
|
||||||
|
└── resources
|
||||||
|
├── checkstyle-header.txt <co xml:id="CO3-2"/>
|
||||||
|
├── checkstyle.xml <co xml:id="CO3-3"/>
|
||||||
|
└── intellij
|
||||||
|
├── Intellij_Project_Defaults.xml <co xml:id="CO3-4"/>
|
||||||
|
└── Intellij_Spring_Boot_Java_Conventions.xml <co xml:id="CO3-5"/></screen>
|
||||||
|
</para>
|
||||||
|
</formalpara>
|
||||||
|
<calloutlist>
|
||||||
|
<callout arearefs="CO3-3">
|
||||||
|
<para>Default Checkstyle rules</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO3-2">
|
||||||
|
<para>File header setup</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO3-1">
|
||||||
|
<para>Default suppression rules</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO3-4">
|
||||||
|
<para>Project defaults for Intellij that apply most of Checkstyle rules</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO3-5">
|
||||||
|
<para>Project style conventions for Intellij that apply most of Checkstyle rules</para>
|
||||||
|
</callout>
|
||||||
|
</calloutlist>
|
||||||
|
<figure>
|
||||||
|
<title>Code style</title>
|
||||||
|
<mediaobject>
|
||||||
|
<imageobject>
|
||||||
|
<imagedata fileref="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/docs/src/main/asciidoc/images/intellij-code-style.png"/>
|
||||||
|
</imageobject>
|
||||||
|
<textobject><phrase>Code style</phrase></textobject>
|
||||||
|
</mediaobject>
|
||||||
|
</figure>
|
||||||
|
<simpara>Go to <literal>File</literal> → <literal>Settings</literal> → <literal>Editor</literal> → <literal>Code style</literal>. There click on the icon next to the <literal>Scheme</literal> section. There, click on the <literal>Import Scheme</literal> value and pick the <literal>Intellij IDEA code style XML</literal> option. Import the <literal>spring-cloud-build-tools/src/main/resources/intellij/Intellij_Spring_Boot_Java_Conventions.xml</literal> file.</simpara>
|
||||||
|
<figure>
|
||||||
|
<title>Inspection profiles</title>
|
||||||
|
<mediaobject>
|
||||||
|
<imageobject>
|
||||||
|
<imagedata fileref="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/docs/src/main/asciidoc/images/intellij-inspections.png"/>
|
||||||
|
</imageobject>
|
||||||
|
<textobject><phrase>Code style</phrase></textobject>
|
||||||
|
</mediaobject>
|
||||||
|
</figure>
|
||||||
|
<simpara>Go to <literal>File</literal> → <literal>Settings</literal> → <literal>Editor</literal> → <literal>Inspections</literal>. There click on the icon next to the <literal>Profile</literal> section. There, click on the <literal>Import Profile</literal> and import the <literal>spring-cloud-build-tools/src/main/resources/intellij/Intellij_Project_Defaults.xml</literal> file.</simpara>
|
||||||
|
<formalpara>
|
||||||
|
<title>Checkstyle</title>
|
||||||
|
<para>To have Intellij work with Checkstyle, you have to install the <literal>Checkstyle</literal> plugin. It’s advisable to also install the <literal>Assertions2Assertj</literal> to automatically convert the JUnit assertions</para>
|
||||||
|
</formalpara>
|
||||||
|
<informalfigure>
|
||||||
|
<mediaobject>
|
||||||
|
<imageobject>
|
||||||
|
<imagedata fileref="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/docs/src/main/asciidoc/images/intellij-checkstyle.png"/>
|
||||||
|
</imageobject>
|
||||||
|
<textobject><phrase>Checkstyle</phrase></textobject>
|
||||||
|
</mediaobject>
|
||||||
|
</informalfigure>
|
||||||
|
<simpara>Go to <literal>File</literal> → <literal>Settings</literal> → <literal>Other settings</literal> → <literal>Checkstyle</literal>. There click on the <literal>+</literal> icon in the <literal>Configuration file</literal> section. There, you’ll have to define where the checkstyle rules should be picked from. In the image above, we’ve picked the rules from the cloned Spring Cloud Build repository. However, you can point to the Spring Cloud Build’s GitHub repository (e.g. for the <literal>checkstyle.xml</literal> : <literal><link xl:href="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-build-tools/src/main/resources/checkstyle.xml">https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-build-tools/src/main/resources/checkstyle.xml</link></literal>). We need to provide the following variables:</simpara>
|
||||||
|
<itemizedlist>
|
||||||
|
<listitem>
|
||||||
|
<simpara><literal>checkstyle.header.file</literal> - please point it to the Spring Cloud Build’s, <literal>spring-cloud-build-tools/src/main/resources/checkstyle-header.txt</literal> file either in your cloned repo or via the <literal><link xl:href="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-build-tools/src/main/resources/checkstyle-header.txt">https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-build-tools/src/main/resources/checkstyle-header.txt</link></literal> URL.</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara><literal>checkstyle.suppressions.file</literal> - default suppressions. Please point it to the Spring Cloud Build’s, <literal>spring-cloud-build-tools/src/checkstyle/checkstyle-suppressions.xml</literal> file either in your cloned repo or via the <literal><link xl:href="https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-build-tools/src/checkstyle/checkstyle-suppressions.xml">https://raw.githubusercontent.com/spring-cloud/spring-cloud-build/master/spring-cloud-build-tools/src/checkstyle/checkstyle-suppressions.xml</link></literal> URL.</simpara>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<simpara><literal>checkstyle.additional.suppressions.file</literal> - this variable corresponds to suppressions in your local project. E.g. you’re working on <literal>spring-cloud-contract</literal>. Then point to the <literal>project-root/src/checkstyle/checkstyle-suppressions.xml</literal> folder. Example for <literal>spring-cloud-contract</literal> would be: <literal>/home/username/spring-cloud-contract/src/checkstyle/checkstyle-suppressions.xml</literal>.</simpara>
|
||||||
|
</listitem>
|
||||||
|
</itemizedlist>
|
||||||
|
<important>
|
||||||
|
<simpara>Remember to set the <literal>Scan Scope</literal> to <literal>All sources</literal> since we apply checkstyle rules for production and test sources.</simpara>
|
||||||
|
</important>
|
||||||
|
</section>
|
||||||
|
</section>
|
||||||
|
</chapter>
|
||||||
|
<chapter xml:id="_reusing_the_documentation">
|
||||||
|
<title>Reusing the documentation</title>
|
||||||
|
<simpara>Spring Cloud Build publishes its <literal>spring-cloud-build-docs</literal> module that contains
|
||||||
|
helpful scripts (e.g. README generation ruby script) and css, xslt and images
|
||||||
|
for the Spring Cloud documentation. If you want to follow the same convention
|
||||||
|
approach of generating documentation just add these plugins to your <literal>docs</literal> module</simpara>
|
||||||
|
<programlisting language="xml" linenumbering="unnumbered"><profiles>
|
||||||
|
<profile>
|
||||||
|
<id>docs</id>
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-dependency-plugin</artifactId> <co xml:id="CO4-1"/>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.asciidoctor</groupId>
|
||||||
|
<artifactId>asciidoctor-maven-plugin</artifactId> <co xml:id="CO4-2"/>
|
||||||
|
</plugin>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-antrun-plugin</artifactId> <co xml:id="CO4-3"/>
|
||||||
|
<inherited>false</inherited>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
</profile>
|
||||||
|
</profiles></programlisting>
|
||||||
|
<calloutlist>
|
||||||
|
<callout arearefs="CO4-1">
|
||||||
|
<para>This plugin downloads and unpacks the resources of the <literal>spring-cloud-build-docs</literal> module</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO4-2">
|
||||||
|
<para>This plugin is required to parse the Asciidoctor documentation</para>
|
||||||
|
</callout>
|
||||||
|
<callout arearefs="CO4-3">
|
||||||
|
<para>This plugin is required to copy resources into proper final destinations and to generate main README.adoc</para>
|
||||||
|
</callout>
|
||||||
|
</calloutlist>
|
||||||
|
<important>
|
||||||
|
<simpara>The order of plugin declaration is important!</simpara>
|
||||||
|
</important>
|
||||||
|
</chapter>
|
||||||
|
</book>
|
||||||