13 Commits
v2.4 ... v2.8

Author SHA1 Message Date
fbt
8591081269 README 2015-02-09 19:37:55 +03:00
fbt
9e15b8200e trailing newline 2015-02-09 19:36:30 +03:00
fbt
bf18623e06 woo proper handling 2015-02-09 16:22:26 +03:00
fbt
34775cfe97 Readme update 2015-02-06 19:26:40 +03:00
fbt
9b3ea06c61 I'm on fire today. 2015-02-06 13:45:54 +03:00
fbt
f8cfeac03c And another bugfix. 2015-02-06 13:43:36 +03:00
fbt
422adf3d47 args_norm is not needed now.
+ a bugfix.
2015-02-06 13:42:10 +03:00
fbt
07d1805d13 I don't like getopts. Don't know why. I just don't. 2015-02-06 13:40:27 +03:00
fbt
3d148e6b4a Handle arguments with getopt: it supports arguments with spaces. 2015-02-06 11:25:36 +03:00
fbt
c8b1f67bdd Don't download existing sources 2015-02-06 09:28:40 +03:00
fbt
d1becc7836 Show versions in AUR searches, less jshon calls, read -r 2015-02-03 12:58:00 +03:00
fbt
b68c7c5949 A slight fix for the argument handler, doesn't really affect zpac in its current state. 2015-02-01 17:27:39 +03:00
fbt
8e575157f7 Handle -- properly 2015-01-31 18:54:41 +03:00
2 changed files with 70 additions and 40 deletions

View File

@@ -2,16 +2,15 @@ zpac
---- ----
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.
$ zpac -h Usage: zpac [flags] <package>
Usage: zpac [flags] <package> 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.
-S Search only in the sync db. Implies -s. -A Search only in AUR. Implies -s.
-A Search only in AUR. Implies -s. -d Get the package sources (default). Set twice to also get the dependencies.
-d Get the package sources (default). -f Force downloading package sources even if they are already present in the working directory.
-D Get the dependencies also. Implies -d. -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/zpac.rc.sh
By default zpac downloads the sources into the current directory. Controlled by `$cfg_workdir`. By default zpac downloads the sources into the current directory. Controlled by `$cfg_workdir`.

91
zpac
View File

@@ -20,8 +20,9 @@ usage() {
-s Search for <package>. -s Search for <package>.
-S Search only in the sync db. Implies -s. -S Search only in the sync db. Implies -s.
-A Search only in AUR. Implies -s. -A Search only in AUR. Implies -s.
-d Get the package sources (default). -d Get the package sources (default). Set twice to also get the dependencies.
Set twice to also get the dependencies. -f Force downloading package sources even if they are already present in the working directory.
-w <dir> Set the working directory.
EOF EOF
} }
@@ -35,7 +36,14 @@ aur.search() {
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
printf 'aur/%s\n %s\n' "${aur_search_results[${i}]}" "$( jshon -e results -e $i -e Description -u <<< "$aur_api_search_data" )" {
read -r version
read -r description
} < <(
jshon -e results -e $i -e Version -u -p -e Description -u <<< "$aur_api_search_data"
)
printf '%s %s\n %s\n' "aur/${aur_search_results[$i]}" "$version" "$description"
done done
else else
return 1 return 1
@@ -56,21 +64,32 @@ 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 local dep_name aur_api_multireq aur_deps_api_data aur_deps_count aur_deps pkg_aur_info pkg_base tarball_path
read pkg_aur_info read -r pkg_aur_info
pkg_base=$( jshon -e results -e PackageBase -u <<< "$pkg_aur_info" ) {
tarball_path=$( jshon -e results -e URLPath -u <<< "$pkg_aur_info" ) read -r pkg_base
read -r tarball_path
} < <(
jshon -e results -e PackageBase -u -p -e URLPath -u <<< "$pkg_aur_info"
)
(( flag_force )) || {
[[ -d "${cfg_workdir}/${pkg_base}" ]] && {
echo "Found ${pkg_base} in ${cfg_workdir}, skipping. Use -f to override."
return 17
}
}
cd "$cfg_workdir" cd "$cfg_workdir"
echo "Downloading ${cfg_aur_url}${tarball_path}" echo "Working in ${cfg_workdir}"
echo "Downloading ${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!"
return 1 return 1
} }
echo ": ${cfg_workdir}/${pkg_base}"
if (( flag_get_deps )); then if (( flag_get_deps )); then
unset depends makedepends unset depends makedepends
@@ -86,11 +105,18 @@ 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}."
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")
return "$?" _result="$?"
(( _result )) && {
(( _result == 17 )) || {
return "$_result"
}
} }
done done
fi fi
@@ -113,39 +139,36 @@ abs.get() {
} }
args_norm() { args_norm() {
declare arg opt c
declare -g argv
while (( $# )); do while (( $# )); do
unset -v arg opt c keys unset -v arg opt c
case "$1" in case "$1" in
--) shift; break;; (--) argv+=( "$1" ); break;;
--*) (--*)
IFS='=' read arg opt <<< "$1" IFS='=' read arg opt <<< "$1"
printf '%s\n' "$arg" argv+=( "$arg" )
[[ "$opt" ]] && { [[ "$opt" ]] && {
printf '%s\n' "$opt" argv+=( "$opt" )
} }
;; ;;
-*) (-*)
while read -n1 c while read -n1 c
do do
case "$c" in case "$c" in
-|'') :;; -|'') :;;
*) keys+=( "-$c" );; *) argv+=( "-$c" );;
esac esac
done <<< "$1" done <<< "$1"
printf '%s\n' "${keys[@]}"
;; ;;
(*) argv+=( "$1" );;
esac esac
[[ "$2" && ! "$2" =~ ^- ]] && {
printf '%s\n' "$2"
shift
}
shift shift
done done
} }
@@ -157,6 +180,8 @@ main() {
while (( $# )); do while (( $# )); do
case "$1" in case "$1" in
(--) shift; break;;
(-h) usage; return 0;; (-h) usage; return 0;;
(-s) action='search';; (-s) action='search';;
@@ -175,14 +200,19 @@ main() {
fi fi
;; ;;
(--) shift; break;; (-w)
cfg_workdir="$2"
shift;;
(-f) flag_force=1;;
(-*) (-*)
err "Unknown key: $1" err "Unknown key: $1"
usage usage
return 1 return 1
;; ;;
*) break;; (*) break;;
esac esac
shift shift
done done
@@ -217,7 +247,7 @@ main() {
if (( ! "$?" )); then if (( ! "$?" )); then
repo='aur' repo='aur'
else else
while read; do while read -r; do
if [[ "$REPLY" =~ ^Repository ]]; then if [[ "$REPLY" =~ ^Repository ]]; then
repo="${REPLY##* }" repo="${REPLY##* }"
fi fi
@@ -265,4 +295,5 @@ main() {
esac esac
} }
main $(args_norm "$@") args_norm "$@"
main "${argv[@]}"