From: Mikhail Zabaluev <mhz@alt-linux.org> To: devel@altlinux.ru Subject: [devel] Эссе о lib%name-devel :) Date: Fri, 9 Nov 2001 02:58:12 +0300 Message-ID: <20011109025812.B1986@localhost.localdomain> (raw) Доброго времени суток. Считаю нужным обстоятельно высказаться на столь активно обсуждаемую тему, хотя бы потому, чтобы разъяснить, за что я так взъелся по, казалось бы, пустяковому вопросу. Вы правы, поезд ушел и с delibification не стоит торопиться накануне релиза. Но я хочу показать, почему принятое сейчас правило может быть неудобным и недружественным к пользователю. О логичности спорить не будем, потому что логика в правиле все же есть. Я буду обозначать принятую в нашем дистрибутиве конвенцию lib%name-devel "правилом ALTLinux", а конвенцию %name-devel -- "правилом RedHat". Итак, рассмотрим достаточно типичный сценарий поведения пользователя, который, судя по сообщениям в рассылки, встречается довольно часто. 1. Пользователь много слышал о софте по имени foo, видел ссылки на freshmeat'е и горит желанием эту штуку поставить. Он находит пакет foo в дистрибутиве и радостно его устанавливает. По пути выясняется, что пакет foo требует libfoo. Пользователь, недолго думая, удовлетворяет зависимость, либо это за него делает автоматика. Факт наличия libfoo быстро выветривается из памяти пользователя. 2. Спустя некоторое время пользователь решает собрать нечто с использованием foo. Собирает он не из source RPM, поэтому никаких BuildRequires не существует. Пользователю быстро становится ясно, что для разработки нужны некие дополнительные файлы. Если он знаком с RedHat и не ведает подвоха, он ищет foo-devel и, не найдя, приходит в горькое недоумение. Если пользователь стреляный, он будет искать и libfoo-devel и foo-devel (поскольку второй вариант тоже встречается). Понятно, что цена вопроса -- один glob, но в гуевых средствах этот glob придется делать вручную :( Поиск еще усложняется, когда lib-пакеты меняют "корень" по имени библиотеки, которую они содержат -- что, кстати, правильно для пакета с самой библиотекой, по тем же соображениям легкости поиска. Когда от вас требуют libcapplet.so.0, вы первым делом станете искать пакет libcapplet. Но чтобы догадаться, что для разработки под control-center нужен libcapplet-devel, нужно обладать инсайдерской информацией :) С "правилом RH" проблема часто решается еще на этапе 1, когда пользователь видит в листинге foo и foo-devel рядом и устанавливает их вместе "до кучи". Так было и в Spring. Были возражения, что в дистрибутиве с "правилом RH" не однозначно выводится имя -devel пакета из имени libfoo. Во-первых, эта неоднозначность симметрична описанной выше для "правила AltLinux". Во-вторых, ниже приведена shell-функция, которая выдает имя соответствующего -devel по имени _любого_ пакета, если действует "правило RH". FindDevel() { local name=$1 # Try the obvious local develname="${name}-devel" if CheckPackage $develname; then echo $develname return fi # Deduce from the name of the source package local srcname=$(rpm -q --qf='%{SOURCERPM}\n' $name) develname=${srcname%%-[0-9]*}-devel if CheckPackage $develname; then echo $develname return fi return 1 } Не приведенная здесь функция CheckPackage проверяет наличие пакета в репозитарии. Теперь попробуйте-ка вычислить libcapplet-devel из control-center по "правилу AltLinux" без доступа к spec'у. И еще. Будет ли 'apt-get install libfoo-devel' устанавливать foo-devel, если у того прописан соответствующий Provides? Если да, то можно обязать в -devel писать Provides: lib%name-devel для всех пакетов lib%name, которые данный -devel покрывает. Тогда, имея libfoo, можно будет не думая набрать приведенную выше команду и получить ровно то, что нужно. -- Stay tuned, MhZ JID: mookid@jabber.org ___________ God is Dead. -- Nietzsche Nietzsche is Dead. -- God Nietzsche is God. -- Dead _______________________________________________ Devel mailing list Devel@linux.iplabs.ru http://www.logic.ru/mailman/listinfo/devel
next reply other threads:[~2001-11-08 23:58 UTC|newest] Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top 2001-11-08 23:58 Mikhail Zabaluev [this message] 2001-11-09 8:35 ` Dmitry V. Levin 2001-11-09 9:25 ` [devel] " Mikhail Zabaluev 2001-11-10 8:44 ` [devel] " Michael Shigorin 2001-11-10 9:42 ` [devel] " Mikhail Zabaluev
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20011109025812.B1986@localhost.localdomain \ --to=mhz@alt-linux.org \ --cc=devel@altlinux.ru \ --cc=devel@linux.iplabs.ru \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
ALT Linux Team development discussions This inbox may be cloned and mirrored by anyone: git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \ devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru public-inbox-index devel Example config snippet for mirrors. Newsgroup available over NNTP: nntp://lore.altlinux.org/org.altlinux.lists.devel AGPL code for this site: git clone https://public-inbox.org/public-inbox.git