Open Source & Linux Lab

It's better when it's simple

User Tools

Site Tools


etc:common_activities:slind:deb_producer

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
Last revisionBoth sides next revision
etc:common_activities:slind:deb_producer [2007/11/10 20:36] kkvetc:common_activities:slind:deb_producer [2008/01/17 02:36] kvm
Line 1: Line 1:
-==== Плагин для сборки пакетов ====+===== Плагин генерации .deb пакетов =====
  
-Пакет -- архив, содержащий в себе файлы, приготовленные для установки в систему. Пакет содержит информацию о содержащихся в нём программах, их версияхправилах установки и удаления пакета+<note>  
 +для тестирования плагина в cvs(projects/slind/eclipse/tst/) лежат исходные коды less. Чтобы вручную собрать deb-пакет достаточно((при условиичто установленны все необходимые для сборки пакеты)) выполнить debuild 
 +</note>
  
-Помимо всего прочего, пакет содержит в себе полную версию, __список файлов которые он предоставляет__ и __список требуемых пакетов(зависимостей)__. Список требуемых пакетов содержит пакеты, которые уже должны быть установелны, когда будет происходить установка нашего пакета. 
  
-Разрешением зависимостей занимается менеджер пакетов.+Требования к плагину приведены в таблице. 
 +^Id    ^Описание ^P((приоритет: 1-maх,3-min)) ^Комментарий ^ 
 +| REQ1   | Должен быть расширением стандартного проекта CDT                                          | 1 | | 
 +| REQ2   | Структура дерева файлов пакета должна определяться целью install в makefile               | 1 | | 
 +| REQ3   | Должен поддерживаться standard проект                                                     | 1 | | 
 +| REQ4   | <del>Должен поддерживаться managed проект</del>                                           | 2 | | 
 +| REQ5   | Пользователь указывает местоположение файлов на целевой платформе вручную                 | 1 | | 
 +| REQ6   | Файлы, входящие в пакет берутся из CDT- проекта или из его целей                          | 1 | | 
 +| REQ7   | Должен быть предоставлен интерфейс описания пакетов (файл control)                        | 1 | | 
 +| REQ8   | Должна быть возможность редактирования скриптов установки / удаления  пакета              | 3 | | 
 +| REQ9   | Пользователь должен уметь изменять changelog                                              | 2 | | 
 +| REQ10  | Должна быть возможность генерации бинарного пакета для целевой платформы                  | 1 | | 
 +| REQ11  | Проект должен экспортироваться в deb-пакет выбором меню File/Export выбор debian package  | 1 | | 
 +| REQ12  | Должен быть предоставлен помощник создания каталога debian, генерирующий  файлы control, changelog, rules (для source-пакетов)| 1 |не использовать dh_make |
  
-=== Требования верхнего уровня  === 
  
-FIXME: в работе+==== План работ ==== 
 +|Освоиться со сборкой source и binary пакетов|21.01| 
 +|Экспорт (доработка)|23.01| 
 +едактор control-файла|28.01| 
 +|Помощник changelog|28.01| 
 +|Генерация rules|6.02|
  
-=== Варианты использования (User story) === 
  
-FIXME: требует существенной переработки+==== Определения ====
  
-  **Выбор типа пакета**. Пользователь перед началом создания пакета, должен выбрать что он хочет сделать: +  * **Standard makefile project** -- проект CDT в котором makefile пишется вручную, никогда не изменяется извне средствами разработки. 
-        * сделать очередную версию уже существующего пакета +  * **Managed makefile project** -- проект CDT в котором makefile каждый раз генерируется заново при изменении проекта. 
-        * сделать первую версию нового пакета  +  * **DebianNature** -- свойство проекта CDT, которое означает что проект содержит каталог debian и для него может быть сгенерирован deb-пакет.
-  - **Выбор существующего пакета**. Если пользователь хотел сделать очередную версию, то он должен выбрать пакет с предыдузей версией. +
-  - **Ввод основных данных о пакете**. Пользователь заполняет набор полей, которые необходимы для создания нового пакета. +
-  - **Выбор файлов, входящих в пакет**. Пользователь находясь в окне, где прелставлены все файлы проекта, выделяет те файлы, которые он хочет поместить в пакет+
-  **Указание каталога установки для файлов**. Пользователь видит список ранее выбраных фалов и указывает пути, куда должны быть установленны файлы. Чтобы указать место установки файлов, ему предоставляется возможность выделить один или несколько файлов и нажав на кнопку, в дереве каталогов выбрать необходимый каталог, либо создать новый, если необходимого нет. +
-  - **Редактирование списка зависимостей нового пакета**. Пользователь видит список пакетов, от которых уже зависит данный пакет. При помощи выделения и кнопок он может удалить некоторые из них, либо добавить новые. Если пользователь нажимает на кнопку добавления нового пакета, ему предлагается ввести имя нового пакета, от которого будет зависить его пакет+
-  **Добавление скриптов пре/пост инсталяции/деинсталяции**. Пользователь видит список возможных видов скриптов, которые он может добавить. Выбирает какой-то тип, после чего ему предлагается выбрать файл, хранящийся на диске, с этим скриптом. Пользователь может указать свой скрипт для каждого типа. +
-  - **Ввод "изменений" в changelog пакета**. Пользователь просматривает существующий changelog. и имеет возможность ввести текст нового изменения. Все остальные поля проставленны автоматически. Редактировать изменения прошлых версий пользователь не может+
-  - **Сборка нового пакета**. Пользователь наблюдает все ранее введеные данные в наглядной форме, чтобы удостоверится, что он все сделал правильно и нажимает кнопку "Finish" чтобы собрать пакет.+
  
  
-=== Уточняющая информация === 
  
-== Входные данные для генерации пакета == 
  
-Чтобы сгенерировать пакет, необходимо иметь следующие данные: +==== Реализация ====
-  * тип пакета (бинарный или с исходными текстами программы); +
-  * список файлов, которые необходимо запаковать; +
-  * в случае, если это бинарный пакет необходимо: +
-     * список требуемых библиотек;+
-     * список предоставляемых библиотек; +
-  * путь, куда ставить какой файл(разные файлы могут быть установлены в различные каталоги)+
  
-== Сборка пакетов для другой платформы ==+  * Разработка пакета (плагина) org.slind.ei.debproducer 
 +  * Для standard-проектов пользователь вручную заполняет местоположение файлов внутри цели install 
 +  * <del>Для managed-проектов пользватель может отредактировать переменные указывающие пути для установи файлов в целевой системе(bin,doc,lib,...)</del>   
 +  * Если в проекте нет каталога debian, (в котором в том числе лежит changelog), то он генерируется помощником, и все файлы добавляются в проект  
 +  * Сборка пакета происходит из специально подготовленного каталога при помощи dpkg 
 +  * Подготовка каталога, где будет запущен dpkg, происходит при помощи make install и копирования директории debian экспортируемого проекта
  
-FIXME: в работе 
  
-== Пакеты с исходниками: сборка и установка == 
  
-FIXME: в работе 
  
  
Line 52: Line 55:
  
  
 +==== Интерфейс пользователя ====
 +
 +  * Генерация каталога DEBIAN (File->New->DEBIAN) ((заполнение файла control, rules для source-пакетов, генерация файла changelog))
 +  * Редактор файла control: по аналогии с редактором для plugin.xml. Должен предоставлять возможность заполнения стандартных полей control-файла и добавление специальных полей для пакетов slind
 +  * Дейсвия редактировани файла changelog: new item, new version, новая подверсия (non-maintainer)
 +  * Экспорт пакета (File->Export->.deb package)
 +
 +
 +
 +
 +
 +
 +
 +==== Сценарии ====
 +  * Предусловие: стандартный cdt-проект. В makefile проекта есть цель install, зависящая от DESTDIR
 +=== Генерация директории DEBIAN ===
 +  * Пользователь выбирает пункт меню File->New->DEBIAN
 +[[.:deb_producer:gui | Мастер]] имеет следующие экраны:
 +^наименование ^обязательный ^назначение ^ 
 +| Package type                  | да  | выбор типа пакета, указание пути к директории debian от корня проекта|
 +|Source description|source|Описание общей части|
 +|Packages descrition|source|Описание бинарных пакетов|
 +|Package description|binary|Описание бинарного пакета|
 + 
 +  * В полях мастера пользователь заполняет поля для файла control 
 +  * Генерируется директория debian, содержащая файлы control, changelog и rules((для source-пакетов))
 +  * Пользователь имеет возможность редактировать полученные файлы и добавлять необязательные файлы в созданный каталог
 +=== Экспорт .deb-пакета ===
 +  * Пользователь выбирает меню File/export или Export в контекстном меню проекта. В появившемся дилоге 
 +выбирает пункт "General/Debian package".
 +Мастер имеет следующие экраны:
 +^наименование ^обязательный ^назначение ^ 
 +| export                | да  | путь для сохранения .deb|
 +
 +  * словно по волшебству, в указанной директории появляется deb-пакет...
 +
 +==== Подробности ====
 +
 +  * [[.:deb_producer:files_description   | Описание структуры файлов каталога DEBIAN]]
 +  * [[.:deb_producer:gui          | Интерфейс пользователя]]
 +
 +
 +
 +==== Ссылки ====
 +[[http://www.eclipseplugincentral.com/Web_Links-index-req-viewlink-cid-275.html|плагин для редактирования скриптов]]
 +
 +~~DISCUSSION~~
etc/common_activities/slind/deb_producer.txt · Last modified: 2008/03/23 23:16 by zan