Compare commits
15 Commits
Author | SHA1 | Date | |
---|---|---|---|
8591081269 | |||
9e15b8200e | |||
bf18623e06 | |||
34775cfe97 | |||
9b3ea06c61 | |||
f8cfeac03c | |||
422adf3d47 | |||
07d1805d13 | |||
3d148e6b4a | |||
c8b1f67bdd | |||
d1becc7836 | |||
b68c7c5949 | |||
8e575157f7 | |||
7d778ecd66 | |||
aa8929ff8e |
11
README.md
11
README.md
@@ -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).
|
-d Get the package sources (default). Set twice to also get the dependencies.
|
||||||
-D Get the dependencies also. Implies -d.
|
-f Force downloading package sources even if they are already present in 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/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`.
|
||||||
|
|
||||||
|
110
zpac
110
zpac
@@ -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.
|
||||||
-D Get the dependencies also. Implies -d.
|
-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
|
||||||
aur_deps=$( jshon -e results -a -e Name -u <<< "$aur_deps_api_data" )
|
echo "Getting dependencies for ${pkg_base}."
|
||||||
|
|
||||||
|
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
|
||||||
@@ -112,6 +138,41 @@ 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() {
|
||||||
|
declare arg opt c
|
||||||
|
declare -g argv
|
||||||
|
|
||||||
|
while (( $# )); do
|
||||||
|
unset -v arg opt c
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
(--) argv+=( "$1" ); break;;
|
||||||
|
|
||||||
|
(--*)
|
||||||
|
IFS='=' read arg opt <<< "$1"
|
||||||
|
argv+=( "$arg" )
|
||||||
|
|
||||||
|
[[ "$opt" ]] && {
|
||||||
|
argv+=( "$opt" )
|
||||||
|
}
|
||||||
|
;;
|
||||||
|
|
||||||
|
(-*)
|
||||||
|
while read -n1 c
|
||||||
|
do
|
||||||
|
case "$c" in
|
||||||
|
-|'') :;;
|
||||||
|
*) argv+=( "-$c" );;
|
||||||
|
esac
|
||||||
|
done <<< "$1"
|
||||||
|
;;
|
||||||
|
|
||||||
|
(*) argv+=( "$1" );;
|
||||||
|
esac
|
||||||
|
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"
|
||||||
@@ -119,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';;
|
||||||
@@ -129,19 +192,27 @@ main() {
|
|||||||
action='search'
|
action='search'
|
||||||
flag_search_syncdb=1;;
|
flag_search_syncdb=1;;
|
||||||
|
|
||||||
(-d) action='get';;
|
(-d)
|
||||||
(-D)
|
if [[ "$action" == 'get' ]]; then
|
||||||
|
flag_get_deps=1
|
||||||
|
else
|
||||||
action='get'
|
action='get'
|
||||||
flag_get_deps=1;;
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
(-w)
|
||||||
|
cfg_workdir="$2"
|
||||||
|
shift;;
|
||||||
|
|
||||||
|
(-f) flag_force=1;;
|
||||||
|
|
||||||
(--) shift; break;;
|
|
||||||
(-*)
|
(-*)
|
||||||
err "Unknown key: $1"
|
err "Unknown key: $1"
|
||||||
usage
|
usage
|
||||||
return 1
|
return 1
|
||||||
;;
|
;;
|
||||||
|
|
||||||
*) break;;
|
(*) break;;
|
||||||
esac
|
esac
|
||||||
shift
|
shift
|
||||||
done
|
done
|
||||||
@@ -176,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
|
||||||
@@ -224,4 +295,5 @@ main() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
main "$@"
|
args_norm "$@"
|
||||||
|
main "${argv[@]}"
|
||||||
|
Reference in New Issue
Block a user