(Created page with "{{admon/warning|This is a DRAFT.}} = DAP Packaging guidelines = DevAssistant provides an easy extendability through Assistants. These assistants are normally distributed via...") |
mNo edit summary |
||
(4 intermediate revisions by 2 users not shown) | |||
Line 13: | Line 13: | ||
== Naming guidelines == | == Naming guidelines == | ||
* Every (RPM) package name must start with <code>dap-</code>, which is followed by the name of the Assistant itself, all lowercase. For example, the DAP named <code>Openscad</code> will be named <code>dap-openscad</code> in the SPEC file. | * Every (RPM) package name must start with <code>devassistant-dap-</code>, which is followed by the name of the Assistant itself, all lowercase. For example, the DAP named <code>Openscad</code> will be named <code>devassistant-dap-openscad</code> in the SPEC file. In this document, the second part of the name (i. e. the substring <code>openscad</code>) will be referenced as <code>%{shortname}</code>. | ||
* There is no difference between packages that provide Assistants, and those that provide only auxiliary files, snippets, metapackages etc. | * There is no difference between packages that provide Assistants, and those that provide only auxiliary files, snippets, metapackages etc. | ||
== Dependencies == | == Dependencies == | ||
* All packages must Require <code>devassistant-ui</code>. This means that the user has at least one user interface for DevAssistant installed, so they can use the DAP without futher installing anything. | * All packages must Require <code>devassistant-ui</code>. This means that the user has at least one user interface for DevAssistant installed, so they can use the DAP without futher installing anything. No version specification is necessary as DevAssistant 0.10.1 is the first version ever to provide <code>devassistant-ui</code>. | ||
* | * <code>Requires: devassistant</code> is not allowed, as that would install more packages for DA than the user may intend or need. | ||
* All packages must | * All packages must have <code>BuildRequires: devassistant-devel</code>. (for macros, installation and checking) | ||
* Each package must Require packages that are specified in the file <code>/meta.yaml</code> in the section <code>dependencies</code>. These names, of course, must contain the <code>dap-</code> prefix. These Requires are generated automatically by dap2rpm. | * Each package must Require packages that are specified in the file <code>/meta.yaml</code> in the section <code>dependencies</code>. These names, of course, must contain the <code>devassistant-dap-</code> prefix. These Requires are generated automatically by dap2rpm. | ||
== Architecture == | == Architecture == | ||
Line 30: | Line 30: | ||
* The macro denoting the parent directory where the package files go is <code>%{assistant_path}</code>. This currently expands to <code>/usr/share/devassistant</code>. | * The macro denoting the parent directory where the package files go is <code>%{assistant_path}</code>. This currently expands to <code>/usr/share/devassistant</code>. | ||
* The macro definitions of <code>%install_assistant</code>, <code>%repack_assistant</code>, and <code>%check_assistant</code> are provided by the package <code>devassistant-devel</code>. | |||
== Prep section == | == Prep section == | ||
Line 42: | Line 43: | ||
== Install section == | == Install section == | ||
* | * Files are installed via the <code>%install_assistant</code> macro | ||
* Using the above macro automatically creates a list of files stored in the file <code>dap-list</code>, which can then be used in the <code>%files</code> section. | |||
* If the package contains licensing files, they should be marked as such by running the <code>%install_assistant</code> macro with argument(s) <code>-L LICENSE_FILE1 LICENSE_FILE2...</code>. The licensing files must be stored only in the <code>doc</code> directory of the DAP. | |||
* If installed manually, the package files are installed into <code>%{buildroot}%{assistant_path}</code> in subdirectories conforming to the DAP layout, i. e. the <code>assistants/crt/foo</code> directory is installed into <code>%{buildroot}%{assistant_path}/assistants/crt/foo</code>. | * If installed manually, the package files are installed into <code>%{buildroot}%{assistant_path}</code> in subdirectories conforming to the DAP layout, i. e. the <code>assistants/crt/foo</code> directory is installed into <code>%{buildroot}%{assistant_path}/assistants/crt/foo</code>. | ||
Line 48: | Line 51: | ||
* You must run the <code>%check_assistant</code> macro in the <code>%check</code> section, and it must pass. | * You must run the <code>%check_assistant</code> macro in the <code>%check</code> section, and it must pass. | ||
* If run manually, you must run the command <code>da pkg lint -w %{shortname}-%{version}.dap</code> (or similar, if your package's name differs). The | * If run manually, you must run the command <code>da pkg lint -w %{shortname}-%{version}.dap</code> (or similar, if your package's name differs). The run must produce no errors. Warnings are permissible. | ||
== Files section == | == Files section == | ||
* Package's files and directories are installed into <code>%{assistant_path}</code>. | * If the macro <code>%install_assistant</code> was used in the <code>%install</code> section, it is sufficient to provide the list of files to the <code>%files</code> section like this: <code>%files -f dap-files</code>. This is the default situation when using dap2rpm. | ||
* Do not install everything like <code>%{assistant_path}/*</code>, list each folder separately | * If done manually: | ||
* The <code>doc</code> directory in the DAP should be installed via the <code>%doc</code> macro, in the same <code>%{assistant_path}</code> directory. | ** Package's files and directories are installed into <code>%{assistant_path}</code>. | ||
* The <code>meta.yaml</code> file must be installed as <code>%{assistant_path}/meta/%{shortname}.yaml</code>. | ** Do not install everything like <code>%{assistant_path}/*</code>, list each folder separately. That includes subdirectories in <code>%{assistant_path}/assistants</code>, as shown in these examples: | ||
*** Bad: <code>%{assistant_path}/assistants/*</code> | |||
*** Good: <code>%{assistant_path}/assistants/crt/%{shortname}</code> | |||
** The <code>doc</code> directory in the DAP should be installed via the <code>%doc</code> macro, in the same <code>%{assistant_path}</code> directory. | |||
** The <code>meta.yaml</code> file must be installed as <code>%{assistant_path}/meta/%{shortname}.yaml</code>. | |||
== Directory ownership == | |||
* The package <code>devassistant-core</code> owns the directory <code>%{assistant_path}</code> itself and the following subdirectories: | |||
*# <code>%{assistant_path}/{assistants,doc,files,icons,meta,snippets}</code> | |||
*# <code>%{assistant_path}/{assistants}/{crt,twk,prep,extra}</code> | |||
*# <code>%{assistant_path}/files/{crt,twk,prep,extra,snippets}</code> | |||
*# <code>%{assistant_path}/icons/{crt,twk,prep,extra}</code> | |||
* The RPM-packaged DAP must own the following files/directories if and only if they are present in the upstream DAP: | |||
** directories named <code>%{shortname}</code> in directories listed in point 2 and 3 of the previous bullet. | |||
*** Example 1: <code>%{assistant_path}/assistant/crt/%{shortname}</code> | |||
*** Example 2: <code>%{assistant_path}/files/snippets/%{shortname}</code> | |||
** files named <code>%{shortname}.yaml</code> in the directories listed in point 2. | |||
** a directory named <code>%{shortname}</code> in the directory <code>%{assistant_path}/doc/</code> | |||
** a file named <code>%{shortname}.yaml</code> in the directory <code>%{assistant_path}/meta/</code> | |||
** a file named <code>%{shortname}.$SUFFIX</code>, where <code>$SUFFIX</code> is an image file suffix (preferably PNG or SVG), in the directories listed in point 4. | |||
== Sample SPEC == | == Sample SPEC == | ||
Line 61: | Line 84: | ||
<pre>%global shortname openscad | <pre>%global shortname openscad | ||
Name: dap-%{shortname} | Name: devassistant-dap-%{shortname} | ||
Version: 0.0.2 | Version: 0.0.2 | ||
Release: 1%{?dist} | Release: 1%{?dist} | ||
Line 74: | Line 97: | ||
BuildRequires: devassistant-devel | BuildRequires: devassistant-devel | ||
Requires: devassistant-ui | Requires: devassistant-ui | ||
Requires: dap-common_args | Requires: devassistant-dap-common_args | ||
Requires: dap-git | Requires: devassistant-dap-git | ||
Requires: dap-github | Requires: devassistant-dap-github | ||
%description | %description | ||
Line 94: | Line 117: | ||
%install | %install | ||
%install_assistant | %install_assistant -L LICENSE NOTICE | ||
%check | %check | ||
%check_assistant | %check_assistant | ||
%files | %files -f dap-files | ||
%doc %{assistant_path}/doc/%{shortname} | |||
%changelog | |||
* Thu Dec 11 2014 Tomas Radej <tradej@redhat.com> - 0.0.2-1 | |||
- Initial package</pre> | |||
== Sample %files section when specified manually == | |||
<pre>%files | |||
%license %{assistant_path}/doc/LICENSE | |||
%license %{assistant_path}/doc/NOTICE | |||
%dir %{assistant_path}/doc/%{shortname} | |||
%doc %{assistant_path}/doc/%{shortname}/README.rst | |||
%{assistant_path}/assistants/crt/%{shortname}* | %{assistant_path}/assistants/crt/%{shortname}* | ||
%{assistant_path}/files/crt/%{shortname}* | %{assistant_path}/files/crt/%{shortname}* | ||
%{assistant_path}/icons/crt/%{shortname}* | %{assistant_path}/icons/crt/%{shortname}* | ||
%{assistant_path}/meta/%{shortname}.yaml | %{assistant_path}/meta/%{shortname}.yaml</pre> | ||
Latest revision as of 14:02, 12 March 2015
DAP Packaging guidelines
DevAssistant provides an easy extendability through Assistants. These assistants are normally distributed via the DevAssistant Package Index in the form of DAP (DevAssistant Package) files. If you want to include a DAP into the main Fedora repositories, you can do so. This document outlines the rules involved.
Note: Packaged DAPs only work with DevAssistant 0.10.0 and newer. They can not be used with DevAssistant versions 0.9.* packaged in Fedora 21 and earlier.
How to package a DAP
We recommend you use the tool dap2rpm, which creates a SPEC file from your DAP automatically. It is packaged in Fedora Rawhide and 21's repositories as dap2rpm.
Naming guidelines
- Every (RPM) package name must start with
devassistant-dap-
, which is followed by the name of the Assistant itself, all lowercase. For example, the DAP namedOpenscad
will be nameddevassistant-dap-openscad
in the SPEC file. In this document, the second part of the name (i. e. the substringopenscad
) will be referenced as%{shortname}
. - There is no difference between packages that provide Assistants, and those that provide only auxiliary files, snippets, metapackages etc.
Dependencies
- All packages must Require
devassistant-ui
. This means that the user has at least one user interface for DevAssistant installed, so they can use the DAP without futher installing anything. No version specification is necessary as DevAssistant 0.10.1 is the first version ever to providedevassistant-ui
. Requires: devassistant
is not allowed, as that would install more packages for DA than the user may intend or need.- All packages must have
BuildRequires: devassistant-devel
. (for macros, installation and checking) - Each package must Require packages that are specified in the file
/meta.yaml
in the sectiondependencies
. These names, of course, must contain thedevassistant-dap-
prefix. These Requires are generated automatically by dap2rpm.
Architecture
- All daps must be architecture independent, i. e.
BuildArch: noarch
.
Macros
- The macro denoting the parent directory where the package files go is
%{assistant_path}
. This currently expands to/usr/share/devassistant
. - The macro definitions of
%install_assistant
,%repack_assistant
, and%check_assistant
are provided by the packagedevassistant-devel
.
Prep section
- DAP must be unpacked with
setup
like other packages, it is not permissible to install the source DAP directly. - If needed, you may patch the source files in this section.
Build section
- You must re-pack the (optionally patched) DAP in the
%build
section using the macro%repack_assistant
. This is needed for installing and checking.
Install section
- Files are installed via the
%install_assistant
macro - Using the above macro automatically creates a list of files stored in the file
dap-list
, which can then be used in the%files
section. - If the package contains licensing files, they should be marked as such by running the
%install_assistant
macro with argument(s)-L LICENSE_FILE1 LICENSE_FILE2...
. The licensing files must be stored only in thedoc
directory of the DAP. - If installed manually, the package files are installed into
%{buildroot}%{assistant_path}
in subdirectories conforming to the DAP layout, i. e. theassistants/crt/foo
directory is installed into%{buildroot}%{assistant_path}/assistants/crt/foo
.
Check section
- You must run the
%check_assistant
macro in the%check
section, and it must pass. - If run manually, you must run the command
da pkg lint -w %{shortname}-%{version}.dap
(or similar, if your package's name differs). The run must produce no errors. Warnings are permissible.
Files section
- If the macro
%install_assistant
was used in the%install
section, it is sufficient to provide the list of files to the%files
section like this:%files -f dap-files
. This is the default situation when using dap2rpm. - If done manually:
- Package's files and directories are installed into
%{assistant_path}
. - Do not install everything like
%{assistant_path}/*
, list each folder separately. That includes subdirectories in%{assistant_path}/assistants
, as shown in these examples:- Bad:
%{assistant_path}/assistants/*
- Good:
%{assistant_path}/assistants/crt/%{shortname}
- Bad:
- The
doc
directory in the DAP should be installed via the%doc
macro, in the same%{assistant_path}
directory. - The
meta.yaml
file must be installed as%{assistant_path}/meta/%{shortname}.yaml
.
- Package's files and directories are installed into
Directory ownership
- The package
devassistant-core
owns the directory%{assistant_path}
itself and the following subdirectories:%{assistant_path}/{assistants,doc,files,icons,meta,snippets}
%{assistant_path}/{assistants}/{crt,twk,prep,extra}
%{assistant_path}/files/{crt,twk,prep,extra,snippets}
%{assistant_path}/icons/{crt,twk,prep,extra}
- The RPM-packaged DAP must own the following files/directories if and only if they are present in the upstream DAP:
- directories named
%{shortname}
in directories listed in point 2 and 3 of the previous bullet.- Example 1:
%{assistant_path}/assistant/crt/%{shortname}
- Example 2:
%{assistant_path}/files/snippets/%{shortname}
- Example 1:
- files named
%{shortname}.yaml
in the directories listed in point 2. - a directory named
%{shortname}
in the directory%{assistant_path}/doc/
- a file named
%{shortname}.yaml
in the directory%{assistant_path}/meta/
- a file named
%{shortname}.$SUFFIX
, where$SUFFIX
is an image file suffix (preferably PNG or SVG), in the directories listed in point 4.
- directories named
Sample SPEC
%global shortname openscad Name: devassistant-dap-%{shortname} Version: 0.0.2 Release: 1%{?dist} Summary: Create 3D printing projects for OpenSCAD BuildArch: noarch License: GPLv3+ and GPLv2 with exceptions URL: https://github.com/3DprintFIT/dap-openscad Source0: https://dapi.devassistant.org/download/%{shortname}-%{version}.dap BuildRequires: devassistant-devel Requires: devassistant-ui Requires: devassistant-dap-common_args Requires: devassistant-dap-git Requires: devassistant-dap-github %description This assistants helps you to create new OpenSCAD project for 3D printing. We use it in our 3D printing lab to store our 3D printers on Github. Projects created with this assistant have a `Makefile` to build the 3D models form OpenSCAD sources. To do so, run `make`. You can also generate the images by `make images` or print plates with `make arrange`. Observe the generated `Makefile` to see all available options. %prep %setup -q -n %{shortname}-%{version} %build %repack_assistant %install %install_assistant -L LICENSE NOTICE %check %check_assistant %files -f dap-files %changelog * Thu Dec 11 2014 Tomas Radej <tradej@redhat.com> - 0.0.2-1 - Initial package
Sample %files section when specified manually
%files %license %{assistant_path}/doc/LICENSE %license %{assistant_path}/doc/NOTICE %dir %{assistant_path}/doc/%{shortname} %doc %{assistant_path}/doc/%{shortname}/README.rst %{assistant_path}/assistants/crt/%{shortname}* %{assistant_path}/files/crt/%{shortname}* %{assistant_path}/icons/crt/%{shortname}* %{assistant_path}/meta/%{shortname}.yaml