Compare commits
No commits in common. "ef4ccbef46ce4ded5d342cb31dea54484e2f8963" and "696425afd988fe715ad46035d8d061412f01a08d" have entirely different histories.
ef4ccbef46
...
696425afd9
17 changed files with 147 additions and 321 deletions
|
@ -1,3 +1,5 @@
|
||||||
# APS
|
# aps
|
||||||
APS - Alnux Packaging System
|
|
||||||
|
|
||||||
|
the alnux package manager
|
||||||
|
|
||||||
|
(the code is completely and utterly horrible and i cant believe i actually wrote this lol)
|
|
@ -1,2 +0,0 @@
|
||||||
# This follows the UNIX philosophy
|
|
||||||
Actually, also altools is meant to be in shell since it's ok
|
|
|
@ -1,32 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
#############
|
|
||||||
# ALINITSYS #
|
|
||||||
#############
|
|
||||||
|
|
||||||
# ALINITSYS is a passthrough to RUNIT OR OPENRC, if RUNIT OR OPENRC exists, if not, then ALINITSYS will wrap it up and init the system.
|
|
||||||
|
|
||||||
function init(){
|
|
||||||
exec runit && echo ":: Running Runit..." || echo ":: Runit not found..." ;
|
|
||||||
exec openrc && echo ":: Running OpenRC..." || echo ":: OpenRC not found..." ;
|
|
||||||
echo ":: Running alinitsys"
|
|
||||||
}
|
|
||||||
function rescue(){
|
|
||||||
echo "[E] Something might've went wrong..."
|
|
||||||
echo ":: Dropping into the SH"
|
|
||||||
exec sh
|
|
||||||
}
|
|
||||||
function daemon(){
|
|
||||||
/var/service/*/start
|
|
||||||
}
|
|
||||||
function getty(){
|
|
||||||
echo ":: Getting TTY"
|
|
||||||
exec getty || exec stty
|
|
||||||
}
|
|
||||||
function start(){
|
|
||||||
init ||
|
|
||||||
daemon &&
|
|
||||||
getty ||
|
|
||||||
rescue
|
|
||||||
}
|
|
||||||
start
|
|
|
@ -1,5 +0,0 @@
|
||||||
ccflags = -O3
|
|
||||||
compile:
|
|
||||||
gcc $(ccflags) pow.c -o pow
|
|
||||||
clean:
|
|
||||||
rm pow
|
|
BIN
altools/c/pow
BIN
altools/c/pow
Binary file not shown.
|
@ -1,28 +0,0 @@
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <sys/reboot.h>
|
|
||||||
|
|
||||||
int main (int argc, char *argv[]) {
|
|
||||||
if (geteuid() != 0) {
|
|
||||||
printf("[E] pow must be run as root\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
sync();
|
|
||||||
|
|
||||||
switch (argv[1] ? argv[1][0]: 0) {
|
|
||||||
case 's':
|
|
||||||
case 'p':
|
|
||||||
reboot(RB_POWER_OFF);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
case 'r':
|
|
||||||
reboot(RB_AUTOBOOT);
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
default:
|
|
||||||
printf("pow r[eboot]|p[oweroff]|s[hutdown]\n");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
}
|
|
18
altools/dae
18
altools/dae
|
@ -1,18 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
###########################
|
|
||||||
# DAE, the deamon manager #
|
|
||||||
###########################
|
|
||||||
|
|
||||||
function daemonctl(){
|
|
||||||
case $1 in
|
|
||||||
stop) . /etc/al/serivces/$2.alsysd
|
|
||||||
stop ;;
|
|
||||||
start) . /etc/al/services/$2.alsysd
|
|
||||||
start ;;
|
|
||||||
esac
|
|
||||||
case $2 in
|
|
||||||
--verbose) set -x ;;
|
|
||||||
*) ;;
|
|
||||||
esac
|
|
||||||
}
|
|
|
@ -1,4 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
export AL_CFG="../config/config"
|
|
||||||
export AL_REPO="/var/tmp/alroot/var/aps/repos/official"
|
|
||||||
../aps s alnux
|
|
|
@ -1,13 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
###############
|
|
||||||
# MKINITRAMFS #
|
|
||||||
###############
|
|
||||||
|
|
||||||
if [ ! -d /usr/src/initramfs ]; then
|
|
||||||
mkdir -p /usr/src/initramfs/{bin,dev,etc,lib,lib64,mnt/root,proc,root,sbin,sys}
|
|
||||||
cp --archive /dev/{null,console,tty,sd*} /usr/src/initramfs/dev/
|
|
||||||
cp --archive /bin/busybox /usr/src/initramfs/bin/busybox
|
|
||||||
fi
|
|
||||||
cd /usr/src/initramfs
|
|
||||||
find . -print0 | cpio --null --create --verbose --format=newc | gzip --best > /boot/initramfs.cpio.gz
|
|
BIN
altools/pow
BIN
altools/pow
Binary file not shown.
|
@ -6,13 +6,13 @@
|
||||||
. /etc/al/config
|
. /etc/al/config
|
||||||
case $1 in
|
case $1 in
|
||||||
# add a repo
|
# add a repo
|
||||||
add) git clone ${2} ${install_root}/var/db/repos
|
add) git clone https://${3}/${2}.git ${install_root}/var/aps/repos/${2}
|
||||||
echo "${2}" >> ${install_root}/etc/al/repo.conf
|
echo "${2}" >> ${install_root}/etc/al/repo.conf
|
||||||
;;
|
;;
|
||||||
# update a repo
|
# update a repo
|
||||||
update) pushd && cd ${install_root}/var/aps/repos/${2} && git pull && popd ;;
|
update) pushd && cd ${install_root}/var/aps/repos/${2} && git pull && popd ;;
|
||||||
# destroy a repo (remove)
|
# destroy a repo (remove)
|
||||||
destroy) rm -rfv ${install_root}/var/db/aps/repos/${2}
|
destroy) rm -rfv ${install_root}/var/aps/repos/${2}
|
||||||
sed -i "/^${2}/d" ${install_root}/etc/al/repo.conf
|
sed -i "/^${2}/d" ${install_root}/etc/al/repo.conf
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
314
aps
314
aps
|
@ -1,220 +1,150 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
###################
|
#################################
|
||||||
# aps. rewritten. #
|
# Alnux Packaging System, #
|
||||||
###################
|
# the package manager for Alnux #
|
||||||
# OHIO: aps *needs* to be rewritten, i can't add any thing else in the aps (v0.0.8.1)
|
#################################
|
||||||
# OHIO: aps is rewritten in 9/10th's so it's no longer a debug build
|
|
||||||
# OHIO: it's rewritten however it has some old code from aps (v0.0.8.1)
|
|
||||||
# KEMAL: abandon all hope, ye who enter here.
|
|
||||||
# OHIO: ^, however my code is cleaner than the mess before.
|
|
||||||
function conf_fetch(){
|
|
||||||
if [ -f "$XDG_CONFIG_HOME/al/config" ]; then
|
if [ -f "$XDG_CONFIG_HOME/al/config" ]; then
|
||||||
. $XDG_CONFIG_HOME/al/config
|
. $XDG_CONFIG_HOME/al/config
|
||||||
elif [ -f "$HOME/.config/al/config" ]; then
|
elif [ -f "$HOME/.config/al/config" ]; then
|
||||||
. $HOME/.config/al/config
|
. $HOME/.config/al/config
|
||||||
elif [ -f "/etc/al/config" ]; then
|
elif [ -f "/etc/al/config" ]; then
|
||||||
. /etc/al/config
|
. /etc/al/config
|
||||||
elif [ -f "/etc/skel/al/config" ]; then
|
|
||||||
. /etc/skel/al/config
|
|
||||||
#elif [ -f $AL_CFG ]; then
|
|
||||||
# . $AL_CFG
|
|
||||||
else
|
else
|
||||||
err "No config file!"
|
temp_location="/var/tmp"
|
||||||
|
install_root="/var/tmp/alroot"
|
||||||
|
installed_pkg_database="${install_root}/var/aps/installed"
|
||||||
|
locpkg_database="${install_root}/var/aps/repos"
|
||||||
|
lock="${install_root}/var/aps/lock"
|
||||||
|
official="https://git.hippoz.xyz/alnux/repo"
|
||||||
|
debug=off
|
||||||
fi
|
fi
|
||||||
}
|
if [ ${debug} = on ]; then
|
||||||
case ${debug} in
|
set -x
|
||||||
on) set -x ;;
|
fi
|
||||||
esac
|
die() {
|
||||||
function prn(){
|
echo "aps: fatal: ${1}"
|
||||||
echo -e "\e[34m==>\e[39m $1"
|
rm "${lock}"
|
||||||
}
|
|
||||||
function wrn(){
|
|
||||||
echo -e "\e[34m==>\e[33m WARNING:\e[39m $1"
|
|
||||||
}
|
|
||||||
#function run(){
|
|
||||||
# printf '%s\n' "$*"
|
|
||||||
# "$@"
|
|
||||||
#}
|
|
||||||
function err(){
|
|
||||||
echo -e "\e[34m==>\e[31m ERROR:\e[39m $1" &&
|
|
||||||
rm ${lock} 2> /dev/null
|
|
||||||
exit 2
|
exit 2
|
||||||
}
|
}
|
||||||
conf_fetch
|
confirm(){
|
||||||
function notf(){
|
echo -ne "Are you sure? [Y/n] "
|
||||||
echo -e "\e[34m==>\e[36m NOTIFICATION:\e[39m $1"
|
read prompt
|
||||||
}
|
if [[ ${prompt} = [nN] ]]; then
|
||||||
function confirm(){
|
die "User said no. Exiting..."
|
||||||
prn "To $1, press ENTER, to cancel, press CTRL+C"
|
elif [[ ${prompt} != [yY] ]]; then
|
||||||
}
|
die "User gave invalid input. Exiting..."
|
||||||
#function dbg(){
|
|
||||||
# wrn "This is a debug build, that may not work!"
|
|
||||||
#}
|
|
||||||
function sources(){
|
|
||||||
#pkg_config_url=$(cat sources)
|
|
||||||
#pkg_config_archv=$(echo ${pkg_config_url} | sed 's:.*/::')
|
|
||||||
#curl -fLO ${pkg_config_url}
|
|
||||||
#mkdir --parents pkgex
|
|
||||||
#pkg_config_archv_ft=$(file --extension ${pkg_config_archv_ft})
|
|
||||||
#case $pkg_config_archv_ft in
|
|
||||||
# *.tar*) prn $(tar -xf ${pkg_config_archv} -C pkgex) ;;
|
|
||||||
# *.xz) prn $(cd pkgex && xz -d ../${pkg_config_archv} && cd ..) ;;
|
|
||||||
# *.bz2) prn $(cd pkgex && bzip2 -d ../${pkg_config_archv} && cd ..) ;;
|
|
||||||
# *.gz) prn $(cd pkgex && gzip -d ../${pkg_config_archv} && cd ..) ;;
|
|
||||||
# *.zst) prn $(cd pkgex && zstd -dc && cd ..) ;;
|
|
||||||
# *) wrn "Not a tar! But it will be kept!"
|
|
||||||
#esac
|
|
||||||
#mkdir --parents pkgsrc
|
|
||||||
#cp -r pkgex/*/* pkgsrc
|
|
||||||
pkg_config_url=$1
|
|
||||||
pkg_config_archv=$(echo ${pkg_config_url} | sed 's:.*/::')
|
|
||||||
curl -fLO ${pkg_config_url}
|
|
||||||
mkdir --parents pkgex
|
|
||||||
pkg_config_archv_ft=$(file --extension ${pkg_config_archv_ft})
|
|
||||||
case $pkg_config_archv_ft in
|
|
||||||
*.tar*) prn $(tar -xf ${pkg_config_archv} -C pkgex) ;;
|
|
||||||
*.xz) prn $(cd pkgex && xz -d ../${pkg_config_archv} && cd ..) ;;
|
|
||||||
*.bz2) prn $(cd pkgex && bzip2 -d ../${pkg_config_archv} && cd ..) ;;
|
|
||||||
*.gz) prn $(cd pkgex && gzip -d ../${pkg_config_archv} && cd ..) ;;
|
|
||||||
*.zst) prn $(cd pkgex && zstd -dc && cd ..) ;;
|
|
||||||
*) wrn "Not a tar! But it will be kept!"
|
|
||||||
esac
|
|
||||||
mkdir --parents pkgsrc
|
|
||||||
cp -r pkgex/*/* pkgsrc
|
|
||||||
|
|
||||||
}
|
|
||||||
function sha256(){
|
|
||||||
#sha256sum $sum > $1.sha256sum
|
|
||||||
sha256sum -c "$1" 1>&2 /dev/null
|
|
||||||
if [ "$?" -ne "0" ]; then
|
|
||||||
prn "OK!"
|
|
||||||
else
|
|
||||||
err "Sha failed!"
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
run_package_script() {
|
||||||
#function md5(){
|
{
|
||||||
# sum="$(cat $@/sums)"
|
|
||||||
# md5sum "$sum"
|
|
||||||
#}
|
|
||||||
#function versum(){
|
|
||||||
# sumrest=$(cat $@/sums | cut -d'+' -f-)
|
|
||||||
# sumtype=$(cat $@/sums | cut -d'+' -f2)
|
|
||||||
# case $sumtype in
|
|
||||||
# sha256) sha256 "$1.sha256sum" ;;
|
|
||||||
# md5) err "MD5 is not supported." ;;
|
|
||||||
# esac
|
|
||||||
#}
|
|
||||||
function runbuildsh(){
|
|
||||||
if [ -x "${2}/${1}" ]; then
|
if [ -x "${2}/${1}" ]; then
|
||||||
prn "Running $1"
|
echo ":: Running ${1}"
|
||||||
cd "${2}" || err "Running $1 has failed, check your permissions."
|
#cd "${2}" || die "Could not enter package working directory. Exiting..."
|
||||||
"${2}/${1}" "${2}/payload" "${2}"
|
"${2}/${1}" "${2}/payload" "${2}"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
function pkg_find(){
|
|
||||||
# i could not even bother, i had to copy kiss in some sense
|
|
||||||
set -- "$1" "$2" "$3" "${4:-"$AL_REPO"}"
|
|
||||||
IFS=:
|
|
||||||
|
|
||||||
for _find_path in $4 "${3:-$sys_db}"; do set +f
|
|
||||||
for _find_pkg in "$_find_path/"$1; do
|
|
||||||
test "${3:--d}" "$_find_pkg" && set -f -- "$@" "$_find_pkg"
|
|
||||||
done
|
|
||||||
done
|
|
||||||
|
|
||||||
unset IFS
|
|
||||||
# alnux search i guess
|
|
||||||
#case $2-$# in
|
|
||||||
# *-4) return 1 ;;
|
|
||||||
# -*) repo_dir=$5; repo_name=${5##*/} ;;
|
|
||||||
# *) shift 4; printf '%s\n' "$@"
|
|
||||||
#esac
|
|
||||||
}
|
}
|
||||||
function pkg_local(){
|
install_local_package() {
|
||||||
if [ -z "$AL_REPO" ]; then
|
[ ! -e "${1}" ] && die "File ${1} does not exist. Exiting..."
|
||||||
err "Alnux Repo variable is not set. Will not continue"
|
# Extract the package
|
||||||
fi
|
confirm
|
||||||
pkg_find $1
|
echo ":: Installing package ${1}"
|
||||||
cp -prv "${1}" "${temp_location}"
|
cp -prv "${1}" "${temp_location}"
|
||||||
|
|
||||||
# - - - - - #
|
|
||||||
# VARIABLES #
|
|
||||||
# - - - - - #
|
|
||||||
pkg_name="${1%/}"
|
pkg_name="${1%/}"
|
||||||
pkg_name="${pkg_name##*/}"
|
pkg_name="${pkg_name##*/}"
|
||||||
pkg_name=$(echo "${pkg_name}" | cut -f 1 -d '.')
|
pkg_name=$(echo "${pkg_name}" | cut -f 1 -d '.')
|
||||||
pkg_path="${temp_location}/${pkg_name}"
|
pkg_path="${temp_location}/${pkg_name}"
|
||||||
# - - #
|
cd "${pkg_path}" || die "Could not enter package path."
|
||||||
# #
|
# Set default values for package
|
||||||
# - - #
|
pkg_config_deploy=true
|
||||||
|
pkg_config_ver="0"
|
||||||
|
pkg_config_makedepends=""
|
||||||
|
pkg_config_depends=""
|
||||||
|
# Download sources.
|
||||||
|
if [ -f sources ]; then
|
||||||
|
pkg_config_sources=$(cat sources)
|
||||||
|
pkg_config_sources_to=$(echo ${pkg_config_sources} | sed 's:.*/::')
|
||||||
|
curl -# ${pkg_config_sources} -o ${pkg_config_sources_to}
|
||||||
|
mkdir pkg_bd
|
||||||
|
tar -xf 1 ${pkg_config_sources_to} -C ${pkg_path}
|
||||||
|
fi
|
||||||
|
# Install package
|
||||||
mkdir -p "${pkg_path}/payload"
|
mkdir -p "${pkg_path}/payload"
|
||||||
. "${pkg_path}/package"
|
. "${pkg_path}/package"
|
||||||
cd "${pkg_path}"
|
cd pkg_bd/
|
||||||
if [ -f *.sources ]; then
|
run_package_script "build" "${pkg_path}"
|
||||||
sources $(cat sources)
|
cd ../..
|
||||||
#"$(cat *.sources)"
|
run_package_script "predeploy" "${pkg_path}"
|
||||||
fi
|
|
||||||
if [ -f *.sha256sums ]; then
|
|
||||||
sha256 "*.sha256sum}"
|
|
||||||
else
|
|
||||||
wrn "No sums file(s) found! Be careful!"
|
|
||||||
fi
|
|
||||||
runbuildsh "build" "${pkg_path}/pkgsrc"
|
|
||||||
runbuildsh "predeploy" "${pkg_path}/pkgsrc"
|
|
||||||
# Old APS code from before the rewrite!
|
|
||||||
# Deploy package
|
# Deploy package
|
||||||
if [ "${pkg_config_deploy}" = true ]; then
|
if [ "${pkg_config_deploy}" = true ]; then
|
||||||
prn "Deploying target ${pkg_name}..."
|
echo ":: Deploying target ${pkg_name}..."
|
||||||
cp -rpv "${pkg_path}/payload"/* "${install_root}" > "${temp_location}/${pkg_name}-payloaddeploylog"
|
cp -rpv "${pkg_path}/payload"/* "${install_root}" > "${temp_location}/${pkg_name}-payloaddeploylog"
|
||||||
sed 's/^.*-> //' "${temp_location}/${pkg_name}-payloaddeploylog" | tr -d \'\" > "${temp_location}/${pkg_name}-payloadfiles"
|
sed 's/^.*-> //' "${temp_location}/${pkg_name}-payloaddeploylog" | tr -d \'\" > "${temp_location}/${pkg_name}-payloadfiles"
|
||||||
rm "${temp_location}/${pkg_name}-payloaddeploylog"
|
rm "${temp_location}/${pkg_name}-payloaddeploylog"
|
||||||
fi
|
fi
|
||||||
runbuildsh "postdeploy" "${pkg_path}/pkgsrc"
|
run_package_script "postdeploy" "${pkg_path}"
|
||||||
# Yet more old APS code
|
# Add package to database
|
||||||
if [ -x "${pkg_path}/package" ]; then
|
if [ -x "${pkg_path}/package" ]; then
|
||||||
prn "Adding target ${pkg_name} to installed package database..."
|
echo ":: Adding target ${pkg_name} to installed package database..."
|
||||||
[ ! -d "${installed_pkg_database}/${pkg_name}" ] && mkdir -p "${installed_pkg_database}/${pkg_name}"
|
[ ! -d "${installed_pkg_database}/${pkg_name}" ] && mkdir "${installed_pkg_database}/${pkg_name}"
|
||||||
cp -pv "${pkg_path}/package" "${installed_pkg_database}/${pkg_name}/package"
|
cp -pv "${pkg_path}/package" "${installed_pkg_database}/${pkg_name}/package"
|
||||||
[ -e "${temp_location}/${pkg_name}-payloadfiles" ] && cp -pv "${temp_location}/${pkg_name}-payloadfiles" "${installed_pkg_database}/${pkg_name}/payloadfiles"
|
[ -e "${temp_location}/${pkg_name}-payloadfiles" ] && cp -pv "${temp_location}/${pkg_name}-payloadfiles" "${installed_pkg_database}/${pkg_name}/payloadfiles"
|
||||||
else
|
else
|
||||||
err "Target ${pkg_name} does not have a package script (it's an invalid package!). Exiting..."
|
die "Target ${pkg_name} does not have a package script (it's an invalid package!). Exiting..."
|
||||||
fi
|
fi
|
||||||
# Old Cleanup, might work
|
# Cleanup
|
||||||
rm -r "${pkg_path}"
|
rm -r "${pkg_path}"
|
||||||
rm "${temp_location}/${pkg_name}-payloadfiles"
|
rm "${temp_location}/${pkg_name}-payloadfiles"
|
||||||
cd "${install_root}" || err "Could not return to main directory. Exiting..."
|
cd "${install_root}" || die "Could not return to main directory. Exiting..."
|
||||||
unset pkg_path
|
unset pkg_path
|
||||||
unset pkg_name
|
unset pkg_name
|
||||||
unset pkg_config_deploy
|
unset pkg_config_deploy
|
||||||
unset pkg_config_ver
|
unset pkg_config_ver
|
||||||
unset pkg_config_makedepends
|
unset pkg_config_makedepends
|
||||||
unset pkg_config_depends
|
unset pkg_config_depends
|
||||||
prn "Install complete for package ${pkg_name}"
|
echo "[*] Install complete for package ${pkg_name}"
|
||||||
|
}
|
||||||
|
sync_deps(){
|
||||||
|
confirm
|
||||||
|
echo ":: Syncing dependencies for ${1}"
|
||||||
|
install_package_from_repo "${pkg_makedepends}"
|
||||||
|
install_package_from_repo "${pkg_deps}"
|
||||||
|
echo "[*] Install dependencies for ${1}"
|
||||||
|
|
||||||
|
}
|
||||||
|
remove_local_package() {
|
||||||
|
confirm
|
||||||
|
echo ":: Removing target ${1}..."
|
||||||
|
pkg_path="${installed_pkg_database}/${1}"
|
||||||
|
[ ! -d "${pkg_path}" ] && die "Package could not be found in local installed package database. Exiting..."
|
||||||
|
payloadfiles_path="${pkg_path}/payloadfiles"
|
||||||
|
[ ! -e "${payloadfiles_path}" ] && die "[E] Package ${1} does not have a payloadfiles file. Exiting..."
|
||||||
|
rm -rv "$(cat ${payloadfiles_path})"
|
||||||
|
rm -rv "${pkg_path}"
|
||||||
|
echo "[*] Removal complete for target ${pkg_name}"
|
||||||
}
|
}
|
||||||
sync_local_repo_database() {
|
sync_local_repo_database() {
|
||||||
# Local database for repo already exists - sync it
|
echo ":: Syncing local database for repo ${1}"
|
||||||
#cd "${1}" || err "Could not enter local database directory. Exiting..."
|
|
||||||
#git pull
|
|
||||||
prn "Syncing local database for $1"
|
|
||||||
if [ ! -d "${locpkg_database}/${1}" ]; then
|
if [ ! -d "${locpkg_database}/${1}" ]; then
|
||||||
# Local database for repo doesnt exists - clone it
|
# Local database for repo doesnt exists - clone it
|
||||||
git clone "${2}" "${locpkg_database}/${1}"
|
git clone "${2}" "${locpkg_database}/${1}"
|
||||||
else
|
else
|
||||||
# Local database for repo already exists - sync it
|
# Local database for repo already exists - sync it
|
||||||
cd "${locpkg_database}/${1}" || err "Could not enter local database directory. Exiting..."
|
cd "${locpkg_database}/${1}" || die "Could not enter local database directory. Exiting..."
|
||||||
git pull
|
git pull
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
install_package_from_repo() { # NOTE(hippoz): This can get a tad confusing... ${1} is the repo and ${2} is the package
|
install_package_from_repo() { # NOTE(hippoz): This can get a tad confusing... ${1} is the repo and ${2} is the package
|
||||||
prn "Installing package(s) ${2} from ${1} repo"
|
echo ":: Installing package ${2} from ${1} repo"
|
||||||
[ ! -d "${locpkg_database}/${1}/${2}" ] && err "Target not found."
|
[ ! -d "${locpkg_database}/${1}/${2}" ] && die "Target not found."
|
||||||
pkg_local "${locpkg_database}/${1}/${2}"
|
install_local_package "${locpkg_database}/${1}/${2}"
|
||||||
}
|
}
|
||||||
update() {
|
upgrade() {
|
||||||
prn "Upgrading installed packages"
|
confirm
|
||||||
cd "${installed_pkg_database}" || err "Could not enter local installed package database directory. Exiting..."
|
echo ":: Upgrading installed packages"
|
||||||
|
cd "${installed_pkg_database}" || die "Could not enter local installed package database directory. Exiting..."
|
||||||
for pkg in */; do
|
for pkg in */; do
|
||||||
installed_pkg_path="${installed_pkg_database}/${pkg}"
|
installed_pkg_path="${installed_pkg_database}/${pkg}"
|
||||||
. "${installed_pkg_path}/package"
|
. "${installed_pkg_path}/package"
|
||||||
|
@ -233,34 +163,46 @@ update() {
|
||||||
unset pkg_config_depends
|
unset pkg_config_depends
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
function help(){
|
version(){
|
||||||
prn "h|help) prints this message"
|
echo "Alnux APS v0.0.8.1"
|
||||||
prn "v|version) version"
|
|
||||||
prn "s|sync) install package(s), and sync repositories"
|
|
||||||
prn "u|update) update"
|
|
||||||
prn "i|install) install LOCAL package(s)"
|
|
||||||
}
|
}
|
||||||
function version(){
|
help(){
|
||||||
prn "APS Version 0.1.0"
|
echo "Alnux APS, the packaging system for Alnux."
|
||||||
|
echo ""
|
||||||
|
echo "sync - Synchronizes from package repository."
|
||||||
|
echo "install - Installs from local package information file and build file."
|
||||||
|
echo "upgrade - Upgrades from package repository."
|
||||||
|
echo "remove - Removes a package from /var/aps/installed and it's install files (payloadfiles)."
|
||||||
|
echo "list - Lists currently installed packages."
|
||||||
|
echo "help - Display this message."
|
||||||
|
echo "version - Display the version."
|
||||||
}
|
}
|
||||||
function main(){
|
list(){
|
||||||
#if [ -f "${lock}" ]; then
|
ls ${installed_pkg_database} | sed 's/^README.md//g'
|
||||||
# err "A lock file already exists (another instance of the package manager could be running). If you're sure no package manager is running, remove the file ${lock}."
|
}
|
||||||
#fi
|
main() {
|
||||||
#touch "${lock}"
|
if [ -f "${lock}" ]; then
|
||||||
#dbg
|
echo "A lock file already exists (another instance of the package manager could be running). If you're sure no package manager is running, remove the file ${lock}."
|
||||||
case $1 in
|
exit 1
|
||||||
s|sync) sync_local_repo_database "${official}" ${official}
|
fi
|
||||||
|
touch "${lock}"
|
||||||
|
case ${1} in
|
||||||
|
install) install_local_package "${2}" ;;
|
||||||
|
remove) remove_local_package "${2}" ;;
|
||||||
|
#sync-dep)
|
||||||
|
# sync_local_repo_database "official" ${official}
|
||||||
|
# [ -z "${2}" ] && exit 0
|
||||||
|
# install_package_from_repo "official" "${2}" ;;
|
||||||
|
sync)
|
||||||
|
sync_local_repo_database "official" ${official}
|
||||||
[ -z "${2}" ] && exit 0
|
[ -z "${2}" ] && exit 0
|
||||||
install_package_from_repo "${official}" "${2}" ;;
|
install_package_from_repo "official" "${2}" ;;
|
||||||
#confirm "install" ;;
|
upgrade) upgrade "official" ;;
|
||||||
i|install) pkg_local ${*: -1} ;;
|
help) help ;;
|
||||||
# confirm "install" ;;
|
version) version ;;
|
||||||
u|update) update ;;
|
list) list ;;
|
||||||
# confirm "update" ;;
|
*) die "Invalid option ${1}, exiting..." ;;
|
||||||
v|version) version ;;
|
|
||||||
h|help) help ;;
|
|
||||||
*) err "Invalid option"
|
|
||||||
esac
|
esac
|
||||||
|
rm "${lock}"
|
||||||
}
|
}
|
||||||
main $1 ${@: -1}
|
main "${1}" "${2}"
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
# Alnux Packaging System #
|
# Alnux Packaging System #
|
||||||
##########################
|
##########################
|
||||||
temp_location="/var/tmp"
|
temp_location="/var/tmp"
|
||||||
install_root="/var/tmp/alroot"
|
install_root="/"
|
||||||
installed_pkg_database="${install_root}/var/aps/installed"
|
installed_pkg_database="${install_root}/var/aps/installed"
|
||||||
locpkg_database="${install_root}/var/aps/repos"
|
locpkg_database="${install_root}/var/aps/repos"
|
||||||
lock="${install_root}/var/aps/lock"
|
lock="${install_root}/var/aps/lock"
|
||||||
|
|
11
man/aps.8
11
man/aps.8
|
@ -1,11 +0,0 @@
|
||||||
aps(v0.1.0) aps(v0.1.0)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
aappss -- aallnnuuxx ppaacckkaaggee mmaannaaggeerr
|
|
||||||
To submit patches, contact the alnux dev team via mail (mailing list).
|
|
||||||
If you need help refer to the wiki
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
aps(v0.1.0)
|
|
BIN
man/aps.8.gz
Normal file
BIN
man/aps.8.gz
Normal file
Binary file not shown.
|
@ -1,5 +0,0 @@
|
||||||
.TH aps "v0.1.0"
|
|
||||||
.SH aps - alnux package manager
|
|
||||||
.SP .SH ALNUX PACKAGE MANAGER - subpages: alnux-pkg-standard.7.
|
|
||||||
To submit patches, contact the alnux dev team via mail (mailing list).
|
|
||||||
If you need help refer to the wiki
|
|
Loading…
Reference in a new issue