Skip to content

Commit

Permalink
SQUASH – wip – generate spec html pages for each intree version
Browse files Browse the repository at this point in the history
  • Loading branch information
michaelsembwever committed Dec 30, 2024
1 parent a5deafa commit dcae2d8
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 107 deletions.
12 changes: 3 additions & 9 deletions cqlprotodoc/template.gohtml
Original file line number Diff line number Diff line change
Expand Up @@ -24,15 +24,9 @@
</style>
</head>
<body>
<nav class="top">
<ul>
<li><a href="native_protocol_v5.html">v5</a></li>
<li><a href="native_protocol_v4.html">v4</a></li>
<li><a href="native_protocol_v3.html">v3</a></li>
<li><a href="NOTICE">NOTICE</a></li>
</ul>
</nav>
<pre>{{.LicenseHTML}}</pre>
<!--
{{.LicenseHTML}}
-->
<h1>{{.Title}}</h1>
<h2>Table of Contents</h2>
<nav>
Expand Down
2 changes: 1 addition & 1 deletion site-content/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ RUN apt update && \
apt install -y \
openjdk-8-jdk \
openjdk-11-jdk \
openjdk-17-jdk \
python3 \
python3-pip \
ant \
Expand Down Expand Up @@ -123,7 +124,6 @@ EXPOSE 5151/tcp
USER ${BUILD_USER}
WORKDIR ${BUILD_DIR}
COPY docker-entrypoint.sh /usr/local/bin/
COPY process-native-protocol-specs-in-docker.sh /usr/local/bin/
ENTRYPOINT ["docker-entrypoint.sh"]

# Possible commands are listed below. The entrypoint will accept any combination of these commands.
Expand Down
63 changes: 22 additions & 41 deletions site-content/docker-entrypoint.sh
Original file line number Diff line number Diff line change
@@ -1,4 +1,19 @@
#!/bin/bash
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# Abort script if a command fails
set -e
Expand All @@ -7,7 +22,6 @@ export CASSANDRA_USE_JDK11=true
export CASSANDRA_WEBSITE_DIR="${BUILD_DIR}/cassandra-website"
export CASSANDRA_SOURCE_DIR="${BUILD_DIR}/cassandra"
export CASSANDRA_WORKING_DIR="${BUILD_DIR}/working/cassandra"
export CASSANDRA_WORKING_DOC="${CASSANDRA_WORKING_DIR}/doc"
GIT_USER_SETUP="false"

setup_git_user() {
Expand Down Expand Up @@ -49,10 +63,10 @@ generate_cassandra_versioned_docs() {
commit_changes_to_branch="disabled"
fi

pushd "${CASSANDRA_WORKING_DIR}" > /dev/null
for version in ${GENERATE_CASSANDRA_VERSIONS}
do
log_message "INFO" "Checking out '${version}'"
pushd "${CASSANDRA_WORKING_DIR}" > /dev/null
git clean -xdff
git checkout "${version}"

Expand All @@ -70,23 +84,24 @@ generate_cassandra_versioned_docs() {
# For Cassandra 3.11 docs use JDK 8
java_version="/usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java"
javac_version="/usr/lib/jvm/java-8-openjdk-amd64/bin/javac"
ant_cmd_options=""
else
elif [ "$(cut -d'.' -f1 <<< "${doc_version}")" -lt 5 ]
then
# For Cassandra 4.0+ docs use JDK 11
# TODO – from 5 onwards, we can detect the default JDK version from the build.xml file
java_version="/usr/lib/jvm/java-11-openjdk-amd64/bin/java"
javac_version="/usr/lib/jvm/java-11-openjdk-amd64/bin/javac"
ant_cmd_options="-Duse.jdk11=true"
else
java_version_=$(grep 'property\s*name="java.default"' build.xml |sed -ne 's/.*value="\([^"]*\)".*/\1/p')
java_version="/usr/lib/jvm/java-${java_version_}-openjdk-amd64/bin/java"
javac_version="/usr/lib/jvm/java-${java_version_}-openjdk-amd64/bin/javac"
fi
sudo update-alternatives --set java ${java_version}
sudo update-alternatives --set javac ${javac_version}

log_message "INFO" "Using Java compiler version $(javac -version) to compile Cassandra JARs"
ant realclean
ant "${ant_cmd_options}" gen-asciidoc
popd > /dev/null

pushd "${CASSANDRA_WORKING_DIR}" > /dev/null
if [ "${commit_changes_to_branch}" = "enabled" ]
then
# Remove the doc/* directory entries in the .gitignore file so we can commit the generated docs to the working
Expand Down Expand Up @@ -204,33 +219,13 @@ render_site_content_to_html() {
popd > /dev/null
}

generate_native_protocol_specs_pages() {
log_message "INFO" "Processing native protocols spec page"
for version in ${GENERATE_CASSANDRA_VERSIONS}
do
log_message "INFO" "Checking out '${version}'"
pushd "${CASSANDRA_WORKING_DIR}" > /dev/null
git clean -xdff
git checkout "${version}"

local doc_version=""
doc_version=$(grep 'property\s*name=\"base.version\"' build.xml |sed -ne 's/.*value=\"\([^"]*\)\".*/\1/p')
if [ -d "${CASSANDRA_WEBSITE_DIR}/site-content/build/html/Cassandra/$(cut -d'.' -f1-2 <<< "${doc_version}")/cassandra/native-protocol" ]
then
sudo /usr/local/bin/process-native-protocol-specs-in-docker.sh "$(cut -d'.' -f1-2 <<< "${doc_version}")"
fi
popd > /dev/null
done
}

prepare_site_html_for_publication() {
pushd "${CASSANDRA_WEBSITE_DIR}" > /dev/null

# copy everything to content/ directory
log_message "INFO" "Moving site HTML to content/"
mkdir -p content/doc
cp -r site-content/build/html/* content/
#rm -f content/_/sed*

# remove hardcoded domain name, and empty domain names first before we duplicate and documentation
content_files_to_change=($(grep -rl 'https://cassandra.apache.org/' content/))
Expand Down Expand Up @@ -332,15 +327,6 @@ run_preview_mode() {
render_site_content_to_html
fi

if [ "${COMMAND_GENERATE_DOCS}" = "run" ]
then
export -f generate_native_protocol_specs_pages
on_change_functions="${on_change_functions} && generate_native_protocol_specs_pages"

GENERATE_CASSANDRA_VERSIONS=$(cut -d' ' -f1 <<< "${GENERATE_CASSANDRA_VERSIONS}")
fi


pushd "${CASSANDRA_WEBSITE_DIR}/site-content/build/html" > /dev/null
live-server --port=5151 --host=0.0.0.0 --no-browser --no-css-inject --wait=2000 &
popd > /dev/null
Expand Down Expand Up @@ -432,11 +418,6 @@ then
export DOCSEARCH_INDEX_VERSION=latest

render_site_content_to_html
if [ "${COMMAND_GENERATE_DOCS}" = "run" ]
then
generate_native_protocol_specs_pages
fi

prepare_site_html_for_publication
fi

Expand Down
53 changes: 0 additions & 53 deletions site-content/process-native-protocol-specs-in-docker.sh

This file was deleted.

6 changes: 3 additions & 3 deletions site-ui/src/layouts/native-protocol.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -158,9 +158,9 @@
}
const files = [
'native_protocol_v3.html',
'native_protocol_v4.html',
'native_protocol_v5.html',
'../_attachments/native_protocol_v3.html',
'../_attachments/native_protocol_v4.html',
'../_attachments/native_protocol_v5.html',
];
window.onload = function () {
Expand Down

0 comments on commit dcae2d8

Please sign in to comment.