dpkg-source.1 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766
  1. .\" dpkg manual page - dpkg-source(1)
  2. .\"
  3. .\" Copyright © 1995-1996 Ian Jackson <ian@chiark.chu.cam.ac.uk>
  4. .\" Copyright © 2000 Wichert Akkerman <wakkerma@debian.org>
  5. .\" Copyright © 2006-2007 Frank Lichtenheld <djpig@debian.org>
  6. .\" Copyright © 2006-2013 Guillem Jover <guillem@debian.org>
  7. .\" Copyright © 2008-2011 Raphaël Hertzog <hertzog@debian.org>
  8. .\" Copyright © 2010 Joey Hess <joeyh@debian.org>
  9. .\"
  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.
  14. .\"
  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.
  19. .\"
  20. .\" You should have received a copy of the GNU General Public License
  21. .\" along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. .
  23. .TH dpkg\-source 1 "2013-04-02" "Debian Project" "dpkg utilities"
  24. .SH NAME
  25. dpkg\-source \- Debian source package (.dsc) manipulation tool
  26. .
  27. .SH SYNOPSIS
  28. .B dpkg\-source
  29. .RI [ option "...] " command
  30. .
  31. .SH DESCRIPTION
  32. .B dpkg\-source
  33. packs and unpacks Debian source archives.
  34. None of these commands allow multiple options to be combined into one,
  35. and they do not allow the value for an option to be specified in a
  36. separate argument.
  37. .
  38. .SH COMMANDS
  39. .TP
  40. .BI "\-x " filename ".dsc " \fR[\fPoutput-directory\fR]\fP
  41. Extract a source package. One non-option argument must be supplied,
  42. the name of the Debian source control file
  43. .RB ( .dsc ).
  44. An optional second non-option argument may be supplied to specify the
  45. directory to extract the source package to, this must not exist. If
  46. no output directory is specified, the source package is extracted into
  47. a directory named \fIsource\fR-\fIversion\fR under the current working
  48. directory.
  49. .B dpkg\-source
  50. will read the names of the other file(s) making up the source package
  51. from the control file; they are assumed to be in the same directory as
  52. the
  53. .BR .dsc .
  54. The files in the extracted package will have their permissions and
  55. ownerships set to those which would have been expected if the files
  56. and directories had simply been created - directories and executable
  57. files will be 0777 and plain files will be 0666, both modified by the
  58. extractors' umask; if the parent directory is setgid then the
  59. extracted directories will be too, and all the files and directories
  60. will inherit its group ownership.
  61. If the source package uses a non-standard format (currently this means all
  62. formats except "1.0"), its name will be stored in
  63. \fBdebian/source/format\fP so that the following builds of the source
  64. package use the same format by default.
  65. .TP
  66. .RI "\fB\-b\fP " directory " [" format-specific-parameters ]
  67. Build a source package. The first non-option argument is taken as the
  68. name of the directory containing the debianized source tree (i.e. with a
  69. debian sub-directory and maybe changes to the original files).
  70. Depending on the source package format used to build the package,
  71. additional parameters might be accepted.
  72. \fBdpkg\-source\fP will build the source package with the first format
  73. found in this ordered list:
  74. the format indicated with the \fI\-\-format\fP command line option,
  75. the format indicated in \fBdebian/source/format\fP,
  76. "1.0". The fallback to "1.0" is deprecated and will be removed at some
  77. point in the future, you should always document the desired source format
  78. in \fBdebian/source/format\fP. See section \fBSOURCE PACKAGE FORMATS\fP
  79. for an extensive description of the various source package formats.
  80. .TP
  81. .RI "\fB\-\-print\-format\fP " directory
  82. Print the source format that would be used to build the source package if
  83. \fBdpkg\-source \-b \fIdirectory\fR was called (in the same conditions and
  84. with the same parameters).
  85. .TP
  86. .RI "\fB\-\-before\-build\fP " directory
  87. Run the corresponding hook of the source package format. This hook is
  88. called before any build of the package (\fBdpkg\-buildpackage\fP calls it
  89. very early even before \fBdebian/rules clean\fP). This command is
  90. idempotent and can be called multiple times. Not all source formats
  91. implement something in this hook, and those that do usually prepare the
  92. source tree for the build for example by ensuring that the Debian patches
  93. are applied.
  94. .TP
  95. .RI "\fB\-\-after\-build\fP " directory
  96. Run the corresponding hook of the source package format. This hook is
  97. called after any build of the package (\fBdpkg\-buildpackage\fP calls it
  98. last). This command is idempotent and can be called multiple times. Not
  99. all source formats implement something in this hook, and those that do
  100. usually use it to undo what \fB\-\-before\-build\fP has done.
  101. .TP
  102. .RI "\fB\-\-commit\fP [" directory "] ..."
  103. Record changes in the source tree unpacked in \fIdirectory\fP. This
  104. command can take supplementary parameters depending on the source format.
  105. It will error out for formats where this operation doesn't mean anything.
  106. .TP
  107. .BR \-? ", " \-\-help
  108. Show the usage message and exit.
  109. .TP
  110. .BR \-\-version
  111. Show the version and exit.
  112. .
  113. .SH OPTIONS
  114. .SS Generic build options
  115. .TP
  116. .BI \-c control-file
  117. Specifies the main source control file to read information from. The
  118. default is
  119. .BR debian/control .
  120. If given with relative pathname this is interpreted starting at
  121. the source tree's top level directory.
  122. .TP
  123. .BI \-l changelog-file
  124. Specifies the changelog file to read information from. The
  125. default is
  126. .BR debian/changelog .
  127. If given with relative pathname this is interpreted starting at
  128. the source tree's top level directory.
  129. .TP
  130. .BI \-F changelog-format
  131. Specifies the format of the changelog. See \fBdpkg\-parsechangelog\fP(1)
  132. for information about alternative formats.
  133. .TP
  134. .BI \-\-format= value
  135. Use the given format for building the source package. It does
  136. override any format given in \fBdebian/source/format\fP.
  137. .TP
  138. .BI \-V name = value
  139. Set an output substitution variable.
  140. See \fBdeb\-substvars\fP(5) for a discussion of output substitution.
  141. .TP
  142. .BI \-T substvars-file
  143. Read substitution variables in
  144. .IR substvars-file ;
  145. the default is to not read any file. This option can be used multiple
  146. times to read substitution variables from multiple files.
  147. .TP
  148. .BI \-D field = value
  149. Override or add an output control file field.
  150. .TP
  151. .BI \-U field
  152. Remove an output control file field.
  153. .TP
  154. .BR \-Z "\fIcompression\fP, " \-\-compression =\fIcompression\fP
  155. Specify the compression to use for created files (tarballs and diffs).
  156. Note that this option will not cause existing tarballs to be recompressed,
  157. it only affects new files. Supported values are:
  158. .IR gzip ", " bzip2 ", " lzma " and " xz .
  159. \fIgzip\fP is the default. \fIxz\fP is only supported since
  160. dpkg 1.15.5.
  161. .TP
  162. .BR \-z "\fIlevel\fP, " \-\-compression\-level =\fIlevel\fP
  163. Compression level to use. As with \fB\-Z\fP it only affects newly created
  164. files. Supported values are:
  165. .IR 1 " to " 9 ", " best ", and " fast .
  166. The default is \fI9\fP for gzip and bzip2, \fI6\fP for xz and lzma.
  167. .TP
  168. .BR \-i "[\fIregexp\fP], " \-\-diff\-ignore [=\fIregexp\fP]
  169. You may specify a perl regular expression to match files you want
  170. filtered out of the list of files for the diff. (This list is
  171. generated by a find command.) (If the source package is being built as a
  172. version 3 source package using a VCS, this can be used to ignore
  173. uncommited changes on specific files. Using \-i.* will ignore all of them.)
  174. \fB\-i\fP by itself enables the option, with a default regexp that will
  175. filter out control files and directories of the most common revision
  176. control systems, backup and swap files and Libtool build output
  177. directories. There can only be one active regexp, of multiple
  178. \fB\-i\fP options only the last one will take effect.
  179. This is very helpful in cutting out extraneous files that get included
  180. in the diff, e.g. if you maintain your source in a revision control
  181. system and want to use a checkout to build a source package without
  182. including the additional files and directories that it will usually
  183. contain (e.g. CVS/, .cvsignore, .svn/). The default regexp is already
  184. very exhaustive, but if you need to replace it, please note that by
  185. default it can match any part of a path, so if you want to match the
  186. begin of a filename or only full filenames, you will need to provide
  187. the necessary anchors (e.g. '(^|/)', '($|/)') yourself.
  188. .TP
  189. .BR \-\-extend\-diff\-ignore =\fIregexp\fP
  190. The perl regular expression specified will extend the default value
  191. of \fB\-\-diff\-ignore\fP and its current value (if set). It does this
  192. by concatenating "\fB|\fP\fIregexp\fP" to the existing value.
  193. This option is convenient to use in \fBdebian/source/options\fP to exclude
  194. some auto-generated files from the automatic patch generation.
  195. .TP
  196. .BR \-I "[\fIfile-pattern\fP], " \-\-tar\-ignore [=\fIfile-pattern\fP]
  197. If this option is specified, the pattern will be passed to
  198. .BR tar (1)'s
  199. .B \-\-exclude
  200. option when it is called to generate a .orig.tar or .tar file. For
  201. example, \fB\-I\fPCVS will make tar skip over CVS directories when generating
  202. a .tar.gz file. The option may be repeated multiple times to list multiple
  203. patterns to exclude.
  204. \fB\-I\fP by itself adds default \fB\-\-exclude\fP options that will
  205. filter out control files and directories of the most common revision
  206. control systems, backup and swap files and Libtool build output
  207. directories.
  208. .PP
  209. .B Note:
  210. While they have similar purposes, \fB\-i\fP and \fB\-I\fP have very
  211. different syntax and semantics. \fB\-i\fP can only be specified once and
  212. takes a perl compatible regular expression which is matched against
  213. the full relative path of each file. \fB\-I\fP can specified
  214. multiple times and takes a filename pattern with shell wildcards.
  215. The pattern is applied to the full relative path but also
  216. to each part of the path individually. The exact semantic of tar's
  217. \fB\-\-exclude\fP option is somewhat complicated, see
  218. http://www.gnu.org/software/tar/manual/tar.html#wildcards for a full
  219. documentation.
  220. The default regexp and patterns for both options can be seen
  221. in the output of the \fB\-\-help\fP command.
  222. .SS Generic extract options
  223. .TP
  224. .BI \-\-no\-copy
  225. Do not copy original tarballs near the extracted source package.
  226. .TP
  227. .BI \-\-no\-check
  228. Do not check signatures and checksums before unpacking.
  229. .TP
  230. .BI \-\-require\-valid\-signature
  231. Refuse to unpack the source package if it doesn't contain an OpenPGP
  232. signature that can be verified either with the user's
  233. \fItrustedkeys.gpg\fP keyring, one of the vendor-specific keyrings, or one
  234. of the official Debian keyrings
  235. (\fI/usr/share/keyrings/debian\-keyring.gpg\fP
  236. and \fI/usr/share/keyrings/debian\-maintainers.gpg\fP).
  237. .SH SOURCE PACKAGE FORMATS
  238. If you don't know what source format to use, you should probably pick
  239. either "3.0 (quilt)" or "3.0 (native)". See
  240. http://wiki.debian.org/Projects/DebSrc3.0 for information on the
  241. deployment of those formats within Debian.
  242. .SS Format: 1.0
  243. A source package in this format consists either of a \fB.orig.tar.gz\fP
  244. associated to a \fB.diff.gz\fP or a single \fB.tar.gz\fP (in that case
  245. the package is said to be \fInative\fP).
  246. .B Extracting
  247. Extracting a native package is a simple extraction of the single
  248. tarball in the target directory. Extracting a non-native package
  249. is done by first unpacking the \fB.orig.tar.gz\fP and then applying
  250. the patch contained in the \fB.diff.gz\fP file. The timestamp of
  251. all patched files is reset to the extraction time of the source
  252. package (this avoids timestamp skews leading to problems when
  253. autogenerated files are patched). The diff can create new files (the whole
  254. debian directory is created that way) but can't remove files (empty files
  255. will be left over).
  256. .B Building
  257. Building a native package is just creating a single tarball with
  258. the source directory. Building a non-native package involves
  259. extracting the original tarball in a separate ".orig" directory and
  260. regenerating the \fB.diff.gz\fP by comparing the source package
  261. \fIdirectory\fP with the .orig directory.
  262. .TP
  263. .B Build options (with \-b):
  264. .PP
  265. If a second non-option argument is supplied it should be the name of the
  266. original source directory or tarfile or the empty string if the package is
  267. a Debian-specific one and so has no Debianisation diffs. If no second
  268. argument is supplied then
  269. .B dpkg\-source
  270. will look for the original source tarfile
  271. .IB package _ upstream-version .orig.tar.gz
  272. or the original source directory
  273. .IB directory .orig
  274. depending on the \fB\-sX\fP arguments.
  275. .BR \-sa ", " \-sp ", " \-sk ", " \-su " and " \-sr
  276. will not overwrite existing tarfiles or directories. If this is
  277. desired then
  278. .BR \-sA ", " \-sP ", " \-sK ", " \-sU " and " \-sR
  279. should be used instead.
  280. .TP
  281. .BR \-sk
  282. Specifies to expect the original source as a tarfile, by default
  283. .IB package _ upstream-version .orig.tar. extension \fR.
  284. It will leave this original source in place as a tarfile, or copy it
  285. to the current directory if it isn't already there. The
  286. tarball will be unpacked into
  287. .IB directory .orig
  288. for the generation of the diff.
  289. .TP
  290. .B \-sp
  291. Like
  292. .B \-sk
  293. but will remove the directory again afterwards.
  294. .TP
  295. .B \-su
  296. Specifies that the original source is expected as a directory, by
  297. default
  298. .IB package - upstream-version .orig
  299. and
  300. .B dpkg\-source
  301. will create a new original source archive from it.
  302. .TP
  303. .B \-sr
  304. Like
  305. .B \-su
  306. but will remove that directory after it has been used.
  307. .TP
  308. .B \-ss
  309. Specifies that the original source is available both as a directory
  310. and as a tarfile. \fBdpkg\-source\fP will use the directory to create
  311. the diff, but the tarfile to create the
  312. .BR .dsc .
  313. This option must be used with care - if the directory and tarfile do
  314. not match a bad source archive will be generated.
  315. .TP
  316. .B \-sn
  317. Specifies to not look for any original source, and to not generate a diff.
  318. The second argument, if supplied, must be the empty string. This is
  319. used for Debian-specific packages which do not have a separate
  320. upstream source and therefore have no debianisation diffs.
  321. .TP
  322. .BR \-sa " or " \-sA
  323. Specifies to look for the original source archive as a tarfile or as a
  324. directory - the second argument, if any, may be either, or the empty
  325. string (this is equivalent to using
  326. .BR \-sn ).
  327. If a tarfile is found it will unpack it to create the diff and remove
  328. it afterwards (this is equivalent to
  329. .BR \-sp );
  330. if a directory is found it will pack it to create the original source
  331. and remove it afterwards (this is equivalent to
  332. .BR \-sr );
  333. if neither is found it will assume that the package has no
  334. debianisation diffs, only a straightforward source archive (this is
  335. equivalent to
  336. .BR \-sn ).
  337. If both are found then \fBdpkg\-source\fP will ignore the directory,
  338. overwriting it, if
  339. .B \-sA
  340. was specified (this is equivalent to
  341. .BR \-sP )
  342. or raise an error if
  343. .B \-sa
  344. was specified.
  345. .B \-sA
  346. is the default.
  347. .TP
  348. .B \-\-abort\-on\-upstream\-changes
  349. The process fails if the generated diff contains changes to files
  350. outside of the debian sub-directory. This option is not allowed in
  351. \fBdebian/source/options\fP but can be used in
  352. \fBdebian/source/local\-options\fP.
  353. .TP
  354. .B Extract options (with \-x):
  355. .PP
  356. In all cases any existing original source tree will be removed.
  357. .TP
  358. .B \-sp
  359. Used when extracting then the original source (if any) will be left
  360. as a tarfile. If it is not already located in the current directory
  361. or if an existing but different file is there it will be copied there.
  362. (\fBThis is the default\fP).
  363. .TP
  364. .B \-su
  365. Unpacks the original source tree.
  366. .TP
  367. .B \-sn
  368. Ensures that the original source is neither copied to the current
  369. directory nor unpacked. Any original source tree that was in the
  370. current directory is still removed.
  371. .PP
  372. All the
  373. .BI \-s X
  374. options are mutually exclusive. If you specify more than one only the
  375. last one will be used.
  376. .TP
  377. .B \-\-skip\-debianization
  378. Skips application of the debian diff on top of the upstream sources.
  379. .
  380. .SS Format: 2.0
  381. Also known as wig&pen. This format is not recommended for wide-spread
  382. usage, the format "3.0 (quilt)" replaces it. Wig&pen was the first
  383. specification of a new-generation source package format.
  384. The behaviour of this format is the same as the "3.0 (quilt)" format
  385. except that it doesn't use an explicit list of patches. All files in
  386. \fBdebian/patches/\fP matching the perl regular expression \fB[\\w\-]+\fP
  387. must be valid patches: they are applied at extraction time.
  388. When building a new source package, any change to the upstream source
  389. is stored in a patch named \fBzz_debian\-diff\-auto\fP.
  390. .
  391. .SS Format: 3.0 (native)
  392. This format is an extension of the native package format as defined
  393. in the 1.0 format. It supports all compression methods and
  394. will ignore by default any VCS specific files and directories
  395. as well as many temporary files (see default value associated to
  396. \fB\-I\fP option in the \fB\-\-help\fP output).
  397. .
  398. .SS Format: 3.0 (quilt)
  399. A source package in this format contains at least
  400. an original tarball (\fB.orig.tar.\fP\fIext\fP where \fIext\fP can be
  401. \fBgz\fP, \fBbz2\fP, \fBlzma\fP and \fBxz\fP) and a debian tarball
  402. (\fB.debian.tar.\fP\fIext\fP). It can also contain additional original
  403. tarballs (\fB.orig\-\fP\fIcomponent\fP\fB.tar.\fP\fIext\fP).
  404. \fIcomponent\fP can only contain alphanumeric characters and dashes ("\-").
  405. .PP
  406. .B Extracting
  407. .PP
  408. The main original tarball is extracted first, then all additional original
  409. tarballs are extracted in subdirectories named after the \fIcomponent\fP
  410. part of their filename (any pre-existing directory is replaced). The
  411. debian tarball is extracted on top of the source directory after prior
  412. removal of any pre-existing \fBdebian\fP directory. Note that the
  413. debian tarball must contain a \fBdebian\fP sub-directory but it
  414. can also contain binary files outside of that directory (see
  415. \fB\-\-include\-binaries\fP option).
  416. .PP
  417. All patches listed in \fBdebian/patches/debian.series\fP or
  418. \fBdebian/patches/series\fP are then applied.
  419. If the former file is used and the latter one doesn't exist (or is a
  420. symlink), then the latter is replaced with a symlink to the former. This
  421. is meant to simplify usage of \fBquilt\fP to manage the set of patches. Note
  422. however that while \fBdpkg\-source\fP parses correctly series files with
  423. explicit options used for patch application (stored on each line
  424. after the patch filename and one or more spaces), it does ignore those
  425. options and always expect patches that can be applied with the \fB\-p1\fP
  426. option of \fBpatch\fP. It will thus emit a warning when it encounters
  427. such options, and the build is likely to fail.
  428. .PP
  429. Contrary to \fBquilt\fP's default behaviour, patches are expected to apply
  430. without any fuzz. When that is not the case, you should refresh such
  431. patches with \fBquilt\fP, or \fBdpkg\-source\fP will error out while
  432. trying to apply them.
  433. .PP
  434. Similarly to \fBquilt\fP's default behaviour, the patches can remove
  435. files too.
  436. .PP
  437. The file \fB.pc/applied\-patches\fP is created if some
  438. patches have been applied during the extraction.
  439. .PP
  440. .B Building
  441. .PP
  442. All original tarballs found in the current directory are extracted in a
  443. temporary directory by following the same logic as for the unpack, the
  444. debian directory is copied over in the temporary directory, and all
  445. patches except the automatic patch (\fBdebian\-changes\-\fP\fIversion\fP
  446. or \fBdebian\-changes\fP, depending on \fB\-\-single\-debian\-patch\fP) are
  447. applied. The temporary directory is compared to the source package
  448. directory. When the diff is non-empty, the build fails unless
  449. \fB\-\-single\-debian\-patch\fP or \fB\-\-auto\-commit\fP
  450. has been used, in which case the diff is stored in the automatic patch.
  451. If the automatic patch is created/deleted, it's added/removed from the
  452. series file and from the \fBquilt\fP metadata.
  453. Any change
  454. on a binary file is not representable in a diff and will thus lead to a
  455. failure unless the maintainer deliberately decided to include that
  456. modified binary file in the debian tarball (by listing it in
  457. \fBdebian/source/include\-binaries\fP). The build will also fail if it
  458. finds binary files in the debian sub-directory unless they have been
  459. whitelisted through \fBdebian/source/include\-binaries\fP.
  460. The updated debian directory and the list of modified binaries is then
  461. used to generate the debian tarball.
  462. The automatically generated diff doesn't include changes on VCS specific
  463. files as well as many temporary files (see default value associated to
  464. \fB\-i\fP option in the \fB\-\-help\fP output). In particular, the
  465. \fB.pc\fP directory used by \fBquilt\fP is ignored during generation of the
  466. automatic patch.
  467. Note: \fBdpkg\-source\fP \fB\-\-before\-build\fP (and \fB\-b\fP) will
  468. ensure that all patches listed in the series file are applied so that a
  469. package build always has all patches applied. It does this by finding
  470. unapplied patches (they are listed in the \fBseries\fP file but not in
  471. \fB.pc/applied\-patches\fP), and if the first patch in that set can be
  472. applied without errors, it will apply them all. The option
  473. \fB\-\-no\-preparation\fP can be used to disable this
  474. behavior.
  475. .PP
  476. .B Recording changes
  477. .TP
  478. .RI "\fB\-\-commit\fP [" directory "] [" patch-name "] [" patch-file ]
  479. Generates a patch corresponding to the local changes that are not managed
  480. by the \fBquilt\fP patch system and integrates it in the patch system under
  481. the name \fIpatch-name\fP. If the name is missing, it will be asked
  482. interactively. If \fIpatch-file\fP is given, it is used as the patch
  483. corresponding to the local changes to integrate. Once integrated, an
  484. editor is launched so that you can edit the meta-information in the patch
  485. header.
  486. Passing \fIpatch-file\fP is mainly useful after a build failure that
  487. pre-generated this file, and on this ground the given file is removed
  488. after integration. Note also that the changes contained in the patch file
  489. must already be applied on the tree and that the files modified by the
  490. patch must not have supplementary unrecorded changes.
  491. If the patch generation detects modified binary files, they will be
  492. automatically added to \fBdebian/source/include\-binaries\fP so that
  493. they end up in the debian tarball (exactly like \fBdpkg-source
  494. \-\-include\-binaries \-b\fP would do).
  495. .PP
  496. .B Build options
  497. .TP
  498. .BI \-\-allow\-version\-of\-quilt\-db= version
  499. Allow \fBdpkg\-source\fP to build the source package if the version of
  500. the \fBquilt\fP metadata is the one specified, even if \fBdpkg\-source\fP
  501. doesn't know about it. Effectively this says that the given version of the
  502. \fBquilt\fP metadata is compatible with the version 2 that \fBdpkg\-source\fP
  503. currently supports. The version of the \fBquilt\fP metadata is stored in
  504. \fB.pc/.version\fP.
  505. .TP
  506. .B \-\-include\-removal
  507. Do not ignore removed files and include them in the automatically
  508. generated patch.
  509. .TP
  510. .B \-\-include\-timestamp
  511. Include timestamp in the automatically generated patch.
  512. .TP
  513. .B \-\-include\-binaries
  514. Add all modified binaries in the debian tarball. Also add them to
  515. \fBdebian/source/include\-binaries\fP: they will be added by default
  516. in subsequent builds and this option is thus no more needed.
  517. .TP
  518. .B \-\-no\-preparation
  519. Do not try to prepare the build tree by applying patches which are
  520. apparently unapplied.
  521. .TP
  522. .B \-\-single\-debian\-patch
  523. Use \fBdebian/patches/debian\-changes\fP instead of
  524. \fBdebian/patches/debian\-changes\-\fP\fIversion\fP for the name of the
  525. automatic patch generated during build. This option is particularly
  526. useful when the package is maintained in a VCS and a patch set can't reliably
  527. be generated. Instead the current diff with upstream should be stored in a
  528. single patch. The option would be put in \fBdebian/source/local\-options\fP
  529. and would be accompanied by a \fBdebian/source/local\-patch\-header\fP file
  530. explaining how the Debian changes can be best reviewed, for example in the
  531. VCS that is used.
  532. .TP
  533. .B \-\-create\-empty\-orig
  534. Automatically create the main original tarball as empty if it's missing
  535. and if there are supplementary original tarballs. This option is meant to
  536. be used when the source package is just a bundle of multiple upstream
  537. software and where there's no "main" software.
  538. .TP
  539. .B \-\-no\-unapply\-patches, \-\-unapply\-patches
  540. By default, \fBdpkg\-source\fP will automatically unapply the patches in the
  541. \fB\-\-after\-build\fP hook if it did apply them during
  542. \fB\-\-before\-build\fP. Those options allow you to forcefully disable
  543. or enable the patch unapplication process. Those options are only allowed
  544. in \fBdebian/source/local\-options\fP so that all generated source
  545. packages have the same behavior by default.
  546. .TP
  547. .B \-\-abort\-on\-upstream\-changes
  548. The process fails if an automatic patch has been generated. This option
  549. can be used to ensure that all changes were properly recorded in separate
  550. \fBquilt\fP patches prior to the source package build. This option is not
  551. allowed in \fBdebian/source/options\fP but can be used in
  552. \fBdebian/source/local\-options\fP.
  553. .TP
  554. .B \-\-auto\-commit
  555. The process doesn't fail if an automatic patch has been generated, instead
  556. it's immediately recorded in the \fBquilt\fP series.
  557. .PP
  558. .B Extract options
  559. .TP
  560. .B \-\-skip\-debianization
  561. Skips extraction of the debian tarball on top of the upstream sources.
  562. .TP
  563. .B \-\-skip\-patches
  564. Do not apply patches at the end of the extraction.
  565. .
  566. .SS Format: 3.0 (custom)
  567. This format is special. It doesn't represent a real source package
  568. format but can be used to create source packages with arbitrary files.
  569. .PP
  570. .B Build options
  571. .PP
  572. All non-option arguments are taken as files to integrate in the
  573. generated source package. They must exist and are preferably
  574. in the current directory. At least one file must be given.
  575. .TP
  576. .BI \-\-target\-format= value
  577. \fBRequired\fP. Defines the real format of the generated source package.
  578. The generated .dsc file will contain this value in its \fBFormat\fP field
  579. and not "3.0 (custom)".
  580. .
  581. .SS Format: 3.0 (git)
  582. This format is experimental.
  583. .PP
  584. A source package in this format consists of a
  585. single bundle of a git repository \fB.git\fP to hold the source of a package.
  586. There may also be a \fB.gitshallow\fP file listing revisions for a shallow
  587. git clone.
  588. .PP
  589. .B Extracting
  590. .PP
  591. The bundle is cloned as a git repository to the target directory.
  592. If there is a gitshallow file, it is installed as `.git/shallow` inside
  593. the cloned git repository.
  594. .PP
  595. Note that by default the new repository will have the same branch checked
  596. out that was checked out in the original source. (Typically "master", but
  597. it could be anything.) Any other branches will be available under
  598. `remotes/origin/`.
  599. .PP
  600. .B Building
  601. .PP
  602. Before going any further, some checks are done to ensure that we
  603. don't have any non-ignored uncommitted changes.
  604. .PP
  605. \fBgit\-bundle\fP(1) is used to generate a bundle of the git repository.
  606. By default, all branches and tags in the repository are included in the
  607. bundle.
  608. .PP
  609. .B Build options
  610. .TP
  611. .BI \-\-git\-ref= ref
  612. Allows specifying a git ref to include in the git bundle. Use disables
  613. the default behavior of including all branches and tags. May be specified
  614. multiple times. The \fIref\fP can be the name of a branch or tag to
  615. include. It may also be any parameter that can be passed to
  616. \fBgit\-rev\-list\fP(1). For example, to include only
  617. the master branch, use \fB\-\-git\-ref=\fPmaster. To include all tags and
  618. branches, except for the private branch, use \fB\-\-git\-ref=\fP\-\-all
  619. \fB\-\-git\-ref=\fP^private
  620. .TP
  621. .BI \-\-git\-depth= number
  622. Creates a shallow clone with a history truncated to the specified number of
  623. revisions.
  624. .SS Format: 3.0 (bzr)
  625. This format is experimental. It generates a single tarball
  626. containing the bzr repository.
  627. .PP
  628. .B Extracting
  629. .PP
  630. The tarball is unpacked and then bzr is used to checkout the current
  631. branch.
  632. .PP
  633. .B Building
  634. .PP
  635. Before going any further, some checks are done to ensure that we
  636. don't have any non-ignored uncommitted changes.
  637. .PP
  638. Then the VCS specific part of the source directory is copied over to a
  639. temporary directory. Before this temporary directory is packed in a tarball,
  640. various cleanup are done to save space.
  641. .SH DIAGNOSTICS
  642. .SS no source format specified in debian/source/format
  643. The file \fBdebian/source/format\fP should always exist and indicate the
  644. desired source format. For backwards compatibility, format "1.0" is
  645. assumed when the file doesn't exist but you should not rely on this:
  646. at some point in the future \fBdpkg\-source\fP will be modified to fail
  647. when that file doesn't exist.
  648. The rationale is that format "1.0" is no longer the recommended format,
  649. you should usually pick one of the newer formats ("3.0 (quilt)", "3.0
  650. (native)") but \fBdpkg\-source\fP will not do this automatically for you.
  651. If you want to continue using the old format, you should be explicit about
  652. it and put "1.0" in \fBdebian/source/format\fP.
  653. .SS the diff modifies the following upstream files
  654. When using source format "1.0" it is usually a bad idea to modify
  655. upstream files directly as the changes end up hidden and mostly
  656. undocumented in the .diff.gz file. Instead you should store your changes
  657. as patches in the debian directory and apply them at build-time. To avoid
  658. this complexity you can also use the format "3.0 (quilt)" that offers this
  659. natively.
  660. .SS cannot represent change to \fIfile\fP
  661. Changes to upstream sources are usually stored with patch files, but not
  662. all changes can be represented with patches: they can only alter the
  663. content of plain text files. If you try replacing a file with something of
  664. a different type (for example replacing a plain file with a symlink or a
  665. directory), you will get this error message.
  666. .SS newly created empty file \fIfile\fB will not be represented in diff
  667. Empty files can't be created with patch files. Thus this change is not
  668. recorded in the source package and you are warned about it.
  669. .SS executable mode \fIperms\fB of \fIfile\fB will not be represented in diff
  670. .SS special mode \fIperms\fB of \fIfile\fB will not be represented in diff
  671. Patch files do not record permissions of files and thus modified
  672. permissions are not stored in the source package. This warning reminds you
  673. of that fact.
  674. .SH FILE FORMATS
  675. .SS debian/source/format
  676. This file contains on a single line the format that should be used to
  677. build the source package (possible formats are described above). No leading
  678. or trailing spaces are allowed.
  679. .SS debian/source/include\-binaries
  680. This file contains a list of binary files (one per line) that should be
  681. included in the debian tarball. Leading and trailing spaces are stripped.
  682. Lines starting with "#" are comments and are skipped. Empty lines are ignored.
  683. .SS debian/source/options
  684. This file contains a list of long options that should be automatically
  685. prepended to the set of command line options of a \fBdpkg\-source \-b\fR
  686. or \fBdpkg\-source \-\-print\-format\fR call. Options like
  687. \fB\-\-compression\fR and \fB\-\-compression\-level\fR are well suited for
  688. this file.
  689. .P
  690. Each option should be put on a separate line. Empty lines and lines
  691. starting with "#" are ignored. The leading "\-\-" should be
  692. stripped and short options are not allowed. Optional spaces are allowed
  693. around the "=" symbol and optional quotes are allowed around the value.
  694. Here's an example of such a file:
  695. .P
  696. # let dpkg\-source create a debian.tar.bz2 with maximal compression
  697. compression = "bzip2"
  698. compression\-level = 9
  699. # use debian/patches/debian\-changes as automatic patch
  700. single\-debian\-patch
  701. # ignore changes on config.{sub,guess}
  702. extend-diff-ignore = "(^|/)(config\.sub|config\.guess)$"
  703. .P
  704. Note: \fBformat\fR options are not accepted in this file, you should
  705. use \fBdebian/source/format\fR instead.
  706. .SS debian/source/local\-options
  707. Exactly like \fBdebian/source/options\fP except that the file is not
  708. included in the generated source package. It can be useful to store
  709. a preference tied to the maintainer or to the VCS repository where
  710. the source package is maintained.
  711. .SS debian/source/local\-patch\-header
  712. .SS debian/source/patch\-header
  713. Free form text that is put on top of the automatic patch generated
  714. in formats "2.0" or "3.0 (quilt)". \fBlocal\-patch\-header\fP is not
  715. included in the generated source package while \fBpatch\-header\fP is.
  716. .SS debian/patches/series
  717. This file lists all patches that have to be applied (in the given order)
  718. on top of the upstream source package. Leading and trailing spaces are
  719. stripped. Lines starting with "#" are comments and are skipped. Empty
  720. lines are ignored. Remaining lines start with a patch filename (relative
  721. to the \fBdebian/patches/\fP directory) up to the first space character or
  722. the end of line. Optional \fBquilt\fP options can follow up to the end of line
  723. or the first "#" preceded by one or more spaces (which marks the start of
  724. a comment up to the end of line).
  725. .SH BUGS
  726. The point at which field overriding occurs compared to certain
  727. standard output field settings is rather confused.
  728. .SH SEE ALSO
  729. .BR dpkg\-deb (1),
  730. .BR dpkg (1),
  731. .BR dselect (1).