po: Update German man pages translation
[dpkg.git] / man / dpkg-source.pod
blob736f42fd2be63cc95365ab2d6f7fef3397b96f79
1 # dpkg manual page - dpkg-source(1)
3 # Copyright © 1995-1996 Ian Jackson <ijackson@chiark.greenend.org.uk>
4 # Copyright © 2000 Wichert Akkerman <wakkerma@debian.org>
5 # Copyright © 2006-2007 Frank Lichtenheld <djpig@debian.org>
6 # Copyright © 2006-2015 Guillem Jover <guillem@debian.org>
7 # Copyright © 2008-2011 Raphaël Hertzog <hertzog@debian.org>
8 # Copyright © 2010 Joey Hess <joeyh@debian.org>
10 # This is free software; you can redistribute it and/or modify
11 # it under the terms of the GNU General Public License as published by
12 # the Free Software Foundation; either version 2 of the License, or
13 # (at your option) any later version.
15 # This is distributed in the hope that it will be useful,
16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18 # GNU General Public License for more details.
20 # You should have received a copy of the GNU General Public License
21 # along with this program.  If not, see <https://www.gnu.org/licenses/>.
23 =encoding utf8
25 =head1 NAME
27 dpkg-source - Debian source package (.dsc) manipulation tool
29 =head1 SYNOPSIS
31 B<dpkg-source>
32 [I<option>...] I<command>
34 =head1 DESCRIPTION
36 B<dpkg-source>
37 packs and unpacks Debian source archives.
39 None of these commands allow multiple options to be combined into one,
40 and they do not allow the value for an option to be specified in a
41 separate argument.
43 =head1 COMMANDS
45 =over
47 =item B<-x>, B<--extract> I<filename>.dsc [I<output-directory>]
49 Extract a source package (B<--extract> since dpkg 1.17.14).
50 One non-option argument must be supplied,
51 the name of the Debian source control file
52 (B<.dsc>).
53 An optional second non-option argument may be supplied to specify the
54 directory to extract the source package to, this must not exist.
56 no output directory is specified, the source package is extracted into
57 a directory named I<source>-I<version> under the current working
58 directory.
60 B<dpkg-source>
61 will read the names of the other file(s) making up the source package
62 from the control file; they are assumed to be in the same directory as
63 the
64 B<.dsc>.
66 The files in the extracted package will have their permissions and
67 ownerships set to those which would have been expected if the files
68 and directories had simply been created - directories and executable
69 files will be 0777 and plain files will be 0666, both modified by the
70 extractors' umask; if the parent directory is setgid then the
71 extracted directories will be too, and all the files and directories
72 will inherit its group ownership.
74 If the source package uses a non-standard format (currently this means all
75 formats except “1.0”), its name will be stored in
76 B<debian/source/format> so that the following builds of the source
77 package use the same format by default.
79 =item B<-b>, B<--build> I<directory> [I<format-specific-parameters>]
81 Build a source package (B<--build> since dpkg 1.17.14).
82 The first non-option argument is taken as the
83 name of the directory containing the debianized source tree (i.e. with a
84 debian sub-directory and maybe changes to the original files).
85 Depending on the source package format used to build the package,
86 additional parameters might be accepted.
88 B<dpkg-source> will build the source package with the first format
89 found in this ordered list:
90 the format indicated with the I<--format> command line option,
91 the format indicated in B<debian/source/format>,
92 “1.0”.
93 The fallback to “1.0” is deprecated and will be removed at some
94 point in the future, you should always document the desired source format
95 in B<debian/source/format>.
96 See section L</SOURCE PACKAGE FORMATS>
97 for an extensive description of the various source package formats.
99 =item B<--print-format> I<directory>
101 Print the source format that would be used to build the source package if
102 B<dpkg-source --build> I<directory> was called (in the same conditions
103 and with the same parameters; since dpkg 1.15.5).
105 =item B<--before-build> I<directory>
107 Run the corresponding hook of the source package format (since dpkg 1.15.8).
108 This hook is
109 called before any build of the package (B<dpkg-buildpackage> calls it
110 very early even before B<debian/rules clean>).
111 This command is idempotent and can be called multiple times.
112 Not all source formats
113 implement something in this hook, and those that do usually prepare the
114 source tree for the build for example by ensuring that the Debian patches
115 are applied.
117 =item B<--after-build> I<directory>
119 Run the corresponding hook of the source package format (since dpkg 1.15.8).
120 This hook is
121 called after any build of the package (B<dpkg-buildpackage> calls it
122 last).
123 This command is idempotent and can be called multiple times.
125 all source formats implement something in this hook, and those that do
126 usually use it to undo what B<--before-build> has done.
128 =item B<--commit> [I<directory>] ...
130 Record changes in the source tree unpacked in I<directory>
131 (since dpkg 1.16.1).
132 This command can take supplementary parameters depending on the source format.
133 It will error out for formats where this operation doesn't mean anything.
135 =item B<-?>, B<--help>
137 Show the usage message and exit.
138 The format specific build and extract options can be shown by using the
139 B<--format> option.
141 =item B<--version>
143 Show the version and exit.
145 =back
147 =head1 OPTIONS
149 =head2 Generic build options
151 =over
153 =item B<-c>I<control-file>
155 Specifies the main source control file to read information from.
157 default is
158 B<debian/control>.
159 If given with relative pathname this is interpreted starting at
160 the source tree's top level directory.
162 =item B<-l>I<changelog-file>
164 Specifies the changelog file to read information from.
166 default is
167 B<debian/changelog>.
168 If given with relative pathname this is interpreted starting at
169 the source tree's top level directory.
171 =item B<-F>I<changelog-format>
173 Specifies the format of the changelog.
174 See L<dpkg-parsechangelog(1)>
175 for information about alternative formats.
177 =item B<--format=>I<value>
179 Use the given format for building the source package (since dpkg 1.14.17).
180 It does override any format given in B<debian/source/format>.
182 =item B<-V>I<name>B<=>I<value>
184 Set an output substitution variable.
185 See L<deb-substvars(5)> for a discussion of output substitution.
187 =item B<-T>I<substvars-file>
189 Read substitution variables in
190 I<substvars-file>;
191 the default is to not read any file.
192 This option can be used multiple
193 times to read substitution variables from multiple files (since dpkg 1.15.6).
195 =item B<-D>I<field>B<=>I<value>
197 Override or add an output control file field.
199 =item B<-U>I<field>
201 Remove an output control file field.
203 =item B<-Z>I<compression>, B<--compression>=I<compression>
205 Specify the compression to use for created tarballs and diff files
206 (B<--compression> since dpkg 1.15.5).
207 Note that this option will not cause existing tarballs to be recompressed,
208 it only affects new files.
209 Supported values are:
210 I<gzip>, I<bzip2>, I<lzma> and I<xz>.
211 The default is I<xz> for formats 2.0 and newer, and I<gzip> for
212 format 1.0.
213 I<xz> is only supported since dpkg 1.15.5.
215 =item B<-z>I<level>, B<--compression-level>=I<level>
217 Compression level to use (B<--compression-level> since dpkg 1.15.5).
218 As with B<-Z> it only affects newly created
219 files.
220 Supported values are:
221 I<1> to I<9>, I<best>, and I<fast>.
222 The default is I<9> for gzip and bzip2, I<6> for xz and lzma.
224 =item B<-i>[I<regex>], B<--diff-ignore>[=I<regex>]
226 You may specify a perl regular expression to match files you want
227 filtered out of the list of files for the diff (B<--diff-ignore>
228 since dpkg 1.15.6).
229 (This list is
230 generated by a find command.) (If the source package is being built as a
231 version 3 source package using a VCS, this can be used to ignore
232 uncommitted changes on specific files.
233 Using -i.* will ignore all of them.)
235 The B<-i> option by itself enables this setting with a default regex
236 (preserving any modification to the default regex done by a previous use
237 of B<--extend-diff-ignore>) that will filter out control files and
238 directories of the most common revision control systems, backup and swap
239 files and Libtool build output directories.
240 There can only be one active
241 regex, of multiple B<-i> options only the last one will take effect.
243 This is very helpful in cutting out extraneous files that get included
244 in the diff, for example if you maintain your source in a revision control
245 system and want to use a checkout to build a source package without
246 including the additional files and directories that it will usually
247 contain (e.g. CVS/, .cvsignore, .svn/).
248 The default regex is already
249 very exhaustive, but if you need to replace it, please note that by
250 default it can match any part of a path, so if you want to match the
251 begin of a filename or only full filenames, you will need to provide
252 the necessary anchors (e.g. ‘(^|/)’, ‘($|/)’) yourself.
254 =item B<--extend-diff-ignore>=I<regex>
256 The perl regular expression specified will extend the default value used by
257 B<--diff-ignore> and its current value, if set (since dpkg 1.15.6).
258 It does this by concatenating “B<|>I<regex>” to the existing value.
259 This option is convenient to use in B<debian/source/options> to exclude
260 some auto-generated files from the automatic patch generation.
262 =item B<-I>[I<file-pattern>], B<--tar-ignore>[=I<file-pattern>]
264 If this option is specified, the pattern will be passed to
265 L<tar(1)>'s
266 B<--exclude>
267 option when it is called to generate a .orig.tar or .tar file
268 (B<--tar-ignore> since dpkg 1.15.6).
270 example, B<-I>CVS will make tar skip over CVS directories when generating
271 a .tar.gz file.
272 The option may be repeated multiple times to list multiple
273 patterns to exclude.
275 B<-I> by itself adds default B<--exclude> options that will
276 filter out control files and directories of the most common revision
277 control systems, backup and swap files and Libtool build output
278 directories.
280 =back
282 B<Note>:
283 While they have similar purposes, B<-i> and B<-I> have very
284 different syntax and semantics.
285 B<-i> can only be specified once and
286 takes a perl compatible regular expression which is matched against
287 the full relative path of each file.
288 B<-I> can specified
289 multiple times and takes a filename pattern with shell wildcards.
290 The pattern is applied to the full relative path but also
291 to each part of the path individually.
292 The exact semantic of tar's
293 B<--exclude> option is somewhat complicated, see
294 L<https://www.gnu.org/software/tar/manual/tar.html#wildcards> for a full
295 documentation.
297 The default regex and patterns for both options can be seen
298 in the output of the B<--help> command.
300 =head2 Generic extract options
302 =over
304 =item B<--no-copy>
306 Do not copy original tarballs near the extracted source package
307 (since dpkg 1.14.17).
309 =item B<--no-check>
311 Do not check signatures and checksums before unpacking (since dpkg 1.14.17).
313 =item B<--no-overwrite-dir>
315 Do not overwrite the extraction directory if it already exists
316 (since dpkg 1.18.8).
318 =item B<--require-valid-signature>
320 Refuse to unpack the source package if it doesn't contain an OpenPGP
321 signature that can be verified (since dpkg 1.15.0) either with the user's
322 I<trustedkeys.gpg> keyring, one of the vendor-specific keyrings, or one
323 of the official Debian keyrings
324 (I</usr/share/keyrings/debian-keyring.gpg>,
325 I</usr/share/keyrings/debian-nonupload.gpg> and
326 I</usr/share/keyrings/debian-maintainers.gpg>).
328 =item B<--require-strong-checksums>
330 Refuse to unpack the source package if it does not contain any strong
331 checksums (since dpkg 1.18.7).
332 Currently the only known checksum considered strong is B<SHA-256>.
334 =item B<--ignore-bad-version>
336 Turns the bad source package version check into a non-fatal warning
337 (since dpkg 1.17.7).
338 This option should only be necessary when extracting ancient source
339 packages with broken versions, just for backwards compatibility.
341 =back
343 =head2 Generic general options
345 =over
347 =item B<--threads-max=>I<threads>
349 Sets the maximum number of threads allowed for compressors that support
350 multi-threaded operations (since dpkg 1.21.14).
352 =item B<-q>
354 Sets quiet mode to suppress warnings.
356 =back
358 =head1 SOURCE PACKAGE FORMATS
360 If you don't know what source format to use, you should probably pick
361 either “3.0 (quilt)” or “3.0 (native)”.
362 See L<https://wiki.debian.org/Projects/DebSrc3.0> for information on the
363 deployment of those formats within Debian.
365 =head2 Format: 1.0
367 A source package in this format consists either of a B<.orig.tar.gz>
368 associated to a B<.diff.gz> or a single B<.tar.gz> (in that case
369 the package is said to be I<native>).
370 Optionally the original tarball might be accompanied by a detached
371 upstream signature B<.orig.tar.gz.asc>, extraction
372 supported since dpkg 1.18.5.
374 B<Extracting>
376 Extracting a native package is a simple extraction of the single
377 tarball in the target directory.
378 Extracting a non-native package
379 is done by first unpacking the B<.orig.tar.gz> and then applying
380 the patch contained in the B<.diff.gz> file.
381 The timestamp of
382 all patched files is reset to the extraction time of the source
383 package (this avoids timestamp skews leading to problems when
384 autogenerated files are patched).
385 The diff can create new files (the whole
386 debian directory is created that way) but cannot remove files (empty files
387 will be left over) and cannot create or change symlinks.
389 B<Building>
391 Building a native package is just creating a single tarball with
392 the source directory.
393 Building a non-native package involves
394 extracting the original tarball in a separate “.orig” directory and
395 regenerating the B<.diff.gz> by comparing the source package
396 I<directory> with the .orig directory.
398 B<Build options (with --build):>
400 If a second non-option argument is supplied it should be the name of the
401 original source directory or tarfile or the empty string if the package is
402 a Debian-specific one and so has no debianization diffs.
403 If no second
404 argument is supplied then
405 B<dpkg-source>
406 will look for the original source tarfile
407 I<package>B<_>I<upstream-version>B<.orig.tar.gz>
408 or the original source directory
409 I<directory>B<.orig>
410 depending on the B<-sX> arguments.
412 B<-sa>, B<-sp>, B<-sk>, B<-su> and B<-sr>
413 will not overwrite existing tarfiles or directories.
414 If this is
415 desired then
416 B<-sA>, B<-sP>, B<-sK>, B<-sU> and B<-sR>
417 should be used instead.
419 =over
421 =item B<-sk>
423 Specifies to expect the original source as a tarfile, by default
424 I<package>B<_>I<upstream-version>B<.orig.tar.>I<extension>.
425 It will leave this original source in place as a tarfile, or copy it
426 to the current directory if it isn't already there.
428 tarball will be unpacked into
429 I<directory>B<.orig>
430 for the generation of the diff.
432 =item B<-sp>
434 Like
435 B<-sk>
436 but will remove the directory again afterwards.
438 =item B<-su>
440 Specifies that the original source is expected as a directory, by
441 default
442 I<package>B<->I<upstream-version>B<.orig>
444 B<dpkg-source>
445 will create a new original source archive from it.
447 =item B<-sr>
449 Like
450 B<-su>
451 but will remove that directory after it has been used.
453 =item B<-ss>
455 Specifies that the original source is available both as a directory
456 and as a tarfile.
457 B<dpkg-source> will use the directory to create
458 the diff, but the tarfile to create the
459 B<.dsc>.
460 This option must be used with care - if the directory and tarfile do
461 not match a bad source archive will be generated.
463 =item B<-sn>
465 Specifies to not look for any original source, and to not generate a diff.
466 The second argument, if supplied, must be the empty string.
467 This is
468 used for Debian-specific packages which do not have a separate
469 upstream source and therefore have no debianization diffs.
471 =item B<-sa> or B<-sA>
473 Specifies to look for the original source archive as a tarfile or as a
474 directory - the second argument, if any, may be either, or the empty
475 string (this is equivalent to using
476 B<-sn>).
477 If a tarfile is found it will unpack it to create the diff and remove
478 it afterwards (this is equivalent to
479 B<-sp>);
480 if a directory is found it will pack it to create the original source
481 and remove it afterwards (this is equivalent to
482 B<-sr>);
483 if neither is found it will assume that the package has no
484 debianization diffs, only a straightforward source archive (this is
485 equivalent to
486 B<-sn>).
487 If both are found then B<dpkg-source> will ignore the directory,
488 overwriting it, if
489 B<-sA>
490 was specified (this is equivalent to
491 B<-sP>)
492 or raise an error if
493 B<-sa>
494 was specified.
495 B<-sa>
496 is the default.
498 =item B<--abort-on-upstream-changes>
500 The process fails if the generated diff contains changes to files
501 outside of the debian sub-directory (since dpkg 1.15.8).
502 This option is not allowed in
503 B<debian/source/options> but can be used in
504 B<debian/source/local-options>.
506 =back
508 B<Extract options (with --extract):>
510 In all cases any existing original source tree will be removed.
512 =over
514 =item B<-sp>
516 Used when extracting then the original source (if any) will be left
517 as a tarfile.
518 If it is not already located in the current directory
519 or if an existing but different file is there it will be copied there.
520 (B<This is the default>).
522 =item B<-su>
524 Unpacks the original source tree.
526 =item B<-sn>
528 Ensures that the original source is neither copied to the current
529 directory nor unpacked.
530 Any original source tree that was in the
531 current directory is still removed.
533 =back
535 All the
536 B<-s>I<X>
537 options are mutually exclusive.
538 If you specify more than one only the
539 last one will be used.
541 =over
543 =item B<--skip-debianization>
545 Skips application of the debian diff on top of the upstream sources
546 (since dpkg 1.15.1).
548 =back
550 =head2 Format: 2.0
552 Extraction supported since dpkg 1.13.9, building supported since dpkg 1.14.8.
553 Also known as wig&pen.
554 This format is not recommended for wide-spread
555 usage, the format “3.0 (quilt)” replaces it.
556 Wig&pen was the first specification of a new-generation source package format.
558 The behavior of this format is the same as the “3.0 (quilt)” format
559 except that it doesn't use an explicit list of patches.
560 All files in
561 B<debian/patches/> matching the perl regular expression B<[\w-]+>
562 must be valid patches: they are applied at extraction time.
564 When building a new source package, any change to the upstream source
565 is stored in a patch named B<zz_debian-diff-auto>.
567 =head2 Format: 3.0 (native)
569 Supported since dpkg 1.14.17.
570 This format is an extension of the native package format as defined
571 in the 1.0 format.
572 It supports all compression methods and
573 will ignore by default any VCS specific files and directories
574 as well as many temporary files (see default value associated to
575 B<-I> option in the B<--help> output).
577 =head2 Format: 3.0 (quilt)
579 Supported since dpkg 1.14.17.
580 A source package in this format contains at least
581 an original tarball (B<.orig.tar.>I<ext> where I<ext> can be
582 B<gz>, B<bz2>, B<lzma> and B<xz>) and a debian tarball
583 (B<.debian.tar.>I<ext>).
584 It can also contain additional original
585 tarballs (B<.orig->I<component>B<.tar.>I<ext>).
586 I<component> can only contain alphanumeric (‘a-zA-Z0-9’) characters
587 and hyphens (‘-’).
588 Optionally each original tarball can be accompanied by a detached
589 upstream signature (B<.orig.tar.>I<ext>B<.asc> and
590 B<.orig->I<component>B<.tar.>I<ext>B<.asc>), extraction
591 supported since dpkg 1.17.20, building supported since dpkg 1.18.5.
593 B<Extracting>
595 The main original tarball is extracted first, then all additional original
596 tarballs are extracted in subdirectories named after the I<component>
597 part of their filename (any pre-existing directory is replaced).
599 debian tarball is extracted on top of the source directory after prior
600 removal of any pre-existing B<debian> directory.
601 Note that the
602 debian tarball must contain a B<debian> sub-directory but it
603 can also contain binary files outside of that directory (see
604 B<--include-binaries> option).
606 All patches listed in B<debian/patches/>I<vendor>B<.series> or
607 B<debian/patches/series> are then applied, where I<vendor> will be
608 the lowercase name of the current vendor, or B<debian> if there is
609 no vendor defined.
610 If the former file is used and the latter one doesn't exist (or is a
611 symlink), then the latter is replaced with a symlink to the former.
612 This is meant to simplify usage of B<quilt> to manage the set of patches.
613 Vendor-specific series files are intended to make it possible to serialize
614 multiple development branches based on the vendor, in a declarative way,
615 in preference to open-coding this handling in B<debian/rules>.
616 This is particularly useful when the source would need to be patched
617 conditionally because the affected files do not have built-in conditional
618 occlusion support.
619 Note however that while B<dpkg-source> parses correctly series files
620 with explicit options used for patch application (stored on each line
621 after the patch filename and one or more spaces), it does ignore those
622 options and always expects patches that can be applied with the B<-p1>
623 option of B<patch>.
624 It will thus emit a warning when it encounters
625 such options, and the build is likely to fail.
627 Note that L<lintian(1)> will emit unconditional warnings when using
628 vendor series due to a controversial Debian specific ruling, which should
629 not affect any external usage; to silence these, the dpkg lintian profile
630 can be used by passing «B<--profile dpkg>» to L<lintian(1)>.
632 The timestamp of all patched files is reset to the extraction time of
633 the source package (this avoids timestamp skews leading to problems
634 when autogenerated files are patched).
636 Contrary to B<quilt>'s default behavior, patches are expected to apply
637 without any fuzz.
638 When that is not the case, you should refresh such
639 patches with B<quilt>, or B<dpkg-source> will error out while
640 trying to apply them.
642 Similarly to B<quilt>'s default behavior, the patches can remove
643 files too.
645 The file B<.pc/applied-patches> is created if some
646 patches have been applied during the extraction.
648 B<Building>
650 All original tarballs found in the current directory are extracted in a
651 temporary directory by following the same logic as for the unpack, the
652 debian directory is copied over in the temporary directory, and all
653 patches except the automatic patch (B<debian-changes->I<version>
654 or B<debian-changes>, depending on B<--single-debian-patch>) are
655 applied.
656 The temporary directory is compared to the source package directory.
657 When the diff is non-empty, the build fails unless
658 B<--single-debian-patch> or B<--auto-commit>
659 has been used, in which case the diff is stored in the automatic patch.
660 If the automatic patch is created/deleted, it's added/removed from the
661 series file and from the B<quilt> metadata.
663 Any change
664 on a binary file is not representable in a diff and will thus lead to a
665 failure unless the maintainer deliberately decided to include that
666 modified binary file in the debian tarball (by listing it in
667 B<debian/source/include-binaries>).
668 The build will also fail if it
669 finds binary files in the debian sub-directory unless they have been
670 allowed through B<debian/source/include-binaries>.
672 The updated debian directory and the list of modified binaries is then
673 used to generate the debian tarball.
675 The automatically generated diff doesn't include changes on VCS specific
676 files as well as many temporary files (see default value associated to
677 B<-i> option in the B<--help> output).
678 In particular, the
679 B<.pc> directory used by B<quilt> is ignored during generation of the
680 automatic patch.
682 B<Note>: B<dpkg-source> B<--before-build> (and B<--build>) will
683 ensure that all patches listed in the series file are applied so that a
684 package build always has all patches applied.
685 It does this by finding
686 unapplied patches (they are listed in the B<series> file but not in
687 B<.pc/applied-patches>), and if the first patch in that set can be
688 applied without errors, it will apply them all.
689 The option
690 B<--no-preparation> can be used to disable this
691 behavior.
693 B<Recording changes>
695 =over
697 =item B<--commit> [I<directory>] [I<patch-name>] [I<patch-file>]
699 Generates a patch corresponding to the local changes that are not managed
700 by the B<quilt> patch system and integrates it in the patch system under
701 the name I<patch-name>.
702 If the name is missing, it will be asked interactively.
703 If I<patch-file> is given,
704 it is used as the patch corresponding to the local changes to integrate.
705 Once integrated, an
706 editor (the first one found from B<sensible-editor>, C<$VISUAL>, C<$EDITOR>,
707 B<vi>) is launched so that you can edit the meta-information in the patch
708 header.
710 Passing I<patch-file> is mainly useful after a build failure that
711 pre-generated this file, and on this ground the given file is removed
712 after integration.
713 Note also that the changes contained in the patch file
714 must already be applied on the tree and that the files modified by the
715 patch must not have supplementary unrecorded changes.
717 If the patch generation detects modified binary files, they will be
718 automatically added to B<debian/source/include-binaries> so that
719 they end up in the debian tarball (exactly like B<dpkg-source
720 --include-binaries --build> would do).
722 =back
724 B<Build options>
726 =over
728 =item B<--allow-version-of-quilt-db=>I<version>
730 Allow B<dpkg-source> to build the source package if the version of
731 the B<quilt> metadata is the one specified, even if B<dpkg-source>
732 doesn't know about it (since dpkg 1.15.5.4).
733 Effectively this says that the given version of the
734 B<quilt> metadata is compatible with the version 2 that B<dpkg-source>
735 currently supports.
736 The version of the B<quilt> metadata is stored in
737 B<.pc/.version>.
739 =item B<--include-removal>
741 Do not ignore removed files and include them in the automatically
742 generated patch.
744 =item B<--include-timestamp>
746 Include timestamp in the automatically generated patch.
748 =item B<--include-binaries>
750 Add all modified binaries in the debian tarball.
751 Also add them to
752 B<debian/source/include-binaries>: they will be added by default
753 in subsequent builds and this option is thus no more needed.
755 =item B<--no-preparation>
757 Do not try to prepare the build tree by applying patches which are
758 apparently unapplied (since dpkg 1.14.18).
760 =item B<--single-debian-patch>
762 Use B<debian/patches/debian-changes> instead of
763 B<debian/patches/debian-changes->I<version> for the name of the
764 automatic patch generated during build (since dpkg 1.15.5.4).
765 This option is particularly
766 useful when the package is maintained in a VCS and a patch set can't reliably
767 be generated.
768 Instead the current diff with upstream should be stored in a single patch.
769 The option would be put in B<debian/source/local-options>
770 and would be accompanied by a B<debian/source/local-patch-header> file
771 explaining how the Debian changes can be best reviewed, for example in the
772 VCS that is used.
774 =item B<--create-empty-orig>
776 Automatically create the main original tarball as empty if it's missing
777 and if there are supplementary original tarballs (since dpkg 1.15.6).
778 This option is meant to
779 be used when the source package is just a bundle of multiple upstream
780 software and where there's no “main” software.
782 =item B<--no-unapply-patches, --unapply-patches>
784 By default, B<dpkg-source> will automatically unapply the patches in the
785 B<--after-build> hook if it did apply them during
786 B<--before-build> (B<--unapply-patches> since dpkg 1.15.8,
787 B<--no-unapply-patches> since dpkg 1.16.5).
788 Those options allow you to forcefully disable
789 or enable the patch unapplication process.
790 Those options are only allowed
791 in B<debian/source/local-options> so that all generated source
792 packages have the same behavior by default.
794 =item B<--abort-on-upstream-changes>
796 The process fails if an automatic patch has been generated
797 (since dpkg 1.15.8).
798 This option
799 can be used to ensure that all changes were properly recorded in separate
800 B<quilt> patches prior to the source package build.
801 This option is not
802 allowed in B<debian/source/options> but can be used in
803 B<debian/source/local-options>.
805 =item B<--auto-commit>
807 The process doesn't fail if an automatic patch has been generated, instead
808 it's immediately recorded in the B<quilt> series.
810 =back
812 B<Extract options>
814 =over
816 =item B<--skip-debianization>
818 Skips extraction of the debian tarball on top of the upstream sources
819 (since dpkg 1.15.1).
821 =item B<--skip-patches>
823 Do not apply patches at the end of the extraction (since dpkg 1.14.18).
825 =back
827 =head2 Format: 3.0 (custom)
829 Supported since dpkg 1.14.17.
830 This format is special.
831 It doesn't represent a real source package
832 format but can be used to create source packages with arbitrary files.
834 B<Build options>
836 All non-option arguments are taken as files to integrate in the
837 generated source package.
838 They must exist and are preferably in the current directory.
839 At least one file must be given.
841 =over
843 =item B<--target-format=>I<value>
845 B<Required>.
846 Defines the real format of the generated source package.
847 The generated .dsc file will contain this value in its B<Format> field
848 and not “3.0 (custom)”.
850 =back
852 =head2 Format: 3.0 (git)
854 Supported since dpkg 1.14.17.
855 This format is experimental.
857 A source package in this format consists of a
858 single bundle of a git repository B<.git> to hold the source of a package.
859 There may also be a B<.gitshallow> file listing revisions for a shallow
860 git clone.
862 B<Extracting>
864 The bundle is cloned as a git repository to the target directory.
865 If there is a gitshallow file, it is installed as I<.git/shallow> inside
866 the cloned git repository.
868 Note that by default the new repository will have the same branch checked
869 out that was checked out in the original source.
870 (Typically “main”, but it could be anything.)
871 Any other branches will be available under I<remotes/origin/>.
873 B<Building>
875 Before going any further, some checks are done to ensure that we
876 don't have any non-ignored uncommitted changes.
878 L<git-bundle(1)> is used to generate a bundle of the git repository.
879 By default, all branches and tags in the repository are included in the
880 bundle.
882 B<Build options>
884 =over
886 =item B<--git-ref=>I<ref>
888 Allows specifying a git ref to include in the git bundle.
889 Use disables the default behavior of including all branches and tags.
890 May be specified multiple times.
891 The I<ref> can be the name of a branch or tag to include.
892 It may also be any parameter that can be passed to L<git-rev-list(1)>.
893 For example, to include only the main branch, use B<--git-ref=>main.
894 To include all tags and
895 branches, except for the private branch, use B<--git-ref=>--all
896 B<--git-ref=>^private
898 =item B<--git-depth=>I<number>
900 Creates a shallow clone with a history truncated to the specified number of
901 revisions.
903 =back
905 =head2 Format: 3.0 (bzr)
907 Supported since dpkg 1.14.17.
908 This format is experimental.
909 It generates a single tarball containing the bzr repository.
911 B<Extracting>
913 The tarball is unpacked and then bzr is used to checkout the current
914 branch.
916 B<Building>
918 Before going any further, some checks are done to ensure that we
919 don't have any non-ignored uncommitted changes.
921 Then the VCS specific part of the source directory is copied over to a
922 temporary directory.
923 Before this temporary directory is packed in a tarball,
924 various cleanup are done to save space.
926 =head1 DIAGNOSTICS
928 =head2 no source format specified in debian/source/format
930 The file B<debian/source/format> should always exist and indicate the
931 desired source format.
932 For backwards compatibility, format “1.0” is
933 assumed when the file doesn't exist but you should not rely on this:
934 at some point in the future B<dpkg-source> will be modified to fail
935 when that file doesn't exist.
937 The rationale is that format “1.0” is no longer the recommended format,
938 you should usually pick one of the newer formats (“3.0 (quilt)”, “3.0
939 (native)”) but B<dpkg-source> will not do this automatically for you.
940 If you want to continue using the old format, you should be explicit about
941 it and put “1.0” in B<debian/source/format>.
943 =head2 the diff modifies the following upstream files
945 When using source format “1.0” it is usually a bad idea to modify
946 upstream files directly as the changes end up hidden and mostly
947 undocumented in the .diff.gz file.
948 Instead you should store your changes as patches in the debian directory
949 and apply them at build-time.
950 To avoid
951 this complexity you can also use the format “3.0 (quilt)” that offers
952 this natively.
954 =head2 cannot represent change to I<file>
956 Changes to upstream sources are usually stored with patch files, but not
957 all changes can be represented with patches: they can only alter the
958 content of plain text files.
959 If you try replacing a file with something of
960 a different type (for example replacing a plain file with a symlink or a
961 directory), you will get this error message.
963 =head2 newly created empty file I<file> will not be represented in diff
965 Empty files can't be created with patch files.
966 Thus this change is not
967 recorded in the source package and you are warned about it.
969 =head2 executable mode I<perms> of I<file> will not be represented in diff
971 Patch files do not record permissions of files and thus executable
972 permissions are not stored in the source package.
973 This warning reminds you
974 of that fact.
976 =head2 special mode I<perms> of I<file> will not be represented in diff
978 Patch files do not record permissions of files and thus modified
979 permissions are not stored in the source package.
980 This warning reminds you
981 of that fact.
983 =head1 ENVIRONMENT
985 =over
987 =item B<DPKG_COLORS>
989 Sets the color mode (since dpkg 1.18.5).
990 The currently accepted values are: B<auto> (default), B<always> and
991 B<never>.
993 =item B<DPKG_NLS>
995 If set, it will be used to decide whether to activate Native Language Support,
996 also known as internationalization (or i18n) support (since dpkg 1.19.0).
997 The accepted values are: B<0> and B<1> (default).
999 =item B<SOURCE_DATE_EPOCH>
1001 If set, it will be used as the timestamp (as seconds since the epoch) to
1002 clamp the mtime in the L<tar(5)> file entries.
1004 Since dpkg 1.18.11.
1006 =item B<VISUAL>
1008 =item B<EDITOR>
1010 Used by the “2.0” and “3.0 (quilt)” source format modules.
1012 =item B<GIT_DIR>
1014 =item B<GIT_INDEX_FILE>
1016 =item B<GIT_OBJECT_DIRECTORY>
1018 =item B<GIT_ALTERNATE_OBJECT_DIRECTORIES>
1020 =item B<GIT_WORK_TREE>
1022 Used by the “3.0 (git)” source format modules.
1024 =back
1026 =head1 FILES
1028 =head2 debian/source/format
1030 This file contains on a single line the format that should be used to
1031 build the source package (possible formats are described above).
1032 No leading
1033 or trailing spaces are allowed.
1035 =head2 debian/source/include-binaries
1037 This file contains a list of pathnames of binary files (one per line) relative
1038 to the source root directory that should be included in the debian tarball.
1039 Leading and trailing spaces are stripped.
1040 Lines starting with ‘B<#>’ are comments and are skipped.
1041 Empty lines are ignored.
1043 =head2 debian/source/options
1045 This file contains a list of long options that should be automatically
1046 prepended to the set of command line options of a B<dpkg-source --build>
1047 or B<dpkg-source --print-format> call.
1048 Options like
1049 B<--compression> and B<--compression-level> are well suited for
1050 this file.
1052 Each option should be put on a separate line.
1053 Empty lines and lines
1054 starting with ‘B<#>’ are ignored.
1055 The leading ‘B<-->’ should be stripped and short options are
1056 not allowed.
1057 Optional spaces are allowed around the ‘B<=>’ symbol and optional
1058 quotes are allowed around the value.
1059 Here's an example of such a file:
1061  # let dpkg-source create a debian.tar.bz2 with maximal compression
1062  compression = "bzip2"
1063  compression-level = 9
1064  # use debian/patches/debian-changes as automatic patch
1065  single-debian-patch
1066  # ignore changes on config.{sub,guess}
1067  extend-diff-ignore = "(^|/)(config.sub|config.guess)$"
1069 B<Note>: B<format> options are not accepted in this file, you should
1070 use B<debian/source/format> instead.
1072 =head2 debian/source/local-options
1074 Exactly like B<debian/source/options> except that the file is not
1075 included in the generated source package.
1076 It can be useful to store
1077 a preference tied to the maintainer or to the VCS repository where
1078 the source package is maintained.
1080 =head2 debian/source/local-patch-header
1082 =head2 debian/source/patch-header
1084 Free form text that is put on top of the automatic patch generated
1085 in formats “2.0” or “3.0 (quilt)”.
1086 B<local-patch-header> is not
1087 included in the generated source package while B<patch-header> is.
1089 =head2 debian/patches/I<vendor>.series
1091 =head2 debian/patches/series
1093 This file lists all patches that have to be applied (in the given order)
1094 on top of the upstream source package.
1095 Leading and trailing spaces are
1096 stripped.
1097 The I<vendor> will be the lowercase name of the current vendor, or
1098 B<debian> if there is no vendor defined.
1099 If the vendor-specific series file does not exist, the vendor-less series
1100 file will be used.
1101 Lines starting with ‘B<#>’ are comments and are skipped.
1102 Empty lines are ignored.
1103 Remaining lines start with a patch filename (relative
1104 to the B<debian/patches/> directory) up to the first space character or
1105 the end of line.
1106 Optional B<quilt> options can follow up to the end of line
1107 or the first ‘B<#>’ preceded by one or more spaces (which marks the
1108 start of a comment up to the end of line).
1110 =head1 SECURITY
1112 Examining untrusted source packages or extracting them into staging
1113 directories should be considered a security boundary, and any breakage
1114 of that boundary stemming from these operations should be considered a
1115 security vulnerability.
1116 But handling untrusted source packages should not be done lightly,
1117 as the surface area includes any compression command supported,
1118 commands to handle specific data formats (such as L<tar(1)> or L<patch(1)>)
1119 in addition to the source package formats and control files themselves.
1120 Performing these operations over untrusted data as root is strongly
1121 discouraged.
1123 Building source packages should only be performed over trusted data.
1125 =head1 BUGS
1127 The point at which field overriding occurs compared to certain
1128 standard output field settings is rather confused.
1130 =head1 SEE ALSO
1132 L<deb-src-control(5)>,
1133 L<deb-changelog(5)>,
1134 L<deb-substvars(5)>,
1135 L<dsc(5)>.