Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
c1490bb339 | |||
d26cd45116 | |||
73004f978c | |||
1c136aab43 | |||
4351aa9450 | |||
d19dc0fbb1 | |||
b2cb42c371 | |||
95c0ffa43b |
10
README.md
10
README.md
@@ -1,8 +1,8 @@
|
|||||||
zpac
|
prm
|
||||||
----
|
---
|
||||||
A very simple AUR/ABS helper. Doesn't build packages, only gets the sources.
|
A very simple AUR/ABS helper. Doesn't build packages, only gets the sources.
|
||||||
|
|
||||||
Usage: zpac [flags] <package>
|
Usage: prm [flags] <package>
|
||||||
Flags:
|
Flags:
|
||||||
-h Show this message.
|
-h Show this message.
|
||||||
-s Search for <package>.
|
-s Search for <package>.
|
||||||
@@ -12,5 +12,5 @@ Flags:
|
|||||||
-f Force downloading package sources even if they are already present in the working directory.
|
-f Force downloading package sources even if they are already present in the working directory.
|
||||||
-w <dir> Set the working directory.
|
-w <dir> Set the working directory.
|
||||||
|
|
||||||
You can override any value in the script in \$HOME/.config/zpac.rc.sh
|
You can override any value in the script in \$HOME/.config/prm.rc.sh
|
||||||
By default zpac downloads the sources into the current directory. Controlled by `$cfg_workdir`.
|
By default prm downloads the sources into the current directory. Controlled by `$cfg_workdir`.
|
||||||
|
72
zpac → prm
72
zpac → prm
@@ -9,11 +9,12 @@ cfg_workdir="$PWD"
|
|||||||
cfg_aur_url='https://aur.archlinux.org'
|
cfg_aur_url='https://aur.archlinux.org'
|
||||||
cfg_aur_api="${cfg_aur_url}/rpc.php"
|
cfg_aur_api="${cfg_aur_url}/rpc.php"
|
||||||
|
|
||||||
echo() { printf '%s\n' "$*"; }
|
err() { printf "$@" >&2; }
|
||||||
err() { echo "$*" >&2; }
|
|
||||||
|
_cat() { while read -r; do printf '%s\n' "$REPLY"; done }
|
||||||
|
|
||||||
usage() {
|
usage() {
|
||||||
while read; do echo "$REPLY"; done <<- EOF
|
_cat <<- EOF
|
||||||
Usage: $_self [flags] <package>
|
Usage: $_self [flags] <package>
|
||||||
Flags:
|
Flags:
|
||||||
-h Show this message.
|
-h Show this message.
|
||||||
@@ -27,12 +28,14 @@ usage() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
aur.search() {
|
aur.search() {
|
||||||
local aur_api_search_data aur_search_result_num pkg
|
declare i aur_api_search_data aur_search_result_num aur_search_results version description
|
||||||
|
|
||||||
aur_api_search_data=$( curl -skL "${cfg_aur_api}?type=search&arg=${1}" )
|
aur_api_search_data=$( curl -skL "${cfg_aur_api}?type=search&arg=${1}" )
|
||||||
aur_search_result_num=$( jshon -e resultcount -u <<< "$aur_api_search_data" )
|
aur_search_result_num=$( jshon -e resultcount -u <<< "$aur_api_search_data" )
|
||||||
|
|
||||||
if (( aur_search_result_num )); then
|
# Exit if nothing was found
|
||||||
|
(( aur_search_result_num )) || { return 1; }
|
||||||
|
|
||||||
aur_search_results=( $( jshon -e results -a -e Name -u <<< "$aur_api_search_data" ) )
|
aur_search_results=( $( jshon -e results -a -e Name -u <<< "$aur_api_search_data" ) )
|
||||||
|
|
||||||
for i in "${!aur_search_results[@]}"; do
|
for i in "${!aur_search_results[@]}"; do
|
||||||
@@ -45,24 +48,21 @@ aur.search() {
|
|||||||
|
|
||||||
printf '%s %s\n %s\n' "aur/${aur_search_results[$i]}" "$version" "$description"
|
printf '%s %s\n %s\n' "aur/${aur_search_results[$i]}" "$version" "$description"
|
||||||
done
|
done
|
||||||
else
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
aur.info() {
|
aur.info() {
|
||||||
local pkg_aur_info=$( curl -skL "${cfg_aur_api}?type=info&arg=${1}" 2>/dev/null )
|
declare pkg_aur_info aur_query_result
|
||||||
local aur_query_result=$( jshon -e resultcount -u <<< "$pkg_aur_info" )
|
|
||||||
|
|
||||||
if (( aur_query_result )); then
|
pkg_aur_info=$( curl -skL "${cfg_aur_api}?type=info&arg=${1}" 2>/dev/null )
|
||||||
echo "$pkg_aur_info"
|
aur_query_result=$( jshon -e resultcount -u <<< "$pkg_aur_info" )
|
||||||
else
|
|
||||||
return 1
|
(( aur_query_result )) || { return 1; }
|
||||||
fi
|
|
||||||
|
printf '%s' "$pkg_aur_info"
|
||||||
}
|
}
|
||||||
|
|
||||||
aur.get() {
|
aur.get() {
|
||||||
local dep_name aur_api_multireq aur_deps_api_data aur_deps_count aur_deps pkg_aur_info pkg_base tarball_path
|
declare i pkg_aur_info pkg_base tarball_path depends makedepends dep_name aur_api_multireq dep_name aur_deps_api_data aur_deps_count aur_deps
|
||||||
|
|
||||||
read -r pkg_aur_info
|
read -r pkg_aur_info
|
||||||
|
|
||||||
@@ -75,24 +75,22 @@ aur.get() {
|
|||||||
|
|
||||||
(( flag_force )) || {
|
(( flag_force )) || {
|
||||||
[[ -d "${cfg_workdir}/${pkg_base}" ]] && {
|
[[ -d "${cfg_workdir}/${pkg_base}" ]] && {
|
||||||
echo "Found ${pkg_base} in ${cfg_workdir}, skipping. Use -f to override."
|
printf "Found %s in %s, skipping. Use -f to override\n" "${pkg_base}" "${cfg_workdir}"
|
||||||
return 17
|
return 17
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cd "$cfg_workdir"
|
cd "$cfg_workdir"
|
||||||
|
|
||||||
echo "Working in ${cfg_workdir}"
|
printf "Working in %s\n" "${cfg_workdir}"
|
||||||
|
|
||||||
echo "Downloading ${pkg_base}"
|
printf "Downloading %s\n" "${pkg_base}"
|
||||||
{ curl -skL "${cfg_aur_url}${tarball_path}" | gzip -d | tar x; } || {
|
{ curl -skL "${cfg_aur_url}${tarball_path}" | gzip -d | tar x; } || {
|
||||||
err "Fail!"
|
err "Fail!\n"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
if (( flag_get_deps )); then
|
if (( flag_get_deps )); then
|
||||||
unset depends makedepends
|
|
||||||
|
|
||||||
cd "${cfg_workdir}/${pkg_base}"
|
cd "${cfg_workdir}/${pkg_base}"
|
||||||
source PKGBUILD
|
source PKGBUILD
|
||||||
|
|
||||||
@@ -105,7 +103,7 @@ aur.get() {
|
|||||||
aur_deps_count=$( jshon -e resultcount <<< "$aur_deps_api_data" )
|
aur_deps_count=$( jshon -e resultcount <<< "$aur_deps_api_data" )
|
||||||
|
|
||||||
if (( aur_deps_count )); then
|
if (( aur_deps_count )); then
|
||||||
echo "Getting dependencies for ${pkg_base}."
|
printf "Getting dependencies for %s\n" "${pkg_base}"
|
||||||
|
|
||||||
aur_deps=( $( jshon -e results -a -e Name -u <<< "$aur_deps_api_data" ) )
|
aur_deps=( $( jshon -e results -a -e Name -u <<< "$aur_deps_api_data" ) )
|
||||||
|
|
||||||
@@ -113,18 +111,16 @@ aur.get() {
|
|||||||
aur.get < <(aur.info "$i")
|
aur.get < <(aur.info "$i")
|
||||||
_result="$?"
|
_result="$?"
|
||||||
|
|
||||||
(( _result )) && {
|
(( _result > 0 && result != 17 )) && {
|
||||||
(( _result == 17 )) || {
|
|
||||||
return "$_result"
|
return "$_result"
|
||||||
}
|
}
|
||||||
}
|
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
abs.get() {
|
abs.get() {
|
||||||
local pkg_repo svn_repo
|
declare pkg_repo svn_repo
|
||||||
|
|
||||||
pkg_repo="$2"
|
pkg_repo="$2"
|
||||||
|
|
||||||
@@ -138,7 +134,7 @@ abs.get() {
|
|||||||
svn checkout "svn://svn.archlinux.org/${svn_repo}/${1}/trunk" "${cfg_workdir}/${1}"
|
svn checkout "svn://svn.archlinux.org/${svn_repo}/${1}/trunk" "${cfg_workdir}/${1}"
|
||||||
}
|
}
|
||||||
|
|
||||||
args_norm() {
|
set_argv() {
|
||||||
declare arg opt c
|
declare arg opt c
|
||||||
declare -g argv
|
declare -g argv
|
||||||
|
|
||||||
@@ -174,8 +170,8 @@ args_norm() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
if [[ -f "$HOME/.config/zpac.rc.sh" ]]; then
|
if [[ -f "$HOME/.config/prm.rc.sh" ]]; then
|
||||||
source "$HOME/.config/zpac.rc.sh"
|
source "$HOME/.config/prm.rc.sh"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
while (( $# )); do
|
while (( $# )); do
|
||||||
@@ -207,7 +203,7 @@ main() {
|
|||||||
(-f) flag_force=1;;
|
(-f) flag_force=1;;
|
||||||
|
|
||||||
(-*)
|
(-*)
|
||||||
err "Unknown key: $1"
|
err "Unknown key: %s\n" "$1"
|
||||||
usage
|
usage
|
||||||
return 1
|
return 1
|
||||||
;;
|
;;
|
||||||
@@ -237,7 +233,7 @@ main() {
|
|||||||
(get)
|
(get)
|
||||||
[[ -d "$cfg_workdir" ]] || {
|
[[ -d "$cfg_workdir" ]] || {
|
||||||
mkdir -p "$cfg_workdir" || {
|
mkdir -p "$cfg_workdir" || {
|
||||||
err "Can't create workdir: ${cfg_workdir}."
|
err "Can't create workdir: %s\n" "$cfg_workdir"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -254,12 +250,12 @@ main() {
|
|||||||
done < <( pacman -Si "$package" )
|
done < <( pacman -Si "$package" )
|
||||||
|
|
||||||
[[ "$repo" ]] || {
|
[[ "$repo" ]] || {
|
||||||
err "Can't find package ${package}"
|
err "Can't find package %s\n" "$package"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Found ${package} in ${repo}."
|
printf "Found %s in %s\n" "$package" "$repo"
|
||||||
|
|
||||||
case "$repo" in
|
case "$repo" in
|
||||||
(aur)
|
(aur)
|
||||||
@@ -269,7 +265,7 @@ main() {
|
|||||||
abs.get "$package" "$repo";;
|
abs.get "$package" "$repo";;
|
||||||
|
|
||||||
(*)
|
(*)
|
||||||
err "Repository $repo not supported."
|
err "Repository %s not supported\n" "$repo"
|
||||||
return 1;;
|
return 1;;
|
||||||
esac
|
esac
|
||||||
;;
|
;;
|
||||||
@@ -277,7 +273,7 @@ main() {
|
|||||||
(search)
|
(search)
|
||||||
if (( flag_search_aur )); then
|
if (( flag_search_aur )); then
|
||||||
aur.search "$package" || {
|
aur.search "$package" || {
|
||||||
err "No packages found."
|
err "No packages found\n"
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
elif (( flag_search_syncdb )); then
|
elif (( flag_search_syncdb )); then
|
||||||
@@ -287,7 +283,7 @@ main() {
|
|||||||
pacman -Ss "$package" 2>/dev/null || { flag_pacman_search_fail=1; }
|
pacman -Ss "$package" 2>/dev/null || { flag_pacman_search_fail=1; }
|
||||||
|
|
||||||
if (( flag_aur_search_fail && flag_pacman_search_fail )); then
|
if (( flag_aur_search_fail && flag_pacman_search_fail )); then
|
||||||
err "No packages found."
|
err "No packages found\n"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -295,5 +291,5 @@ main() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
args_norm "$@"
|
set_argv "$@"
|
||||||
main "${argv[@]}"
|
main "${argv[@]}"
|
Reference in New Issue
Block a user