1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260
|
// vim:set filetype=asciidoc:
[[start]]
== Prerequisites
Here are the prerequisites you need to understand before getting involved with Debian.
[[people]]
=== People around Debian
There are several types of people interacting around Debian with different roles:
* *upstream author*: the person who made the original program.
* *upstream maintainer*: the person who currently maintains the program.
* *maintainer*: the person making the Debian package of the program.
* *sponsor*: a person who helps maintainers to upload packages to the official Debian package archive (after checking their contents).
* *mentor*: a person who helps novice maintainers with packaging etc.
* *Debian Developer* (DD): a member of the Debian project with full upload rights to the official Debian package archive.
* *Debian Maintainer* (DM): a person with limited upload rights to the official Debian package archive.
Please note that you can't become an official *Debian Developer* (DD) overnight, as it requires more than just technical skills. Don't be discouraged by this. If your work is useful to others, you can still upload your package either as a *maintainer* through a *sponsor* or as a *Debian Maintainer*.
Please note that you don't need to create new packages to become an official Debian Developer. Contributing to existing packages can also provide a path to becoming an official Debian Developer. There are many packages waiting for good maintainers (see "`"`<<approaches>>`"`").
[[contribute]]
=== How to contribute
Please refer to the following to learn how to contribute to Debian:
* "`https://www.debian.org/intro/help[How can you help Debian?]`" (official)
* "`https://www.debian.org/doc/manuals/debian-faq/contributing[The Debian GNU/Linux FAQ, Chapter 13 - Contributing to the Debian Project]`" (semi-official)
* "`https://wiki.debian.org/HelpDebian[Debian Wiki, HelpDebian]`" (supplemental)
* "`https://nm.debian.org/[Debian New Member site]`" (official)
* "`https://wiki.debian.org/DebianMentorsFaq[Debian Mentors FAQ]`" (supplemental)
[[social]]
=== Social dynamics of Debian
Please understand Debian's social dynamics to prepare yourself for interactions with Debian:
* We are all volunteers.
** You can't impose tasks on others.
** You should be self-motivated to do things.
* Friendly cooperation is the driving force.
** Your contribution should not over-strain others.
** Your contribution is valuable only when others appreciate it.
* Debian is not a school where you get automatic attention from teachers.
** You should be able to learn many things independently.
** Attention from other volunteers is a scarce resource.
* Debian is constantly improving.
** You are expected to make high quality packages.
** You should adapt yourself to change.
Since we focus only on the technical aspects of the packaging in the rest of this guide, please refer to the following to understand the social dynamics of Debian:
* "`http://upsilon.cc/~zack/talks/2011/20110321-taipei.pdf[Debian: 17 years of Free Software, "do-ocracy", and democracy]`" (Introductory slides by the ex-DPL)
[[reminders]]
=== Technical reminders
Here are some technical reminders to help other maintainers work on your package easily and effectively, maximizing the output of Debian as a whole.
* Make your package easy to debug.
** Keep your package simple.
** Don't over-engineer your package.
* Keep your package well-documented.
** Use readable code style.
** Make comments in code.
** Format code consistently.
** Maintain the git repository footnote:[The overwhelming number of Debian maintainers use *git* over other VCS systems such as *hg*, *bzr*, etc.] of the package.
NOTE: Debugging of software tends to consume more time than writing the initial working software.
It is unwise to run your base system under the *unstable* suite, even for development purposes.
* Creation and verification of binary *deb* packages should use a minimal *unstable* chroot as described in "`<<sbuild-setup>>`".
* Basic interactive package development activities should use an *unstable* chroot as described in "`<<chroot-persistent>>`".
NOTE: Advanced package development activities, such as testing full Desktop systems, network daemons, and system installer packages, should use the *unstable* suite running under "`https://www.debian.org/doc/manuals/debian-reference/ch09.en.html#_multiple_desktop_systems[virtualization]`".
[[debian-doc]]
=== Debian documentation
Please make yourself ready to read the pertinent part of the latest Debian documentation to generate perfect Debian packages:
* "`Debian Policy Manual`"
** The official "`must follow`" rules (https://www.debian.org/doc/devel-manuals#policy)
* "`Debian Developer's Reference`"
** The official "`best practice`" document (https://www.debian.org/doc/devel-manuals#devref)
* "`Guide for Debian Maintainers`" -- this guide
** A "`tutorial reference`" document (https://www.debian.org/doc/devel-manuals#debmake-doc)
All these documents are published on https://www.debian.org using the *unstable* suite versions of corresponding Debian packages.
If you wish to have local access to all these documents from your base system, please consider using techniques such as "`https://www.debian.org/doc/manuals/debian-reference/ch02.en.html#_tweaking_candidate_version[apt-pinning]`" and "`https://en.wikipedia.org/wiki/Chroot[chroot]`".
If this guide contradicts the official Debian documentation, the official Debian documentation is correct. Please file a bug report on the *debmake-doc* package using the *reportbug* command.
Here are alternative tutorial documents, which you may read along with this guide:
* "`Debian Packaging Tutorial`"
** https://www.debian.org/doc/devel-manuals#packaging-tutorial
** https://packages.qa.debian.org/p/packaging-tutorial.html
* "`Ubuntu Packaging Guide`" (Ubuntu is Debian based.)
** http://packaging.ubuntu.com/html/
* "`Debian New Maintainers' Guide`" (predecessor of this tutorial, deprecated)
** https://www.debian.org/doc/devel-manuals#maint-guide
** https://packages.qa.debian.org/m/maint-guide.html
TIP: When reading these, you may consider using the *debmake* command in place of the *dh_make* command.
[[help]]
=== Help resources
Before deciding to ask your question in a public forum, please do your part by reading the relevant documentation:
* package information available through the *aptitude*, *apt-cache*, and *dpkg* commands.
* files in **/usr/share/doc/**__package__ for all pertinent packages.
* contents of *man* __command__ for all pertinent commands.
* contents of *info* __command__ for all pertinent commands.
* contents of "`https://lists.debian.org/debian-mentors/[debian-mentors@lists.debian.org mailing list archive]`".
* contents of "`https://lists.debian.org/debian-devel/[debian-devel@lists.debian.org mailing list archive]`".
You can find your desired information effectively by using a well-formed search string such as "keyword site:lists.debian.org" to limit the search domain of the web search engine.
Creating a small test package is a good way to learn the details of packaging. Inspecting existing well-maintained packages is the best way to learn how other people make packages.
If you still have questions about the packaging, you can ask them interactively:
* debian-mentors@lists.debian.org mailing list. (This mailing list is for the novice.)
* debian-devel@lists.debian.org mailing list. (This mailing list is for the expert.)
* https://www.debian.org/support#irc[IRC] such as #debian-mentors.
* Teams focusing on a specific set of packages. (Full list at https://wiki.debian.org/Teams)
* Language-specific mailing lists.
** "`https://lists.debian.org/devel.html[debian-devel-{french,italian,portuguese,spanish}@lists.debian.org]`"
** "`https://lists.debian.org/debian-chinese-gb/[debian-chinese-gb@lists.debian.org]`" (This mailing list is for general (Simplified) Chinese discussion.)
** "`http://www.debian.or.jp/community/ml/openml.html#develML[debian-devel@debian.or.jp]`"
More experienced Debian developers will gladly help you if you ask properly after making the required efforts.
CAUTION: Debian development is a moving target. Some information found on the web may be outdated, incorrect, or non-applicable. Please use such information carefully.
[[situation]]
=== Archive situation
Please realize the situation of the Debian archive.
* Debian already has packages for most kinds of programs.
* The number of packages already in the Debian archive is several tens of times greater than that of active maintainers.
* Unfortunately, some packages lack an appropriate level of attention by the maintainer.
Thus, contributions to packages already in the archive are far more appreciated (and more likely to receive sponsorship for uploading) by other maintainers.
TIP: The *wnpp-alert* command from the *devscripts* package can check for installed packages that are up for adoption or orphaned.
TIP: The *how-can-i-help* package can show opportunities for contributing to Debian based on packages installed locally.
[[approaches]]
=== Contribution approaches
Here is pseudo-Python code for your contribution approaches to Debian with a *program*:
----
if exist_in_debian(program):
if is_team_maintained(program):
join_team(program)
if is_orphaned(program): # maintainer: Debian QA Group
adopt_it(program)
elif is_RFA(program): # Request for Adoption
adopt_it(program)
else:
if need_help(program):
contact_maintainer(program)
triaging_bugs(program)
preparing_QA_or_NMU_uploads(program)
else:
leave_it(program)
else: # new packages
if not is_good_program(program):
give_up_packaging(program)
elif not is_distributable(program):
give_up_packaging(program)
else: # worth packaging
if is_ITPed_by_others(program):
if need_help(program):
contact_ITPer_for_collaboration(program)
else:
leave_it_to_ITPer(program)
else: # really new
if is_applicable_team(program):
join_team(program)
if is_DFSG(program) and is_DFSG(dependency(program)):
file_ITP(program, area="main") # This is Debian
elif is_DFSG(program):
file_ITP(program, area="contrib") # This is not Debian
else: # non-DFSG
file_ITP(program, area="non-free") # This is not Debian
package_it_and_close_ITP(program)
----
Here:
* For exist_in_debian(), and is_team_maintained(); check:
** the *aptitude* command
** "`https://www.debian.org/distrib/packages[Debian packages]`" web page
** Debian wiki "`https://wiki.debian.org/Teams[Teams]`" page
* For is_orphaned(), is_RFA(), and is_ITPed_by_others(); check:
** The output of the *wnpp-alert* command.
** "`https://www.debian.org/devel/wnpp/[Work-Needing and Prospective Packages]`"
** "`https://bugs.debian.org/cgi-bin/pkgreport.cgi?pkg=wnpp;dist=unstable[Debian Bug report logs: Bugs in pseudo-package wnpp in unstable]`"
** "`https://wnpp.debian.net/[Debian Packages that Need Lovin']`"
** "`https://wnpp-by-tags.debian.net/[Browse wnpp bugs based on debtags]`"
* For is_good_program(), check:
** The program should be useful.
** The program should not introduce security and maintenance concerns to the Debian system.
** The program should be well documented and its code needs to be understandable (i.e. not obfuscated).
** The program's authors agree with the packaging and are amicable to Debian. footnote:[This is not the absolute requirement. The hostile upstream may become a major resource drain for us all. The friendly upstream can be consulted to solve any problems with the program.]
* For is_it_DFSG(), and is_its_dependency_DFSG(); check:
** "`https://www.debian.org/social_contract#guidelines[Debian Free Software Guidelines]`" (DFSG).
* For is_it_distributable(), check:
** The software must have a license and it should allow its distribution.
You either need to file an *ITP* or adopt a package to start working on it. See the "`Debian Developer's Reference`":
* "`https://www.debian.org/doc/manuals/developers-reference/pkgs.html#newpackage[5.1. New packages]`".
* "`https://www.debian.org/doc/manuals/developers-reference/pkgs.html#archive-manip[5.9. Moving, removing, renaming, orphaning, adopting, and reintroducing packages]`".
[[novice]]
=== Novice contributor and maintainer
The novice contributor and maintainer may wonder what to learn to start your contribution to Debian. Here are my suggestions depending on your focus:
* Packaging
** Basics of the *POSIX shell* and *make*.
** Some rudimentary knowledge of *Perl* and *Python*.
* Translation
** Basics of how the PO based translation system works.
* Documentation
** Basics of text markups (XML, ReST, Wiki, ...).
The novice contributor and maintainer may wonder where to start your contribution to Debian. Here are my suggestions depending on your skills:
* *POSIX shell*, *Perl*, and *Python* skills:
** Send patches to the Debian Installer.
** Send patches to the Debian packaging helper scripts such as *devscripts*, *sbuild*, *schroot*, etc. mentioned in this document.
* *C* and *C++* skills:
** Send patches to the packages with the *required* and *important* priorities.
* Non-English skills:
** Send patches to the PO file of the Debian Installer.
** Send patches to the PO file of the packages with the *required* and *important* priorities.
* Documentation skills:
** Update contents on "`https://wiki.debian.org/[Debian Wiki]`".
** Send patches to the existing "`https://www.debian.org/doc/[Debian Documentation]`".
These activities should give you good exposure to the other Debian people to establish your credibility.
The novice maintainer should avoid packaging programs with the high security exposure:
* *setuid* or *setgid* program
* *daemon* program
* program installed in the */sbin/* or */usr/sbin/* directories
When you gain more experience in packaging, you'll be able to package such programs.
|