Compare commits

...

8 commits
v0.0.2 ... main

Author SHA1 Message Date
leafee98 24172f0771 fix: can't switch to remote branch by git fragment 2024-01-31 14:08:51 +08:00
leafee98 932f8b695e breaking: exit normally when package already built
This is helpful when using local_build.sh scripts.
2024-01-30 16:32:31 +08:00
leafee98 985c0e7a06 Add argument --is-dynamic-pkgver 2023-08-18 20:04:03 +08:00
leafee98 fe278387e5 Add help for --nobuild argument 2023-08-18 19:35:30 +08:00
leafee98 9aedecc62e Add help msg, use _STEP_CHCECK_PACKAGE_EXISTS to replace FORCE 2023-08-18 17:26:56 +08:00
leafee98 3065562dab Refactor code, refactor build script
- Refactor log
- Use variable to specific which step to run, and stop after which step
- Add a lot of program arguments
2023-08-17 16:42:56 +08:00
leafee98 3500ce0058 typo: retrive, fix err use a second level log mark 2023-08-11 21:48:46 +08:00
leafee98 dec5faa54b add section, priority and homepage properties 2023-08-02 22:18:56 +08:00
3 changed files with 206 additions and 81 deletions

View file

@ -1,9 +1,12 @@
#/usr/bin/env bash #/usr/bin/env bash
pkgname="makedeb" pkgname="makedeb"
pkgver=0.0.1.0.g34537bd pkgver=0.0.2.0.g175943a
pkgrel=1 pkgrel=1
arch="all"
pkgcommit="" pkgcommit=""
section="utils" # https://www.debian.org/doc/debian-policy/ch-archive.html#s-subsections
priority="optional" # https://www.debian.org/doc/debian-policy/ch-archive.html#s-priorities
pkgdesc="A painless selfhost git service." pkgdesc="A painless selfhost git service."
url="https://git.leafee98.com/leafee98/makedeb" url="https://git.leafee98.com/leafee98/makedeb"
maintainer="Leafee98 <me@leafee98.com>" maintainer="Leafee98 <me@leafee98.com>"

View file

@ -22,6 +22,8 @@ Every string in array `source` should be like `<actual_file_name>::<download_url
- `pkgver`: package's version, if need to extract version from source, use function `pkgver` - `pkgver`: package's version, if need to extract version from source, use function `pkgver`
- `pkgrel`: debian package reference, it should increase by one every build - `pkgrel`: debian package reference, it should increase by one every build
- `pkgdesc`: package's description - `pkgdesc`: package's description
- `section`: default `misc` if not specified
- `priority`: default `optional` if not specified
- `url`: packages upstream url - `url`: packages upstream url
- `maintainer`: maintainer's contect information - `maintainer`: maintainer's contect information

270
makedeb
View file

@ -6,10 +6,32 @@ buildfile="${workspace}/DEBBUILD"
srcdir="${workspace}/src" srcdir="${workspace}/src"
pkgdir="${workspace}/pkg" pkgdir="${workspace}/pkg"
FAKE_PACKAGE=0 _IN_FAKEROOT=0
_BACKUP_STDOUT=3 # use file descriptor 3 to backup stdout
_BACKUP_STDERR=4 # use file descriptor 4 to backup stderr
_ARGLIST=("$@")
OVERRIDE_SOURCE=0 OVERRIDE_SOURCE=0
SHOW_TARGET_FILE=0
QUIET=0 QUIET=0
PACKAGELIST=0
IS_DYNAMICV_PKGVER=0
_STEP_CLEAN=1
_STEP_RETRIEVE_SOURCE=1
_STEP_EXTRACT_SOURCE=1
_STEP_UPDATE_PKGVER=1
_STEP_CHCECK_PACKAGE_EXISTS=1
_STEP_BUILD=1
_STEP_PACKAGE=1
_STEP_CREATE_ARCHIVE=1
_STOP_AFTER_CLEAN=0
_STOP_AFTER_RETRIEVE_SOURCE=0
_STOP_AFTER_EXTRACT_SOURCE=0
_STOP_AFTER_UPDATE_PKGVER=0
#_STEP_CHCECK_PACKAGE_EXISTS=0 # stop after checking exists is useless
_STOP_AFTER_BUILD=0
_STOP_AFTER_PACKAGE=0
_STOP_AFTER_CREATE_ARCHIVE=0
set -o functrace set -o functrace
set -o nounset set -o nounset
@ -50,10 +72,15 @@ function msg2 {
local mesg=$1; shift local mesg=$1; shift
printf "${BLUE} ->${ALL_OFF}${BOLD} ${mesg}${ALL_OFF}\n" "$@" printf "${BLUE} ->${ALL_OFF}${BOLD} ${mesg}${ALL_OFF}\n" "$@"
} }
function warn {
(( QUIET )) && return 0
local mesg=$1; shift
printf "${YELLOW}==>${ALL_OFF}${BOLD}${YELLOW} ${mesg}${ALL_OFF}\n" "$@" >&2
}
function err { function err {
(( QUIET )) && return 0 (( QUIET )) && return 0
local mesg=$1; shift local mesg=$1; shift
printf "${RED} ->${ALL_OFF}${BOLD}${RED} ${mesg}${ALL_OFF}\n" "$@" >&2 printf "${RED}==>${ALL_OFF}${BOLD}${RED} ${mesg}${ALL_OFF}\n" "$@" >&2
} }
function get_full_version { function get_full_version {
@ -75,18 +102,35 @@ function debian_control {
local install_size="$(du --block-size=1K --summarize ${pkgdir} | cut -d $'\t' -f 1)" local install_size="$(du --block-size=1K --summarize ${pkgdir} | cut -d $'\t' -f 1)"
local fv="$(get_full_version)" local fv="$(get_full_version)"
cat << EOF | envsubst echo "Package: ${pkgname}"
Package: ${pkgname} echo "Version: ${fv}"
Version: ${fv} echo "Architecture: ${arch}"
Architecture: all echo "Maintainer: ${maintainer}"
Maintainer: ${maintainer} echo "Installed-Size: ${install_size}"
Installed-Size: ${install_size} echo "Homepage: ${url}"
Description: ${pkgdesc}
EOF [[ -n "${section:=misc}" ]] && echo "Section: ${section}"
[[ -n "${priority:=optional}" ]] && echo "Priority: ${priority}"
echo "Description: ${pkgdesc}"
} }
function generate_control {
msg "Generating control info..."
mkdir -p "${pkgdir}/DEBIAN"
echo 2 > "${pkgdir}/DEBIAN/compat"
debian_control > "${pkgdir}/DEBIAN/control"
function debian_hooks_warpper { is_function "$1" && "$1" > "$2" && chmod +x "$2" || true; }
debian_hooks_warpper debian_preinst ${pkgdir}/DEBIAN/preinst
debian_hooks_warpper debian_postinst ${pkgdir}/DEBIAN/postinst
debian_hooks_warpper debian_prerm ${pkgdir}/DEBIAN/prerm
debian_hooks_warpper debian_postrm ${pkgdir}/DEBIAN/postrm
}
function generate_deb { function generate_deb {
msg "generating deb package..." msg "Generating deb package..."
local tmpdir="$(mktemp --directory)" local tmpdir="$(mktemp --directory)"
local data_tgz="${tmpdir}/data.tar.gz" local data_tgz="${tmpdir}/data.tar.gz"
@ -103,7 +147,12 @@ function generate_deb {
rm -rf "${tmpdir}" rm -rf "${tmpdir}"
msg2 "generated deb: %s" "$(get_deb_name)" msg2 "Generated deb: %s" "$(get_deb_name)"
}
function step_create_archive {
generate_control
generate_deb
} }
function url_type { function url_type {
@ -134,10 +183,12 @@ function create_soft_link {
if [[ ! -e "${src}" ]] ; then if [[ ! -e "${src}" ]] ; then
err "soft_link src %s not exist" "${src}" err "soft_link src %s not exist" "${src}"
return 1
fi fi
if [[ -e "${tgt}" ]] ; then if [[ -e "${tgt}" ]] ; then
err "soft_link tgt %s already exist" "${tgt}" err "soft_link tgt %s already exist" "${tgt}"
return 1
fi fi
ln --symbolic "${src}" "${tgt}" ln --symbolic "${src}" "${tgt}"
@ -154,17 +205,17 @@ function url_fragment {
# $1 is relative path to file # $1 is relative path to file
# $2 is url/(relative path to materials) # $2 is url/(relative path to materials)
function retrive_source_single { function retrieve_source_single {
local file_name="$1" local file_name="$1"
local url="$2" local url="$2"
case "$(url_type "${url}")" in case "$(url_type "${url}")" in
"git") "git")
if [[ -d "${file_name}" ]]; then if [[ -d "${file_name}" ]]; then
msg2 "updating ${file_name} from ${url} with git..." msg2 "Updating ${file_name} from ${url} with git..."
git --git-dir="${workspace}/${file_name}" fetch --all git --git-dir="${workspace}/${file_name}" fetch --all
else else
msg2 "cloning ${file_name} from ${url} with git..." msg2 "Cloning ${file_name} from ${url} with git..."
local git_source="${url##git+}" local git_source="${url##git+}"
git_source="${git_source%%#*}" git_source="${git_source%%#*}"
git clone --mirror "${git_source}" "${workspace}/${file_name}" git clone --mirror "${git_source}" "${workspace}/${file_name}"
@ -174,21 +225,21 @@ function retrive_source_single {
if (( ! OVERRIDE_SOURCE )) && [[ -f "${workspace}/${file_name}" ]] ; then if (( ! OVERRIDE_SOURCE )) && [[ -f "${workspace}/${file_name}" ]] ; then
msg2 "${file_name} already exists, skip download" msg2 "${file_name} already exists, skip download"
else else
msg2 "retriving ${file_name} from ${url} with curl..." msg2 "Retrieving ${file_name} from ${url} with curl..."
curl --location "${url}" --output "${workspace}/${file_name}" curl --location "${url}" --output "${workspace}/${file_name}"
fi fi
;; ;;
"file") "file")
if [[ -e "${workspace}/${url}" ]] ; then if [[ -e "${workspace}/${url}" ]] ; then
msg2 "found local file: ${url}" msg2 "Found local file: ${url}"
else else
err "local file not found: ${url}" err "Local file not found: ${url}"
err "Aborting..." err "Aborting..."
exit 1 exit 1
fi fi
;; ;;
*) *)
err "retriving url as type ${url_type} not supported" err "Retrieving url as type ${url_type} not supported"
err "Aborting..." err "Aborting..."
exit 1 exit 1
esac esac
@ -210,7 +261,7 @@ function extract_source_single {
if [[ -n "${frag}" ]] ; then if [[ -n "${frag}" ]] ; then
case "${frag%%=*}" in case "${frag%%=*}" in
"branch") "branch")
ref="refs/heads/${frag##*=}" ref="refs/remotes/origin/${frag##*=}"
;; ;;
"tag") "tag")
ref="refs/tags/${frag##*=}" ref="refs/tags/${frag##*=}"
@ -225,7 +276,7 @@ function extract_source_single {
esac esac
fi fi
msg2 "extracting git ${workspace}/${file_name} with reference ${ref}" msg2 "Extracting git ${workspace}/${file_name} with reference ${ref}"
git clone --shared "${workspace}/${file_name}" "${srcdir}/${file_name}" git clone --shared "${workspace}/${file_name}" "${srcdir}/${file_name}"
git -C "${srcdir}/${file_name}" switch --force-create makedeb --no-track "${ref}" git -C "${srcdir}/${file_name}" switch --force-create makedeb --no-track "${ref}"
;; ;;
@ -257,11 +308,11 @@ function decompress_source_file {
*.zip) *.zip)
cmd="unzip" ;; cmd="unzip" ;;
*) *)
msg2 "no need to decompress, skip %s" "${file}" msg2 "No need to decompress, skip %s" "${file}"
return return
esac esac
msg2 "decompressing %s with %s" "${file}" "${cmd}" msg2 "Decompressing %s with %s" "${file}" "${cmd}"
local res=0 local res=0
case "$cmd" in case "$cmd" in
"tar") "tar")
@ -319,24 +370,24 @@ function check_source_validation {
done done
} }
function clean_dir { function step_clean_dir {
msg "cleaning \$srcdir and \$pkgdir..." msg "Cleaning \$srcdir and \$pkgdir..."
rm -rf "${srcdir}" "${pkgdir}" rm -rf "${srcdir}" "${pkgdir}"
mkdir -p "${srcdir}" "${pkgdir}" mkdir -p "${srcdir}" "${pkgdir}"
} }
function retrieve_source { function step_retrieve_source {
msg "retrieving source..." msg "Retrieving source..."
for s in "${source[@]}"; do for s in "${source[@]}"; do
file_name="${s%%::*}" file_name="${s%%::*}"
url="${s##*::}" url="${s##*::}"
retrive_source_single "${file_name}" "${url}" retrieve_source_single "${file_name}" "${url}"
done done
} }
function extract_source { function step_extract_source {
msg "extracting source..." msg "Extracting source..."
for s in "${source[@]}"; do for s in "${source[@]}"; do
file_name="${s%%::*}" file_name="${s%%::*}"
url="${s##*::}" url="${s##*::}"
@ -345,12 +396,12 @@ function extract_source {
done done
} }
function update_pkgver { function step_update_pkgver {
if ! is_function pkgver; then if ! is_function pkgver; then
return return
fi fi
msg "updating pkgver..." msg "Updating pkgver..."
newpkgver="$(run_function_safe pkgver)" newpkgver="$(run_function_safe pkgver)"
if [[ "${newpkgver}" != "${pkgver:-}" ]] ; then if [[ "${newpkgver}" != "${pkgver:-}" ]] ; then
mapfile -t bfcontent < "${buildfile}" mapfile -t bfcontent < "${buildfile}"
@ -367,33 +418,41 @@ function update_pkgver {
source "${buildfile}" source "${buildfile}"
msg2 "updated version: ${newpkgver}" msg2 "Updated version: ${newpkgver}"
fi fi
pkgver="${newpkgver}" pkgver="${newpkgver}"
} }
function generate_control {
msg "generating control info..."
mkdir -p "${pkgdir}/DEBIAN"
echo 2 > "${pkgdir}/DEBIAN/compat"
debian_control > "${pkgdir}/DEBIAN/control"
function debian_hooks_warpper { is_function "$1" && "$1" > "$2" && chmod +x "$2" || true; }
debian_hooks_warpper debian_preinst ${pkgdir}/DEBIAN/preinst
debian_hooks_warpper debian_postinst ${pkgdir}/DEBIAN/postinst
debian_hooks_warpper debian_prerm ${pkgdir}/DEBIAN/prerm
debian_hooks_warpper debian_postrm ${pkgdir}/DEBIAN/postrm
}
function run_function { function run_function {
if is_function "$1" ; then if is_function "$1" ; then
msg "run function: $1" msg "Run function: $1"
run_function_safe "$1" run_function_safe "$1"
fi fi
} }
function disable_stdout {
exec {_BACKUP_STDOUT}>&1
exec 1>/dev/null
}
function enable_stdout {
exec 1>&"$_BACKUP_STDOUT"
}
function show_help {
echo "$0 [OPTIONS]"
echo " -Q quiet, disable log"
echo " -f|--force don't check if package already exists, will"
echo " --nobuild retrieve source, update pkgver and stop"
echo " override the existed package"
echo " --noextract use the current srcdir to build package, skip"
echo " those retrieve source steps"
echo " --noarchive retrieve and build, but don't package to .deb"
echo " --packagelist show file to be generated by current DEBBUILD"
echo " --is-dynamic-pkgver exit with 0 if DEBBUILD will update pkgver later"
echo " -h|--help show this message"
}
## ##
## Here start the build logic ## Here start the build logic
@ -401,11 +460,36 @@ function run_function {
while (( "$#" >= 1 )); do while (( "$#" >= 1 )); do
case "$1" in case "$1" in
-F) FAKE_PACKAGE=1 ;; -F) _IN_FAKEROOT=1 ;;
-OS) OVERRIDE_SOURCE=1 ;;
-STF) SHOW_TARGET_FILE=1 ; QUIET=1 ;;
-Q) QUIET=1 ;; -Q) QUIET=1 ;;
*) err "Unkown option $1"; break ;; -f|--force) _STEP_CHCECK_PACKAGE_EXISTS=0 ;;
--noextract)
_STEP_CLEAN=0
_STEP_RETRIEVE_SOURCE=0
_STEP_EXTRACT_SOURCE=0
_STEP_UPDATE_PKGVER=0
;;
--nobuild)
_STEP_CHCECK_PACKAGE_EXISTS=0
_STEP_BUILD=0
_STEP_PACKAGE=0
_STEP_CREATE_ARCHIVE=0
_STOP_AFTER_UPDATE_PKGVER=1
;;
--noarchive)
_STEP_CHCECK_PACKAGE_EXISTS=0
_STEP_CREATE_ARCHIVE=0
_STOP_AFTER_BUILD=1
;;
--packagelist) PACKAGELIST=1 ;;
--is-dynamic-pkgver) IS_DYNAMICV_PKGVER=1 ;;
-h|--help) show_help ; exit 0;;
*) err "Unkown option $1"
err "Use $0 --help for help"
exit 1 ;;
esac esac
shift shift
done done
@ -413,39 +497,75 @@ done
source "${buildfile}" source "${buildfile}"
if (( ! FAKE_PACKAGE )) ; then if (( PACKAGELIST )) ; then
if (( SHOW_TARGET_FILE )) && ! is_function pkgver ; then
echo "$(get_deb_name)" echo "$(get_deb_name)"
exit 0 exit 0
fi fi
if (( IS_DYNAMICV_PKGVER )) ; then
if is_function pkgver ; then
exit 0
else
exit 4
fi
fi
if (( QUIET )) ; then
disable_stdout
fi
if (( ! _IN_FAKEROOT )) ; then
check_source_validation check_source_validation
clean_dir if (( _STEP_CLEAN )) ; then
step_clean_dir
retrieve_source
extract_source
update_pkgver
if (( SHOW_TARGET_FILE )) && is_function pkgver ; then
echo "$(get_deb_name)"
exit 0
fi fi
if (( _STEP_RETRIEVE_SOURCE )) ; then
step_retrieve_source
fi
if (( _STEP_EXTRACT_SOURCE )) ; then
step_extract_source
fi
if (( _STEP_UPDATE_PKGVER )) ; then
step_update_pkgver
(( _STOP_AFTER_UPDATE_PKGVER )) && msg "Sources are ready."
fi
# Check if the package already exists
if (( _STEP_CHCECK_PACKAGE_EXISTS )) ; then
if [[ -f "$(get_deb_name)" ]] ; then
warn "%s %s" \
"The package $(get_deb_name) already exists, skipping build." \
"(use -f to force re-build)"
exit 0
fi
fi
if (( _STEP_BUILD )) ; then
run_function build run_function build
(( _STOP_AFTER_BUILD )) && msg "Package directory is ready."
fi
if (( _STEP_PACKAGE || _STEP_CREATE_ARCHIVE )) ; then
# recursive call self to run rest task in fakeroot # recursive call self to run rest task in fakeroot
msg "entering fakeroot environment..." msg "Entering fakeroot environment..."
fakeroot -- bash -$- "${BASH_SOURCE[0]}" -F "${ARGLIST[@]}" || exit $? fakeroot -- bash -$- "${BASH_SOURCE[0]}" -F "${_ARGLIST[@]}" || exit $?
msg "leaving fakeroot environment..." msg "Leaving fakeroot environment..."
fi
msg "builds has done"
else else
if (( _STEP_PACKAGE )) ; then
run_function package run_function package
fi
generate_control if (( _STEP_CREATE_ARCHIVE )) ; then
step_create_archive
generate_deb msg "Finish making: $(get_deb_name) $(date)"
fi
fi
if (( QUIET )) ; then
enable_stdout
fi fi