Introduzione

Per chi come me utilizza un sistema misto (testing/sid) è ogni tanto utile sapere quanti e quali pacchetti provengono da quale release. Proprio dopo il recente aggiornamento a Squeeze/Sid mi sono trovato con diversi pacchetti provenienti da Sid. Non tutti sono forse però basilari per il sistema; intendo dire, alcuni sono magari prelevabili da Squeeze, senza scomodare Sid. Cercando in lungo e in largo tutte le espressioni regolari possibili con aptitude, non sono riuscito a trovare un buon metodo per ottenere il risultato voluto. Infine sono incappato in apt-show-versions, e ho capito subito che le mie ricerche avevano dato buon frutto.

Sintassi e utilizzo

Dando il comando

$ apt-show-versions <nomepacchetto>

si ottiene

<nomepacchetto>/<release> <aggiornabilità> (uptodate o upgradeable from xxx to yyy) <versione_attuale>

Ad esempio:

$ apt-show-versions aptitude
aptitude/squeeze uptodate 0.4.11.11-1

Come sopra, otteniamo che il pacchetto aptitude proviene da Squeeze, è aggiornato ed è alla versione 0.4.11.11-1.

Per ottenere una lista di tutti i pacchetti basterà digitare il comando:

$ apt-show-versions

dunque senza specificare nessun pacchetto.

Alcuni esempi

Grazie all'utilizzo di qualche pipe, ovvero la possibilità di eseguire un comando o un'applicazione all'interno di un altro, e di grep, necessario per "filtrare" il risultato, potremmo ora scegliere, contare, rimuovere, tutti i pacchetti di una particolare release.

Visualizzare tutti i pacchetti provenienti da Sid

$ apt-show-versions | grep sid

Contare tutti i pacchetti provenienti da Sid

$ apt-show-versions | grep sid | wc -l

Rimuovere tutti i pacchetti provenienti da Sid

# aptitude remove `apt-show-versions | grep sid | cut -d '/' -f1`

dove con cut -d '/' -f1, dividiamo la stringa dove c'è lo slash (/) e ne prendiamo solo il primo campo (-f1) per avere il nome del pacchetto senza le informazioni relative alla release, all'aggiornabilità e alla versione (che non sarebbero "digerite" da aptitude).

Pinning

  ATTENZIONE
al pinning!


Dal momento che l'utilità del pacchetto si trova in un sistema misto, molto probabilmente anche se non necessariamente, utilizzerete il pinning per gestire i pacchetti provenienti da release diverse. In questo caso, per un pinning > 500 i pacchetti ad esempio in testing con una versione superiore in Sid verranno considerati pacchetti appartenenti a Sid ed aggiornabili. Dunque, al prossimo aggiornamento passeranno all'ultima versione disponibile trovandosi effettivamente in Sid.
Per una "giovane" testing o un sistema misto Sid/experimental è dunque consigliabile un pinning inferiore a 500 per la release superiore.

Approfondimenti

Ulteriori risorse:

  • manpage relative ai comandi citati in questa guida;
  • la guida ufficiale Debian, nella sezione dedicata alla gestione dei pacchetti;
  • una interessante discussione sul forum di Debianizzati.


Happy debian !


Brunitika