Merge branch '87-add-ci-job-for-pages' into 'master'
Added simple shell script for generating HTML overviews of the overlay contents Closes #87 See merge request !156
This commit is contained in:
commit
d5178b1dea
3 changed files with 107 additions and 2 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1 +1,2 @@
|
|||
*~
|
||||
.public/
|
||||
|
|
|
@ -12,8 +12,8 @@ pages:
|
|||
only:
|
||||
- master
|
||||
script:
|
||||
- mkdir .public
|
||||
- mv * .public
|
||||
- chmod +x .gitlab-pages-generator.sh
|
||||
- ./gitlab-pages-generator.sh . .public
|
||||
- mv .public public
|
||||
artifacts:
|
||||
paths:
|
||||
|
|
104
.gitlab-pages-generator.sh
Executable file
104
.gitlab-pages-generator.sh
Executable file
|
@ -0,0 +1,104 @@
|
|||
#!/bin/sh
|
||||
|
||||
ROOT=$(realpath "${1:-.}")
|
||||
TARGET=$(realpath "${2:-.public}")
|
||||
declare -a PARTS=()
|
||||
|
||||
function createDir() {
|
||||
mkdir -p "${1}"
|
||||
}
|
||||
|
||||
function createDirInTarget() {
|
||||
local dirpart="${1}"
|
||||
local destinationdirectory=${dirpart/${ROOT}/${TARGET}}
|
||||
echo $destinationdirectory
|
||||
}
|
||||
|
||||
function writeHTMLHeader() {
|
||||
local targetfile="${1}"
|
||||
local currentdir="${2}"
|
||||
|
||||
cat <<EOHEAD > "${targetfile}"
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>gentoo-overlay/${currentdir}</title>
|
||||
</head>
|
||||
<body>
|
||||
<h1>gentoo-overlay/${currentdir}</h1>
|
||||
<ul>
|
||||
EOHEAD
|
||||
}
|
||||
|
||||
function writeHTMLFooter() {
|
||||
local targetfile="${1}"
|
||||
cat <<EOFOOT >> "${targetfile}"
|
||||
</ul>
|
||||
</body>
|
||||
</html>
|
||||
EOFOOT
|
||||
}
|
||||
|
||||
function writeHTMLFileentry() {
|
||||
local targetfile="${1}"
|
||||
local filename="${2}"
|
||||
cat <<EOFILE >> "${targetfile}"
|
||||
<li><a href="${filename}">${filename}</a></li>
|
||||
EOFILE
|
||||
}
|
||||
|
||||
function pushPart() {
|
||||
local part="${1}"
|
||||
PARTS=("${PARTS[@]}" "${part}")
|
||||
}
|
||||
|
||||
function popPart() {
|
||||
local index=$(expr ${#PARTS[@]} - 1)
|
||||
unset PARTS[${index}]
|
||||
}
|
||||
|
||||
function renderParts() {
|
||||
local IFS="/"
|
||||
echo "${PARTS[*]}"
|
||||
}
|
||||
|
||||
function renderTargetPath() {
|
||||
local parts=$(renderParts)
|
||||
echo "${TARGET}${parts:+/}${parts}"
|
||||
}
|
||||
|
||||
function renderTargetFilename() {
|
||||
local targetPath=$(renderTargetPath)
|
||||
echo "${targetPath}/index.html"
|
||||
}
|
||||
|
||||
function processDir() {
|
||||
local dir="${1}"
|
||||
cd "${dir}"
|
||||
local realpath=$(realpath .)
|
||||
local files=$(ls)
|
||||
local parts=$(renderParts)
|
||||
local targetPath=$(renderTargetPath)
|
||||
local targetFilename=$(renderTargetFilename)
|
||||
mkdir -p "${targetPath}"
|
||||
writeHTMLHeader "${targetFilename}" "${parts}"
|
||||
writeHTMLFileentry "${targetFilename}" ".."
|
||||
for f in ${files} ; do
|
||||
if [ -f "${f}" ] ;then
|
||||
cp "${f}" "${targetPath}"
|
||||
writeHTMLFileentry "${targetFilename}" "${f}"
|
||||
elif [ -d "${f}" ] ; then
|
||||
writeHTMLFileentry "${targetFilename}" "${f}/"
|
||||
pushPart "${f}"
|
||||
processDir "${f}"
|
||||
popPart
|
||||
else
|
||||
echo "Unknown: ${f}"
|
||||
fi
|
||||
done
|
||||
writeHTMLFooter "${targetFilename}"
|
||||
cd ..
|
||||
}
|
||||
|
||||
processDir "${ROOT}"
|
Loading…
Reference in a new issue