Às vezes, quando quero descobrir um novo software para usar, tenho que comparar vários pacotes. Um dos fatores importantes para mim é o tamanho da embalagem, já que costumo usar embalagens leves para tudo.
O pacman -Ss
comando é muito útil, mas eu adoraria ter o tamanho dos pacotes também para poder comparar. Eu tentei pacman -Ssi
, mas não funciona. Existe alguma maneira de adicionar algumas informações ao resultado de pacman -Ss
?
Eu também tentei pacman -Ss -p --print-format "%n: %s"
, mas também não funcionou.
Responder1
Você pode usar pacman -Si
para obter o tamanho instalado de um pacote. Então tudo se torna uma questão de script awk.
Você pode definir a seguinte função e usá-la.
pkgsize(){
pacman -Ss $@ | awk '{if(NR%2) {system("pacman -Si "$1" | grep Ins | cut -d\":\" -f 2 | tr -d \" \n\" "" "); printf " "$1"$";} else print $0}' | sort -h | tr "$" "\n"
}
Você também pode fazer assim se quiser:
pkgsize(){
pacman -Ss video edit | awk 'NR%2 { while("pacman -Si "$1 | getline line) if (line ~ /Ins/) { split(line,a,/:/);printf a[2] };print $1""}'
}
Acabei de descobrir que existe uma abordagem muito mais fácil!
pkgsize(){ expac -SsH M "%m: %n$\t%d" $@ | sort -h | tr '$' '\n'}
Responder2
Aqui está outra solução mais explícita escrita em bash para coletar tamanhos de pacotes, incluindo todas as dependências mínimas.
# bc compatible math form
# ex. 10KiB + 9MiB => 10*kib + 9*mib
function math () {
printf '%s\n' "$@" \
| sed -E 's/(([0-9]+)[[:space:]]*([a-zA-Z]+))/\2*\3/g' \
| sed -E 's,[^a-zA-Z0-9+*/. -]+,,g' \
| tr '[:upper:]' '[:lower:]' || true
}
# bc wrapper with optional SCALE env to round up
function calc () {
[ -z "$1" ] \
&& echo 0 \
&& return 0
local scale=""
local result=
local form="$(math "$@")"
{ [ -z "$form" ] \
|| [[ "$form" =~ ^[+*/-].*$ ]]; } \
&& local form="0$form"
if [[ "$SCALE" =~ ^[0-9]{1}$ ]]; then
local script="scale=$SCALE;x=((10^$SCALE)*($form)+0.5)/(10^$SCALE); print x"
printf "%.${SCALE}f" "$(bc -l <<EOF
$CALC_VARS
$script
EOF
)"
else
local script="x=($form); print x"
bc -l <<EOF
$CALC_VARS
$script
EOF
fi
}
# calc wrapper to pass byte relevant units
function bytecalc () {
CALC_VARS="s=512
kib=1024
mib=1024*kib
gib=1024*mib
tib=1024*gib
kb=1000
mb=1000*kb
gb=1000*mb
tb=1000*gb" calc "$@"
}
function Package::size () {
[ -z "$SEEN" ] \
&& local SEEN=`mktemp` \
&& local cleanup=${#FUNCNAME[@]}
local sum=0
for pkg in "$@"; do
cat "$SEEN" | grep -qE "^$pkg$" \
&& continue
local info=`pacman -Qi "$pkg" 2>/dev/null || pacman -Si "$pkg"`
local size=`grep "Installed Size" <<<"$info" \
| cut -d: -f2 | xargs \
| tr , . || true`
local -a deps=(`grep "Depends On" <<<"$info" \
| cut -d: -f2 \
| grep -oE "($| )[a-z][a-z0-9_.-]*" || true`)
echo "$pkg" >>"$SEEN"
test "${#deps[@]}" -gt 0 \
&& echo "lookup deps for '$pkg': ${deps[@]}" >&2 \
&& local depsize=$(Package::size "${deps[@]}" || true) \
|| local depsize=0
sum=$(SCALE=0 bytecalc "${sum:-0} + ${size:-0} + ${depsize:-0}")
done
test ${cleanup} -eq ${#FUNCNAME[@]} && rm "$SEEN"
echo "$sum"
}
Testes locais
Na minha máquina, Package::size konsole
os resultados 1973756405 bytes
ainda parecem um pouco monolíticos. Por outro lado, se você deseja construir uma distribuição personalizada e moderna apenas com o konsole instalado, seu nicho é pelo menos apoiado por muito potencial de framework.
Sidenote sobre sincronização de banco de dados
Observe que esta função consulta primeiro o banco de dados local e consulta os dados remotos em caso de falha. Portanto, é possível que as listas de dependências locais e remotas não estejam sincronizadas, o que provavelmente retornará resultados errados.
Escopos de variáveis bash
Eu não considero o bash um bug como um todo, mas sim o fato de que variáveis locais são visíveis dentro das funções filhas da função em questão que eu considero.