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
etc:common_activities:slind:deb_producer [2007/11/10 21:15] kkvetc:common_activities:slind:deb_producer [2008/03/23 23:16] (current) zan
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   | <del>Пользователь указывает местоположение файлов на целевой платформе вручную</del>      | 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 |
  
-=== Требования верхнего уровня  === 
  
-В балице приведены требования самого верхнего уровня к разрабатываемому плагину.+==== План работ ==== 
 +|Освоиться со сборкой source и binary пакетов|21.01| 
 +кспорт (доработка)|23.01| 
 +едактор control-файла|28.01| 
 +|Помощник changelog|28.01| 
 +|Генерация rules|6.02|
  
-^Id    ^Описание ^P((приоритет: 1-мах,3-min)) ^Комментарий ^ 
-| REQ1  | Должен поддерживать проект deb описывающий один или несколько пакетов           | 2 | | 
-| REQ2  | Deb-проект должен уметь загружаться и сохраняться                               | 2 | | 
-| REQ3  | Пользователь должен уметь указывать местоположение файлов на целевой платформе  | 1 | | 
-| REQ4  | Должна быть возможность использования файлов и целей CDT-проекта                | 3 | | 
-| REQ5  | Должен быть предоставлен интерфейс описания пакетов (файл control)              | 1 | | 
-| REQ6  | Должна быть возможность редактирования скриптов установки / удаления  пакета    | 2 | | 
-| REQ7  | Пользователь должен уметь изменять changelog                                    | 1 | | 
-| REQ8  | Должна быть возможность генерации пакета для целевой платформы                  | 1 | | 
-| REQ9  | Должен быть мастер создания проекта                                             | 2 | | 
-| REQ10 | Должна быть возможность генерации пакета с исходными текстами                   | 2 | | 
-| REQ11 | Должна быть возможность генерации пакета банарного пакета                       | 1 | | 
  
-=== Варианты использования (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: в работе+  * Генерация каталога DEBIAN (File->New->DEBIAN) ((заполнение файла control, rules для source-пакетов, генерация файла changelog)) 
 +  * Редактор файла controlпо аналогии с редактором для plugin.xml. Должен предоставлять возможность заполнения стандартных полей control-файла и добавление специальных полей для пакетов slind 
 +  * Дейсвия редактировани файла changelog: new item, new version, новая подверсия (non-maintainer) 
 +  * Экспорт пакета (File->Export->.deb package)
  
-== Пакеты с исходниками: сборка и установка == 
  
-FIXME: в работе+==== Сценарии ==== 
 +  * Предусловиестандартный 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.1194718534.txt.gz · Last modified: 2008/01/03 02:32 (external edit)