Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
7d778ecd66 | |||
aa8929ff8e | |||
2ab2fdd126 | |||
2c37b9e64e | |||
59432612de | |||
61a9cbd34d |
@@ -7,6 +7,11 @@ A very simple AUR/ABS helper. Doesn't build packages, only gets the sources.
|
|||||||
Flags:
|
Flags:
|
||||||
-h Show this message.
|
-h Show this message.
|
||||||
-s Search for <package>.
|
-s Search for <package>.
|
||||||
|
-S Search only in the sync db. Implies -s.
|
||||||
|
-A Search only in AUR. Implies -s.
|
||||||
-d Get the package sources (default).
|
-d Get the package sources (default).
|
||||||
|
-D Get the dependencies also. Implies -d.
|
||||||
|
|
||||||
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/zpac.rc.sh
|
||||||
|
By default zpac downloads the sources into the current directory. Controlled by `$cfg_workdir`.
|
||||||
|
|
||||||
|
88
zpac
88
zpac
@@ -18,8 +18,10 @@ usage() {
|
|||||||
Flags:
|
Flags:
|
||||||
-h Show this message.
|
-h Show this message.
|
||||||
-s Search for <package>.
|
-s Search for <package>.
|
||||||
|
-S Search only in the sync db. Implies -s.
|
||||||
|
-A Search only in AUR. Implies -s.
|
||||||
-d Get the package sources (default).
|
-d Get the package sources (default).
|
||||||
-D If used with -d, makes $_self download the dependencies from AUR too.
|
Set twice to also get the dependencies.
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -84,7 +86,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
|
||||||
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" ) )
|
||||||
|
|
||||||
for i in "${aur_deps[@]}"; do
|
for i in "${aur_deps[@]}"; do
|
||||||
aur.get < <(aur.info "$i") || {
|
aur.get < <(aur.info "$i") || {
|
||||||
@@ -110,6 +112,44 @@ 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() {
|
||||||
|
while (( $# )); do
|
||||||
|
unset -v arg opt c keys
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
--) shift; break;;
|
||||||
|
|
||||||
|
--*)
|
||||||
|
IFS='=' read arg opt <<< "$1"
|
||||||
|
printf '%s\n' "$arg"
|
||||||
|
|
||||||
|
[[ "$opt" ]] && {
|
||||||
|
printf '%s\n' "$opt"
|
||||||
|
}
|
||||||
|
;;
|
||||||
|
|
||||||
|
-*)
|
||||||
|
while read -n1 c
|
||||||
|
do
|
||||||
|
case "$c" in
|
||||||
|
-|'') :;;
|
||||||
|
*) keys+=( "-$c" );;
|
||||||
|
esac
|
||||||
|
done <<< "$1"
|
||||||
|
|
||||||
|
printf '%s\n' "${keys[@]}"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
[[ "$2" && ! "$2" =~ ^- ]] && {
|
||||||
|
printf '%s\n' "$2"
|
||||||
|
shift
|
||||||
|
}
|
||||||
|
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
if [[ -f "$HOME/.config/zpac.rc.sh" ]]; then
|
if [[ -f "$HOME/.config/zpac.rc.sh" ]]; then
|
||||||
source "$HOME/.config/zpac.rc.sh"
|
source "$HOME/.config/zpac.rc.sh"
|
||||||
@@ -117,14 +157,26 @@ main() {
|
|||||||
|
|
||||||
while (( $# )); do
|
while (( $# )); do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
--help|-h) usage; return 0;;
|
(-h) usage; return 0;;
|
||||||
|
|
||||||
-s) action='search';;
|
(-s) action='search';;
|
||||||
-d) action='get';;
|
(-A)
|
||||||
-D) flag_get_deps=1;;
|
action='search'
|
||||||
|
flag_search_aur=1;;
|
||||||
|
(-S)
|
||||||
|
action='search'
|
||||||
|
flag_search_syncdb=1;;
|
||||||
|
|
||||||
--) shift; break;;
|
(-d)
|
||||||
-*)
|
if [[ "$action" == 'get' ]]; then
|
||||||
|
flag_get_deps=1
|
||||||
|
else
|
||||||
|
action='get'
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
(--) shift; break;;
|
||||||
|
(-*)
|
||||||
err "Unknown key: $1"
|
err "Unknown key: $1"
|
||||||
usage
|
usage
|
||||||
return 1
|
return 1
|
||||||
@@ -135,7 +187,14 @@ main() {
|
|||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
|
|
||||||
action=${action:-"get"}
|
(( flag_search_aur && flag_search_syncdb )) && {
|
||||||
|
unset flag_search_aur flag_search_syncdb
|
||||||
|
}
|
||||||
|
|
||||||
|
[[ "$action" ]] || {
|
||||||
|
usage
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
if [[ "$1" ]]; then
|
if [[ "$1" ]]; then
|
||||||
package="$1"
|
package="$1"
|
||||||
@@ -186,8 +245,13 @@ main() {
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
(search)
|
(search)
|
||||||
if type -P package-query &>/dev/null; then
|
if (( flag_search_aur )); then
|
||||||
package-query -ASs "$package"
|
aur.search "$package" || {
|
||||||
|
err "No packages found."
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
elif (( flag_search_syncdb )); then
|
||||||
|
pacman -Ss "$package"
|
||||||
else
|
else
|
||||||
aur.search "$package" || { flag_aur_search_fail=1; }
|
aur.search "$package" || { flag_aur_search_fail=1; }
|
||||||
pacman -Ss "$package" 2>/dev/null || { flag_pacman_search_fail=1; }
|
pacman -Ss "$package" 2>/dev/null || { flag_pacman_search_fail=1; }
|
||||||
@@ -201,4 +265,4 @@ main() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
main "$@"
|
main $(args_norm "$@")
|
||||||
|
Reference in New Issue
Block a user