Как я могу получить список всех репозиториев и PPA из командной строки в сценарий установки?


217

Я знаю, как составить список всех пакетов, установленных в моей системе.

Но как я могу получить список всех репозиториев и PPA-скриптов в сценарии, который я могу запустить на новом компьютере для репликации настроек репозитория, включая ключи?

Я знаю, что могу изучить /etc/apt/sources.listи /etc/apt/sources.list.d, но я ищу способ создания сценария, который выполняет все apt-add-repositoryкоманды в новой системе (который сортирует получение всех ключей).

Есть идеи?

Ответы:


106

Вы можете показать все с:

grep ^ /etc/apt/sources.list /etc/apt/sources.list.d/*

13
Как насчет egrep -v '^#|^ *$' /etc/apt/sources.list /etc/apt/sources.list.d/*удаления закомментированных строк и пустых строк?

3
не могли бы вы объяснить использование ^после grepв grep ^ /etc/apt/sources.list /etc/apt/sources.list.d/*?

4
@ vasa1 Символ каретки ^ и знак доллара $ - это метасимволы, которые соответственно соответствуют пустой строке в начале и конце строки.
wojox

4
Я использую Grep ^ [^ #] ... - Он автоматически скрывает все комментировали-исходников
Росс Айкен

13
Если вы не собираетесь ничего отфильтровывать, не будет ли проще просто запуститьcat /etc/apt/sources.list /etc/apt/sources.list.d/*
jbo5112

99

Спасибо за указатели. После небольшой очистки я получил скрипт, в котором перечислены PPA, но не какой-либо другой репозиторий:

#! /bin/sh 
# listppa Script to get all the PPA installed on a system ready to share for reininstall
for APT in `find /etc/apt/ -name \*.list`; do
    grep -o "^deb http://ppa.launchpad.net/[a-z0-9\-]\+/[a-z0-9\-]\+" $APT | while read ENTRY ; do
        USER=`echo $ENTRY | cut -d/ -f4`
        PPA=`echo $ENTRY | cut -d/ -f5`
        echo sudo apt-add-repository ppa:$USER/$PPA
    done
done

Когда вы вызываете его, listppa > installppa.shвы получаете скрипт, который вы можете скопировать на новый компьютер, чтобы переустановить все PPA.

Следующая остановка: сделайте это для других репозиториев:

#! /bin/sh
# Script to get all the PPA installed on a system
for APT in `find /etc/apt/ -name \*.list`; do
    grep -Po "(?<=^deb\s).*?(?=#|$)" $APT | while read ENTRY ; do
        HOST=`echo $ENTRY | cut -d/ -f3`
        USER=`echo $ENTRY | cut -d/ -f4`
        PPA=`echo $ENTRY | cut -d/ -f5`
        #echo sudo apt-add-repository ppa:$USER/$PPA
        if [ "ppa.launchpad.net" = "$HOST" ]; then
            echo sudo apt-add-repository ppa:$USER/$PPA
        else
            echo sudo apt-add-repository \'${ENTRY}\'
        fi
    done
done

Это должно сделать свое дело. Мне нужен вопрос о суперпользователе, чтобы выяснить правильное регулярное выражение.


1
В вашем grep -oпримере, \` in [a-z0-9\-]не делает то, что вы ожидаете. Это фактически соответствует буквальному обратному слешу . Вам не нужно , чтобы избежать- , когда она находится в начале или в конце []списка; на самом деле, вы не можете избежать этого! .. В этом случае \`(вероятно) не будет возникать проблема, потому что вы (надеюсь) не встретите обратную косую черту в debзаписи.
Peter.O

2
Обратите внимание, что имена PPA могут содержать точки, поэтому я думаю, что вы хотите изменить свое регулярное выражение наhttp://ppa.launchpad.net/[a-z0-9-]\+/[a-z0-9.-]\+
kynan

Нет, вы хотите изменить регулярное выражение [[:graph:]] вместо, [a-z...blah.anything]потому что оно будет соответствовать любым буквенно-цифровым + знакам препинания - это то, из чего состоят имена PPA.
MichalH

Я полагаю, вы должны включить debслово в начале каждой строки хранилища, если оно не указано в ppa:$USER/$PPAформе.
Ярно

@stwissel - какая-то конкретная причина, по которой вы использовали find и grep? Вы можете легко сделать glob, который интерпретирует оболочка, и передать его grep. grep -Po "(?<=^deb\s).*?(?=#|$)" /etc/apt/{sources.list,sources.list.d/*.list} | while read ENTRY ; do echo $ENTRY; doneОбратите внимание, что, как написано, это показывает вам имя файла, из которого происходит каждая запись, поэтому вам нужно будет выполнить обрезку с начала результата до первого двоеточия, но это не слишком сложно с вырезкой. Вы также можете пропустить его, uniqесли не хотите, чтобы несколько записей для одного и того же источника (например, если у вас установлен Google Chrome Stable / Beta / Dev).
dragon788

23

Я удивлен, что самый простой, но самый эффективный способ собрать все включенные бинарные программные источники вместе с файлом, в котором они указаны, еще не опубликован:

grep -r --include '*.list' '^deb ' /etc/apt/sources.list /etc/apt/sources.list.d/

Из всех обработанных файлов будет напечатана каждая строка, начинающаяся с deb. Это исключает закомментированные строки, а также deb-srcстроки для включения репозиториев исходного кода.

Он действительно ищет только все *.listфайлы, которые будут проанализированы apt, но, например, *.list.saveфайлы, используемые для резервного копирования, или другие файлы с недопустимыми именами.


Если вам нужен более короткий, но, возможно, только в 99,9% всех случаев правильный вывод, который может искать слишком много файлов (включая все /etc/apt/sources.list*файлы и каталоги, не только /etc/apt/sources.listи `/etc/apt/sources.list.d/*), вы также можете использовать это:

grep -r --include '*.list' '^deb ' /etc/apt/sources.list*

Если нет файлов, которых там быть не должно, вывод будет таким же.


Пример вывода на моей машине будет такой:

/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily main restricted
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates main restricted
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily universe
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates universe
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily multiverse
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates multiverse
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-backports main restricted universe multiverse
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security main restricted
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security universe
/etc/apt/sources.list:deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security multiverse
/etc/apt/sources.list:deb http://archive.canonical.com/ubuntu wily partner
/etc/apt/sources.list.d/maarten-fonville-ubuntu-ppa-wily.list:deb http://ppa.launchpad.net/maarten-fonville/ppa/ubuntu wily main
/etc/apt/sources.list.d/webupd8team-ubuntu-tor-browser-wily.list:deb http://ppa.launchpad.net/webupd8team/tor-browser/ubuntu wily main
/etc/apt/sources.list.d/fossfreedom-ubuntu-indicator-sysmonitor-wily.list:deb http://ppa.launchpad.net/fossfreedom/indicator-sysmonitor/ubuntu wily main
/etc/apt/sources.list.d/getdeb.list:deb http://archive.getdeb.net/ubuntu wily-getdeb apps

Если вы хотите более красивый вывод, давайте передадим его через sed:

grep -r --include '*.list' '^deb ' /etc/apt/ | sed -re 's/^\/etc\/apt\/sources\.list((\.d\/)?|(:)?)//' -e 's/(.*\.list):/\[\1\] /' -e 's/deb http:\/\/ppa.launchpad.net\/(.*?)\/ubuntu .*/ppa:\1/'

И мы увидим это:

deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily main restricted
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates main restricted
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily universe
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates universe
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily multiverse
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-updates multiverse
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-backports main restricted universe multiverse
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security main restricted
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security universe
deb http://ftp-stud.hs-esslingen.de/ubuntu/ wily-security multiverse
deb http://archive.canonical.com/ubuntu wily partner
[maarten-fonville-ubuntu-ppa-wily.list] ppa:maarten-fonville/ppa
[webupd8team-ubuntu-tor-browser-wily.list] ppa:webupd8team/tor-browser
[fossfreedom-ubuntu-indicator-sysmonitor-wily.list] ppa:fossfreedom/indicator-sysmonitor
[getdeb.list] deb http://archive.getdeb.net/ubuntu wily-getdeb apps

1
Судя по принятому ответу, OP хотел, чтобы PPA были показаны в ppa:<user>/<project>форме.
Муру

Вопрос на самом деле просит сгенерировать скрипт, который устанавливает / включает все репозитории. Но название вопроса только о перечислении их. Кроме того, 2-й ответ с наибольшим количеством баллов только перечисляет их, но он перечисляет слишком много.
Byte Commander

Хорошо, но я уже проголосовал. : D
Муру

Вы можете использовать опцию `-h` для grep, чтобы пропустить имена файлов.
Ярно

11

Запустите следующую команду:

apt-cache policy | grep http | awk '{print $2 $3}' | sort -u

Источник


В бионическом режиме это печатает такие строки, как « mirrors.nic.funet.fi/ubuntubionic-security/main »
Ярно

1
Примечание: apt-cache policyрепо будут показаны только после того, как вы запустите apt-get update. Если вы только что добавили репо add-apt-repository, он не будет отображаться до apt-cache policyтех пор, пока вы не запуститеapt-get update
wisbucky

Per @wisbucky: sudo apt update > /dev/null 2>&1 && sudo apt-cache policy | grep http | awk '{print $2 $3}' | sort -uработает хорошо. gist.github.com/bmatthewshea/229da822f1f02157bff192a2e4a8ffd1
bshea

4

Я использую эту команду для вывода списка всех настроенных программных источников (репозиториев), включая отключенные в настоящий момент :

cat /etc/apt/sources.list; for X in /etc/apt/sources.list.d/*; do echo; echo; echo "** $X:"; echo; cat $X; done

Я использую это в основном для устранения неполадок; это, безусловно, может быть включено в сценарии, но вы можете захотеть сузить /etc/apt/sources.list.d/*его, /etc/apt/sources.list.d/*.listчтобы получить только доступные в настоящее время программные источники.


Спасибо за отзыв. cat перечисляет файлы как они есть, поэтому мне нужно было бы вручную отредактировать их, чтобы сгенерировать скрипт (как указано в вопросе). Проблема с репозиториями: если вы просто скопируете файлы из / etc / apt, вы не получите ключи репозитория. Вот почему я хочу сценарий, который выбирает их для нас
stwissel

2

Итак, мы покопались, у нас есть AptPkg::Class.

Таким образом, используя perlмы можем сделать что-то простое, как это ..

perl -MAptPkg::Cache -MData::Dumper -E'say Dumper [AptPkg::Cache->new->files()]' | less

Это дает нам список всех AptPkg::Class::PkgFileпакетов. Вы могли бы, вероятно, сгенерировать apt-add-repositoryкоманды с этим.


2

https://repogen.simplylinux.ch/ предоставит вам список всех PPA для вашей версии Ubuntu. Вот сгенерированный список без исходных файлов и psa принтера samsung:

#------------------------------------------------------------------------------#
#                            OFFICIAL UBUNTU REPOS                             #
#------------------------------------------------------------------------------#


###### Ubuntu Main Repos
deb http://us.archive.ubuntu.com/ubuntu/ yakkety main restricted universe multiverse 

###### Ubuntu Update Repos
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-security main restricted universe multiverse 
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-updates main restricted universe multiverse 
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-proposed main restricted universe multiverse 
deb http://us.archive.ubuntu.com/ubuntu/ yakkety-backports main restricted universe multiverse 

###### Ubuntu Partner Repo
deb http://archive.canonical.com/ubuntu yakkety partner

#------------------------------------------------------------------------------#
#                           UNOFFICIAL UBUNTU REPOS                            #
#------------------------------------------------------------------------------#


###### 3rd Party Binary Repos

#### Flacon PPA - http://kde-apps.org/content/show.php?content=113388
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F2A61FE5
deb http://ppa.launchpad.net/flacon/ppa/ubuntu yakkety main

#### Gimp PPA - https://launchpad.net/~otto-kesselgulasch/+archive/gimp
## Run this command: sudo apt-key adv --recv-keys --keyserver keyserver.ubuntu.com 614C4B38
deb http://ppa.launchpad.net/otto-kesselgulasch/gimp/ubuntu yakkety main

#### Google Chrome Browser - http://www.google.com/linuxrepositories/
## Run this command: wget -q https://dl.google.com/linux/linux_signing_key.pub -O- | sudo apt-key add -
deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main

#### Google Earth - http://www.google.com/linuxrepositories/
## Run this command: wget -q https://dl.google.com/linux/linux_signing_key.pub -O- | sudo apt-key add -
deb [arch=amd64] http://dl.google.com/linux/earth/deb/ stable main

#### Highly Explosive PPA - https://launchpad.net/~dhor/+archive/myway
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 93330B78
deb http://ppa.launchpad.net/dhor/myway/ubuntu yakkety main

#### JDownloader PPA - https://launchpad.net/~jd-team
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 6A68F637
deb http://ppa.launchpad.net/jd-team/jdownloader/ubuntu yakkety main

#### Lazarus - http://www.lazarus.freepascal.org/
## Run this command:  gpg --keyserver hkp://pgp.mit.edu:11371 --recv-keys 6A11800F  && gpg --export --armor 0F7992B0  | sudo apt-key add -
deb http://www.hu.freepascal.org/lazarus/ lazarus-stable universe

#### LibreOffice PPA - http://www.documentfoundation.org/download/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 1378B444
deb http://ppa.launchpad.net/libreoffice/ppa/ubuntu yakkety main

#### MEGA Sync Client - https://mega.co.nz/
deb http://mega.nz/linux/MEGAsync/xUbuntu_16.10/ ./

#### MKVToolnix - http://www.bunkus.org/videotools/mkvtoolnix/
## Run this command: wget -q http://www.bunkus.org/gpg-pub-moritzbunkus.txt -O- | sudo apt-key add -
deb http://www.bunkus.org/ubuntu/yakkety/ ./

#### Mozilla Daily Build Team PPA - http://edge.launchpad.net/~ubuntu-mozilla-daily/+archive/ppa
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys  247510BE
deb http://ppa.launchpad.net/ubuntu-mozilla-daily/ppa/ubuntu yakkety main

#### muCommander - http://www.mucommander.com/
## Run this command: sudo wget -O - http://apt.mucommander.com/apt.key | sudo apt-key add - 
deb http://apt.mucommander.com stable main non-free contrib  

#### Opera - http://www.opera.com/
## Run this command: sudo wget -O - http://deb.opera.com/archive.key | sudo apt-key add -
deb http://deb.opera.com/opera/ stable non-free

#### Oracle Java (JDK) Installer PPA - http://www.webupd8.org/2012/01/install-oracle-java-jdk-7-in-ubuntu-via.html
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys EEA14886
deb http://ppa.launchpad.net/webupd8team/java/ubuntu yakkety main

#### PlayDeb - http://www.playdeb.net/
## Run this command: wget -O- http://archive.getdeb.net/getdeb-archive.key | sudo apt-key add -
deb http://archive.getdeb.net/ubuntu yakkety-getdeb games

#### SABnzbd PPA - http://sabnzbd.org/
## Run this command:  sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4BB9F05F
deb http://ppa.launchpad.net/jcfp/ppa/ubuntu yakkety main

#### SimpleScreenRecorder PPA - http://www.maartenbaert.be/simplescreenrecorder/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 283EC8CD
deb http://ppa.launchpad.net/maarten-baert/simplescreenrecorder/ubuntu yakkety main

#### Steam for Linux - http://store.steampowered.com/about/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys F24AEA9FB05498B7
deb [arch=i386] http://repo.steampowered.com/steam/ precise steam

#### Syncthing - https://syncthing.net/
## Run this command: curl -s https://syncthing.net/release-key.txt | sudo apt-key add -
deb http://apt.syncthing.net/ syncthing release

#### Tor: anonymity online - https://www.torproject.org
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 886DDD89
deb http://deb.torproject.org/torproject.org yakkety main

#### Unsettings PPA - http://www.florian-diesch.de/software/unsettings/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 0FEB6DD9
deb http://ppa.launchpad.net/diesch/testing/ubuntu yakkety main

#### VirtualBox - http://www.virtualbox.org
## Run this command: wget -q http://download.virtualbox.org/virtualbox/debian/oracle_vbox_2016.asc -O- | sudo apt-key add -
deb http://download.virtualbox.org/virtualbox/debian yakkety contrib

#### Webmin - http://www.webmin.com
## Run this command: wget http://www.webmin.com/jcameron-key.asc -O- | sudo apt-key add -
deb http://download.webmin.com/download/repository sarge contrib

#### WebUpd8 PPA - http://www.webupd8.org/
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 4C9D234C
deb http://ppa.launchpad.net/nilarimogard/webupd8/ubuntu yakkety main

#### Xorg Edgers PPA - https://launchpad.net/~xorg-edgers
## Run this command: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 8844C542  
deb http://ppa.launchpad.net/xorg-edgers/ppa/ubuntu yakkety main
here is a generated list without source files and no samsung printer ppa
#### Yuuguu - http://yuuguu.com
deb http://update.yuuguu.com/repositories/apt hardy multiverse

2

Вот мой скрипт " list-apt-repositories", который перечисляет все репозитории в " /etc/sources.list"и" /etc/sources.list.d/*.list". Вы можете добавить, --ppa-onlyчтобы показать только PPA. PPA автоматически преобразуются в ppa:USER/REPOформат.

Соответствующие части состоят из 5 строк list_sourcesи list_ppaфункций, остальные - просто шаблон, чтобы обернуть его в удобный сценарий оболочки.

list-apt-repositories:

#!/bin/sh

usage () {
  cat >&2 <<USAGE
$0 [--ppa-only]

Options:
  --ppa-only            only list PPAs
USAGE
  exit $1
}

list_sources () {
  grep -E '^deb\s' /etc/apt/sources.list /etc/apt/sources.list.d/*.list |\
    cut -f2- -d: |\
    cut -f2 -d' ' |\
    sed -re 's#http://ppa\.launchpad\.net/([^/]+)/([^/]+)(.*?)$#ppa:\1/\2#g'
}

list_ppa () {
  list_sources | grep '^ppa:'
}

generate=list_sources

while test -n "$1"
do
  case "$1" in
    -h|--help) usage 1;;
    --ppa-only) generate=list_ppa;;
    *)
      printf -- "Unknown argument '$1'\n" >&2
      usage 2
    ;;
  esac
  shift
done

$generate

И чтобы сделать скрипт установки, отправьте другой скрипт " make-apt-repository-install-script". Сгенерированный скрипт поддерживает аргумент -y/ --yesдля неинтерактивного использования (см. add-apt-repository(1)).

make-apt-repository-install-script:

#!/bin/sh

if test -n "$1"
then
  cat >&2 <<USAGE
Usage: $0 < PATH_TO_LIST_OF_REPOS
       list-apt-repositories [--ppa-only] | $0

No options recognized.

Reads list of repositories from stdin and generates a script to install them
using \`add-apt-repository(1)\`. The script is printed to stdout.

The generated script supports an optional
\`-y\` or \`--yes\` argument which causes the \`add-apt-repository\` commands
to be run with the \`--yes\` flag.
USAGE
  exit 1
fi

cat <<INSTALL_SCRIPT
#!/bin/sh
y=
case "\$1" in
  -y|--yes) y=\$1;;
  '') y=;;
  *)
    printf '%s\n' "Unknown option '\$1'" "Usage: \$0 [{-y|--yes}]" >&2
    exit 1
  ;;
esac
INSTALL_SCRIPT

xargs -d'\n' printf "add-apt-repository \$y '%s'\n"

Опять же, важная часть - это xargsкоманда в последней строке, остальное - шаблон.


1

Для этого добавьте строки ppa.launchpad.net как ppa: $ USER / $ PPA. Добавьте другие репозитории с их полной строкой из файлов * .list. Никаких тупых линий.

#! / Bin / Баш
# Мой ~ / bin / mk_repositories_restore_script
mkdir -p ~ / bin 
х = ~ / bin / restore_repositories
echo \ # \! / bin / bash> $ x
chmod u + x $ x
(
 для APT в $ (найти / etc / apt / -name \ *. list)
    do sed -n -e '/ ^ deb / {
     /ppa\.launchpad/s/\(.*\/\/[^\/]*.\)\([^ \ t] * \) \ (. * $ \) / sudo apt-add-repository ppa : \ 2 / р;
     /ppa\.launchpad/!s / \ (deb [\ t] * \) \ (. * $ \) / sudo apt-add-repository \ 2 / p;
    } '$ APT
 сделанный
) | сортировать | uniq | tee -a ~ / bin / restore_repositories

0

Спасибо BobDodds!
Если кому-то будет интересно, я немного обновил ваш код (надеюсь, вы не возражаете).
Этот скрипт будет печатать только добавленные пользователем PPA (/etc/apt/sources.list.d).

    #!/bin/bash
    # My ~/bin/mk_repositories_restore_script
    mkdir -p ~/bin
    x=~/bin/restore_repositories
    echo \#\!/bin/bash > $x
    chmod u+x $x
    (
    for APT in $( find /etc/apt/ -name \*.list )
    do sed -n -e '/^deb /{
          /ppa\.launchpad/s/\(.*\/\/[^\/]*.\)\([^ \t]*\)\(.*\/ubuntu.*$\)/ppa:\2/p;                                                                                                                                                                                       
        }' $APT
    done
    ) | sort | uniq | tee -a ~/bin/restore_repositories

0
sed -r -e '/^deb /!d' -e 's/^([^#]*).*/\1/' -e 's/deb http:\/\/ppa.launchpad.net\/(.+)\/ubuntu .*/ppa:\1/' -e "s/.*/sudo add-apt-repository '&'/" /etc/apt/sources.list /etc/apt/sources.list.d/*

Это не генерирует команды для включения возможных исходных репозиториев (deb-src).


-1

устанавливать ppa-purge

apt install ppa-purge

Затем получить список PPA по завершению вкладки ...

ppa-purge -o( Tabдважды нажмите клавишу)


2
Это как бы задом наперед. Как вы предлагаете OP собирать выходные данные завершения оболочки для хранения или обработки? Кроме того, ppa-purgeне имеет -oфлага в соответствии со своей страницей руководства . -1
Дэвид Фёрстер
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.