ALT Linux Community general discussions
 help / color / mirror / Atom feed
From: "Alexei V. Mezin" <mezin@ntmdt.ru>
To: ALT Linux Community <community@lists.altlinux.org>
Subject: [JT ]Re: [Comm] Re: Подскажите о сборке программы
Date: Mon, 12 Dec 2005 19:13:02 +0300
Message-ID: <439DA18E.5040607@ntmdt.ru> (raw)
In-Reply-To: <94a6689a0512120737g7db0f383v@mail.gmail.com>

Алексей Данилович пишет:
> ох. Да я уж сказал, что хорошо это... Но суть не в конкретном пакете :)
А в чем суть? Как собрать программу, выкаченную из инета?
Классический (он же "порочный") путь:
- выкачать tar.gz с программой
- распаковать куда-нить в ~/
- перейти в распакованный каталог
- изучить READMY, INSTALL и прочую документацию
- запустить ./configure --help, изучить результат
- запустить ./configure --prefix=/opt/usr --bla-bla-параметры-по-вкусу
- поглядеть на результат и доставить (рутом) недостающие lib* и *-devel
- выполнить ./configure --prefix=/opt/usr --bla-bla-параметры-по-вкусу
- выполнить make, посмотреть на результат
- поправить ошибки в исходниках
- выполнить make, посмотреть на результат
- выполнить sudo make install
- при необходимости sudo ldconfig
- насладиться результатом

Что тут к чему? configure, на основе разных файлов с описанием того, что 
нужно программе для сборки, проверяет наличие в системе всех нужных 
компонентов, и создает Makefile'ы для сборки программы. Так же учитывает 
и ключи, указанные пользователем (каталог установки, 
включение/отключение отдельных фичей, каталоги с библиотеками и т.п.). 
После этого make, на основе инструкций в Makefile'ах вызывает 
соответствующие компиляторы/линкеры и собирает программу и библиотеки. 
Далее make install устанавливает все в систему.

Это "плохой, негодный" (с) путь установки программ. Причины: для сборки 
программ в системе придется держать кучу компиляторов и заголовочных 
файлов для библиотек. Установленные таким образом программы чаще всего 
невозможно грамотно деинсталлировать. По хорошему перед инсталляцией 
нужно проверять "безопасность" инсталляционных скриптов, а то мало ли 
чего и куда они запишут. Невозможно автоматическое обновление программ. 
И так далее и тому подобное.

Хороший путь установки программ "из исходников" -- скачать src.rpm из 
бэкпортов или Сизифа, настроить сборочную среду hasher и собрать в ней 
бинарный пакет. Который потом спокойно поставить штатным apt/rpm. Этот 
способ хорош тем, что:
- src.rpm содержит кроме исходников еще патчи и spec-файл с правилами 
сборки. Т.е. мэйнтейнер пакета заранее наступил на все грабли, и 
заботливо составил программу их обхода. Поэтому Src.rpm чаще всего 
собираются.
- сборка в hasher не требует установки в систему кучи лишних пакетов.
- сборка и последующая установка пакета гарантируют то, что пакет потом 
можно будет снести, обновить и так далее. Кроме того, автоматом 
отслеживаются зависимости.

Что делать, если нужной программы нет на ftp.altlinux? Поискать на сайте 
разработчиков программы Src.rpm (скорее всего под RH/Mandriva), скачать 
его, исправить спек-файл, собрать Src.rpm и отправить его в hasher на 
сборку <arch>.rpm. После этого либо стать мэйнтейнером пакета, либо 
передать спек кому-нить из действующих мэйнтернеров, вдруг пригодится.

Если нет src.rpm, то качать tar.gz и делать спек самому. Или просить в 
рассылке, может кто уже собрал/может собрать нужный пакет.



-- 
Alexei V. Mezin

NT-MDT Co.
Phone: 095-913-5736
Fax: 095-913-573
Email: mezin@ntmdt.ru
URL: http://www.ntmdt.com


  reply	other threads:[~2005-12-12 16:13 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-12-12  8:33 [Comm] " Алексей Данилович
2005-12-12 10:01 ` [Comm] " Michael Shigorin
2005-12-12 10:33   ` Алексей Данилович
2005-12-12 11:08     ` Michael Shigorin
2005-12-12 11:42       ` Алексей Данилович
2005-12-12 11:50         ` Michael Shigorin
2005-12-12 15:37           ` Алексей Данилович
2005-12-12 16:13             ` Alexei V. Mezin [this message]
2005-12-13  6:54               ` [JT ]Re: " Алексей Данилович
2005-12-13  9:33                 ` Alexei V. Mezin
2005-12-13 12:03                 ` Vladimir V. Kamarzin
2005-12-17  9:16     ` Re[2]: " Andrew Marcipaka

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=439DA18E.5040607@ntmdt.ru \
    --to=mezin@ntmdt.ru \
    --cc=community@lists.altlinux.org \
    /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 Community general discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/community/0 community/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 community community/ http://lore.altlinux.org/community \
		mandrake-russian@linuxteam.iplabs.ru community@lists.altlinux.org community@lists.altlinux.ru community@lists.altlinux.com
	public-inbox-index community

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.community


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git