1 dgit (2.16.1) UNRELEASED; urgency=medium
3 * dgit-badcommit-fixup: New mode --check which is readonly.
5 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sat, 07 Jan 2017 13:04:49 +0000
7 dgit (2.16) unstable; urgency=low
9 Dealing with fallout from #849041:
10 * Provide dgit-badcommit-fixup history-rewriting script.
11 * New rewrite map feature, which allows dgit git server to adjust
12 clients' interpretation of Dgit fields, so that history-rewriting is
13 effective. (Feature is only partially implemented right now -
14 enough to dig current Debian users out of the hole.) Re:#850431.
17 * New test case for history-rewriting.
18 * Change `local foo=$(bar)' idiom to `local foo; foo=$(bar)' since
19 the former does not trip set -e even if bar fails :-(.
21 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Fri, 06 Jan 2017 20:46:30 +0000
23 dgit (2.15) UNRELEASED; urgency=high
26 * Prevent introduction of new commits which lack `committer'
27 information. Ie, prevent the reception of new commits afflicted by
28 #849041. Existing commits are tolerated.
31 * Be much stricter about messages from git-fsck.
33 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 05 Jan 2017 18:20:23 +0000
35 dgit (2.14) unstable; urgency=critical
38 * Do not generate bogus commits with --overwrite or import-dsc.
42 * Run a lot of git-fsck.
44 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Wed, 04 Jan 2017 22:52:55 +0000
46 dgit (2.13) unstable; urgency=high
49 * quilt fixup: Permit creation of patches which delete files, by psssing
50 --include-removal to dpkg-source, and tolerating it when we do our
51 quilt fixup analysis. dpkg-source has supported this since at least
52 stretch. Closes:#848901.
55 * Improve "cannot represent change" message: print the git old and new
59 * Import: Switch back to unpa branch on patch import iterations.
60 In particular, do not fail utterly if dpkg-source and gbp disagree.
63 Documentation [Sean Whitton]:
64 * dgit-maint-gbp(7): Remove reference to closed bug. Closes:#848725.
65 * dgit-sponsorship(7): Update in light of fixed #844129. Closes:#848789.
67 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Wed, 21 Dec 2016 01:32:41 +0000
69 dgit (2.12) unstable; urgency=high
72 * By default, generate a DEP-14 tag as well as a dgit archive/*
73 tag, even in non-split-view quilt modes. Closes:#844129.
74 * Version tags mangling: Protect dots, as per proposed update to DEP-14.
77 * dgit-maint-merge(7): Explain how to change to this workflow
78 from an existing git workflow. [Sean Whitton] Closes:#847807.
79 * dgit-maint-native(7): Clarify that we mean native source format.
80 [Phil Hands] Closes:#847987.
83 * Slightly better message when .dsc not found. Apropos of #844128.
84 * Give better advice if .dsc/.changes signing fails: if no changes
85 are needed to the package, user may indeed just debsign and dput.
87 * Produce better error reporting when absurd git wrapper fails
88 on a patch during .dsc import. Apropos of #848391.
91 * If we cannot hardlink origs into our extraction area, use symlinks
92 instead. Closes:#844570.
93 * Suppress some leftover debugging output from import-dsc.
95 * Do not fail when cloning a package containing dangling symlinks.
97 * Do not fail to import a .dsc containing patches which patch files
98 multiple times, due to #848611. Closes:#848391.
99 * Do not fail to import a .dsc containing patches to .git/ (!)
100 * infra: dgit-repos-policy-debian which broke due to recent git setting
101 GIT_ALTERNATE_OBJECT_DIRECTORIES in the pre-receive-hook.
102 (fixes test suite regression in stretch).
105 * Provide and use stunt lintian and debuild, to avoid lintian
106 complaining about our stupid test packages.
107 (fixes test suite regression in stretch).
109 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Mon, 19 Dec 2016 17:35:18 +0000
111 dgit (2.11) unstable; urgency=medium
114 * dgit-user(7): Better explanation of combined suites (comma syntax).
115 Thanks to Sean Whitton for review and suggestions.
116 * dgit(1), dgit(7): Better reference docs for combined suites.
117 * dgit(1): Improve formatting of rpush section.
120 * Replace make in Test-Depends with build-essential. Most of the tests
121 do in fact run dpkg-buildpackage which bombs out if build-essential is
124 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 08 Nov 2016 22:41:29 +0000
126 dgit (2.10) unstable; urgency=medium
129 * Support the Debian *-security suites.
130 * New comma-separated multiple-suite merging facility (readonly),
131 so that users can easily track "jessie, or jessie-security".
132 * dgit-user(7): Suggest `dgit clone P jessie,-security'.
135 * Cope when an orig tarball is a tarbomb. Ie, if it contains
136 other than one single directory toplevel. Closes:#843422.
137 * Actually honour the branch name, if we are on dgit branch, to specify
138 the suite, as documented in the manpage.
139 * When cloning a distro which has no git server, correctly leave
140 the user on the local dgit branch, not on `master'.
141 * Fix an unconditional print that was supposed to be a printdebug:
142 origs <blah>.orig.tar.gz f.same=1 #f._differ=-1
143 * Print a slightly better message if .git found in orig tarball(s).
146 * Test suite: Add fakeroot and make to Test-Depends. These aren't
147 necessarily pulled in by anything else. (dpkg-dev Recommends
148 build-essential. But we don't actually need build-essential.)
150 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 08 Nov 2016 01:08:51 +0000
152 dgit (2.9) unstable; urgency=medium
155 * During push, automatically calculate which .origs are required,
156 so user never needs [--ch:]-sa or [--ch:]-sd. Closes:#829116.
157 * New import-dsc feature.
158 * New option --dgit-view-save= for split view quilt modes.
159 In particular, means that the output of a split view quilt-fixup
160 is left somewhere useful.
161 * dgit clone: Set timestamps in cloned tree to a single unified time.
162 This makes it less likely that the user will trip over any
163 timestamp-dependent FTBFS bugs (eg #842452).
164 * Support dgit --delayed= push (with a warning in the manpage
165 about possible skew).
166 * dgit gbp-build will arrange to let gbp buildpackage generate
167 .orig tarballs if it seems applicable. Closes:#841094.
169 Documentation improvements:
170 * dgit-*(7). Many new tutorial manpages, several written and many
171 improved by Sean Whitton.
172 * dgit(7): Substantial updates, including documenting split view.
173 * dgit(1): Better cross-references.
174 * dgit(1): Remove obsolete workflow information.
175 * dgit(1): Improved BUGS section.
176 * Fix changelog entry for SIGPIPE to correctly mention
180 * Split brain mode: Fix --new. Closes:#842577.
181 * Properly look for .origs etc. in .., fetching them less often.
183 * Reject `dgit pull' in split view quilt modes, to avoid
184 creating unfortunate wreckage on non-dgit-view branches.
186 * Cope when cloning suite which doesn't receive uploads,
187 like testing. Closes:#842621.
188 * Properly fetch all archive dgit view tags, as we intended.
189 * Actually provide a -p (--package=) option (!)
192 * Test suite: Explicitly configure user.name and user.email, so
193 that tests work when environment doesn't have defaults.
194 Closes:#842279 (I hope).
196 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Mon, 31 Oct 2016 12:47:18 +0000
198 dgit (2.8) unstable; urgency=medium
200 * When in split build mode for `gbp-build' or `build', run
201 mergechanges as is required. Closes:#841990.
202 * Test suite: build-mode-*: Check that right .changes comes out
204 * Defend against debian/patches/series being an unusual object, in case
205 dpkg-source doesn't, in absurd git-apply fallback.
207 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 25 Oct 2016 17:29:23 +0100
209 dgit (2.7) unstable; urgency=medium
211 Absurd bugfix for serious bug:
212 * Work around `git-apply' problems (eg #841865, #829067) exposed by
213 `gbp pq import' (#841866) by sometimes falling back to an emulation of
214 git-apply in terms of dpkg-source --before-build. Closes:#841867.
217 * dgit(1): Reorder the options, moving more important ones earlier.
218 * dgit(1): Some more info about --deliberately.
219 * Provide various --force-something options. Please don't use them.
221 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Mon, 24 Oct 2016 02:37:28 +0100
223 dgit (2.6) unstable; urgency=medium
225 Fixes to HTTP handling:
226 * Check for non-2xx HTTP status codes from ftpmaster api server.
227 * Always honour --curl= and --curl:.
229 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 23 Oct 2016 14:57:22 +0100
231 dgit (2.5) unstable; urgency=low
234 * Do not crash in split brain quilt modes when the two brains are
235 actually identical. (Eg --quilt=gbp with no patches.) Closes:#841770.
236 * Switch to new archive/ tag format by default, even in
237 non-split-brain mode.
238 * Provide --gbp and --dpm as aliases for --quilt=gbp and --quilt=dpm.
241 * dgit-maint-merge(7): New tutorial manpage from Sean Whitton.
244 * Introduce setup/gnupg, to help work around gnupg2 bug #841143
245 and improve performance by amortising gnupg migration cost.
248 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 23 Oct 2016 13:20:23 +0100
250 dgit (2.4) unstable; urgency=low
253 * split brain cache: Fix a wrong implicit reference to $_.
255 * split brain cache: Make sure to write reflog entries for cache updates
256 even if the eventual tree (and therefore commit) is the same.
257 Otherwise, after updating dgit, the cache might have the right answer
258 but not be refreshed even by a build.
259 * dgit gbp-build: No longer invent a --git-debian-branch option.
260 Usually the user is a maintainer using split brain, and we should rely
261 on their own gbp configuration to specify the right check.
265 * dgit(1): Document which --ch: options are a good idea.
267 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 20 Oct 2016 16:31:54 +0100
269 dgit (2.3) unstable; urgency=low
271 * With --overwrite, do not check all sorts of tags (which may
272 not exist, or might contain wrong things). Closes:#841101.
273 * When generating pseudomerge in quilt split brain mode due to
274 --overwrite, actually include the version number in the commit
277 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 18 Oct 2016 01:58:05 +0100
279 dgit (2.2) unstable; urgency=low
281 * Fix config relating to Debian to actually make split brain mode
282 work. Closes:#841085.
283 * Detect SIGPIPE (and SIGCHLD) being blocked or ignored.
286 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Mon, 17 Oct 2016 17:31:18 +0100
288 dgit (2.1) unstable; urgency=low
290 * Do not crash due in clone to failure to handle dpkg-parsechangelog
291 SIGPIPE. Closes:#840989. Avoids:
292 dgit: failed command: dpkg-parsechangelog --format rfc822 --all
293 dgit: subprocess died due to fatal signal PIPE
294 * git- prefixes: Fix some occurrences of `git-foo' in infrastructure,
295 messages, and test suite. Filter out .../git-core from PATH in
296 test suite so that we catch future occurrences.
298 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 16 Oct 2016 19:05:14 +0100
300 dgit (2.0) unstable; urgency=low
303 * dgit sbuild: does not pass -A to sbuild. Consequently the default
304 build is now simply sbuild's default. With older sbuilds it was
305 possible to override dgit's -A by passing another option. But this
306 has been changed recently and now this default setting is very awkward
307 to change for the dgit user.
308 * dgit gbp-build: Make --quilt=gbp the default. (See below.)
309 * New tag format (for dgit view) archive/debian/VERSION.
312 * --quilt=gbp, --quilt=dpm, --quilt=unpacked: Introduce facility for
313 split view (dgit/mainiainer view), to improve compatibility with some
316 New checks and improved behaviours in dgit:
317 * When running dpkg-buildpackage, cope if user specified -g or -G.
318 * dgit sbuild: check that the set of .changes files found is as we
319 expect, before calling mergechanges. Re:#800060.
320 * dgit sbuild: Rename the used-up .changes files to `.inmulti' to
321 avoid accidental use of the wrong one (by software, or by users).
322 * dgit sbuild: Check that the binary .changes file doesn't contain a
324 * Introduce --rm-old-changes to delete previous builds' changes files.
325 * Remove any pre-existing _source.changes file before building source,
327 * No longer tolerate a multitude of .changes files when doing push.
328 Instead, insist on a single one. Closes:#800110.
329 * dgit sbuild no longer deletes extranious .changes files; instead
330 we rely on --rm-old-changes, or failing that, fail early.
331 * When doing quilt linearisation, treat upstream .gitignores not
332 in the toplevel the same way we treat ones in the toplevel.
333 * When automatically generating quilt patch, honour GIT_COMMITTER_DATE
334 for filename creation (makes filename deterministic in test suite).
335 * New --overwrite option, replaces need to for user to use
336 git merge -s ours. Closes:#838718.
337 * When generating quilt patches from git commits, make patches that
338 look quite like git-format-patch output (rather than strange things
339 based on an obselete interpretation of DEP-3).
340 * When generating quilt patches from git commits, honour (and strip)
341 any Gbp-Pq headers (that we understand).
342 * Several dgit-generated commits now have slightly better annotations
343 from dgit about what it was doing.
344 * Before committing to push, check that .dsc and .changes correspond.
346 * Better error message if non-split-brain patch stack no longer
347 applies (due to new upstream version, or user messing with it).
349 * Better error message if HEAD contains changes unrepresentable
350 by `3.0 (quilt)'. Closes:#834618.
351 * Much better error message when HEAD and .dsc do not match.
355 * dgit-repos-policy-debian: Better error handling.
356 * dgit-repos-policy-debian.: fix git-cat-file-handling with multiple
358 * dgit-infrastructure has, and uses, its own copies of the perl modules.
359 This avoids introducing a versioned dependency between dgit and
360 dgit-infrastructure (and also makes it easier to test cross-version
364 * Document the dgit-distro.DISTRO.quilt-mode config setting.
365 * Clarify the --clean= options' documentation. Closes:#800054.
366 * Discourage use of the --PROGRAM:OPTION escape hatch. (Apropos
367 of various bug reports including #800060 and #833025.)
368 * Document the expected form of HEAD for each --quilt= mode.
371 * When cleaning up after failed clone, stat the to-be-cleaned-up
372 directory before running rmtree on it. Closes:#796773.
373 * Do not call "warn" on failure of cleanup handler in END block
374 (since warn has been made fatal and aborts the cleanup chain).
375 * Print better error message (with `fail' rather than `die') if
376 `dgit clone' cannot create the destination directory.
377 * Properly substitute $changesfile in one of the `You can retry'
378 messages. Closes:#800078.
379 * Pass --ch:* and -v options to dpkg-buildpackage when building
380 source. Fixes bad Perl poetry syntax. Closes:#829121.
381 * When synthesing a commit from a .dsc from the archive, stop
382 internal git reset from printing a confusing message about HEAD.
383 * Turn off git gc in the private working areas.
384 * Do not fail to do some important quilt processing in some
386 * Fix two calls to chdir without proper error checking.
387 * Fix a couple of bugs in error reporting.
388 * Fix several bugs in .orig detection/recognition.
389 * Tidy up refs/dgit-fetch/ after dgit fetch (if successful).
390 * Fix handling of in-archive copies.
391 * Don't break if user has push.followTags=true. Closes:#827878.
392 * Arrange for the special dgit remote to be skipped by git fetch --all
393 etc. And no longer configure a fetch spec, since it won't work
394 anyway. Closes:#827892.
395 * Allow local git config options to override user-global ones,
396 as is proper. Closes:#835858.
397 * When generating patch filenames from titles, first transliterate
398 them (lossily) to ascii. Closes:#834807.
401 * When sbuild fails, do not crash due to sed not finding the log
402 file. Instead, simply tolerate the absence of the log file.
403 * Put --no-arch-all in build-modes-sbuild act, not only its real_act.
404 Cosmetic change only.
405 * Set GIT_COMMITTER_DATE and GIT_AUTHOR_DATE and increment them
406 explicitly in drs-push-rejects test. This avoids date dependencies
407 which can cause that test to fail on fast computers.
408 * Remove some spurios .debs from the example_1.0.tar.
409 * Increase sqlite_busy_timeout in debpolicy-dbretry, because old
410 zealot is very slow and we need to give the other processes time
411 to rollback and release the lock.
412 * Test quilt single-debian-patch.
413 * Provide `tartree-edit gitfetchinfo' etc. to help with comparing
414 different test case git working tree tarballs.
415 * Test dgit-repos-policy-debian with multiple (identical, as it happens)
417 * Provide better log output for certain failures.
418 * Many new tests (especially for new functionality).
419 * Add missing debhelper (>=8) to test suite's global Depends.
420 * tstunt arrangements: Fix mishandling of PERLLIB, etc.
421 * tstunt-parsechangelog: Produce Timestamp field (like official one
423 * Do not fail when git requires --allow-unrelated-histories.
425 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 16 Oct 2016 12:12:50 +0100
427 dgit (1.4) unstable; urgency=high
430 * Unbreak --dry-run (`exiting subroutine via next', broken in
431 ac221d67, bug released in 0.22).
432 * When running git-add in commit-quilty-patch, properly escape
433 filenames (which git-add treats as glob patterns).
434 * When running git-add in commit-quilty-patch, use -f and sometimes -A,
435 so as to avoid being broken by any .gitignore, etc.
436 * When quilt linearisation fails, print the right information in
437 the error message. (This has been broken forever.)
438 * Cope properly with `3.0 (quilt)' with single-debian-patch.
439 Closes:#796016. (Still does not work with wheezy's dpkg-source, so
441 * With dgit sbuild, pass our -d before the user's arguments, so that
442 the user can override it. Closes:#796019.
444 New checks and improved behaviours:
445 * Detect and reject git trees containing debian/source/local-options
446 or debian/source/local-patch-header.
447 * In --dry-run mode, _do_ actually run dpkg-source --commit so that we
448 actually do construct the quilt fixup commit; instead, honour
449 --dry-run by avoiding pulling it back to your HEAD.
450 * quilt-fixup checks that the git tree is clean, as for build-prep.
453 * In dgit(7), discuss binaries and documentation present in upstream but
454 removed by rules clean.
457 * Run quilt-fixup with -wgf in distropatches-reject,
458 so that we don't need build-depends.
460 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sat, 22 Aug 2015 15:31:02 +0100
462 dgit (1.3) unstable; urgency=high
465 * In option parser test `@ARGV' not `length @ARGV'. Closes:#795710.
466 * Properly quote package name when constructing regexp in
467 complete_file_from_dsc. Closes:#795736. Also, grep the code for
468 likely similar problems elsewhere and improve a (harmless) instance in
472 * If a .orig in .. is a symlink, hardlink the link target into our
473 private unpack directory, rather than the link itself (since latter
474 won't work if the symlink is relative). Closes:#795665.
475 * Test suite: Fix t-restriction-x-dgit-schroot-build in non-adt mode.
476 * Infrastructure: Improve an error message in dgit-repos-policy-debian.
478 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 16 Aug 2015 17:51:02 +0100
480 dgit (1.2) unstable; urgency=high
483 * Honour *.clean-mode configuration setting for --clean= mode.
484 * No longer require option values to be cuddled: support `--opt val' and
485 `-o val'. Closes:#763332.
489 * Document that tags are in DEP-14 format, and that they
490 are used for authenticating pushes.
491 * Correct cross-reference to point to browse.d.d.o.
492 * Move dgit.default.* to main CONFIGURATION section.
495 * Add missing close of #793060 to changelog for version 1.1.
497 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Fri, 14 Aug 2015 18:27:20 +0100
499 dgit (1.1) unstable; urgency=medium
502 * When source package contains things called .git (even files, and even
503 in subdirectories), remove them. Closes:#793671.
504 * Work around curl -sS -I printing `HTTP/1.0 200 Connection established'
505 before the actual header, so dgit works with https_proxy set (!)
506 * --new is needed for read access to packages in NEW, too. Document
507 this, and make it work properly.
508 * Work around #793471 (madness with $SIG{__WARN__} and Perl's system
509 builtin): move $SIG{} setting into setup_sigwarn in Dgit.pm, and
511 * When invoking git-buildpackage via dgit gbp-build, consider our
512 command line arguments when massaging the dpkg-buildpackage arguments,
513 so that we don't end up giving dpkg-buildpackage contradictory
515 * Cope with new git-buildpackage which provides gbp, rather than the
516 eponymous command, on PATH.
519 * Honour dgit-distros.DISTRO.cmd-CMD and .opts-CMD. Closes:#793427.
520 * Make configuration able to prevent dpkg-mergechangelogs setup.
521 * Provide dgit setup-new-tree (like dpkg-setup-mergechangelogs
522 but only does it if not disabled in config).
523 * Set up git user.email and user.name from distro access config
524 or DEBEMAIL/DEBFULLNAME. Closes:#793410.
525 * When key to use not specified any other way, use the debian/changelog
526 trailer line. Closes:#793423.
527 * Honour --git= (mostly).
530 * Fix some manpage typos. [ Richard Hartmann ]
531 * Manpage said that --clean=check was -wn but that is --clean=none;
532 correctly document that --clean=check is actually -wc.
533 * Document that up to -DDDD (not just -DD) is meaningfully different.
534 * Document that -cname=value applies only for this run.
535 * Improve manpage comment about defining a new distro.
536 * Document that --quilt=linear is the default for Debian.
537 * Fix a formatting problem in --build-products-dir= doc.
538 * In manpage, do not seem to imply that NMU should be of only one
540 * Qualify to Debian the manpage comment about how to do NMU.
541 * In discussion on how to start using dgit when already using git, do
542 not imply/assume that existing git history will have identical trees
544 * Remove stray sentence in config section of manpage.
545 * Manpage: Clarify wording of readonly config.
546 * Manpage: Better cross-references for -k and keyid.
547 * dgit(7): No longer say that dgit-repos lives on Alioth.
550 * Introduce more sophisticated protocol negotiation for rpush.
551 * Do not quote `:' in shellquote.
552 * Print a supplementary message when push fails, giving advice to
553 the user about how to retry. Closes:#793144.
554 * Slurp in entire git config, for better performance.
555 * Rename `git-build' operation to `gbp-build' to make it clearer what
556 it's for. Keep the old name as an alias.
557 * Show `dgit sbuild' in usage message.
558 * When we are using dpkg-buildpackage to clean before using it to also
559 do the build, let it do its cleaning thing as part of its run, rather
560 than running it twice. When we are _not_ supposed to be using
561 dpkg-buildpackage to clean, but we are running it to do the build,
562 pass -nc. Closes:#793060.
563 * Also suppress spurious runs of the clean target when building using
565 * When exec fails, always print the program name in the error message.
568 * Infrastructure: Get mirroring right for fresh repos of existing
571 Packaging, cleanups, debugging and test suite:
572 * Fix Vcs-Git and Vcs-Browse to refer to chiark. (The dgit-repos on
573 alioth aren't suitable right now because the master there can
574 currently only be updated with an actual upload, ie dgit push.)
575 * Make warnings fatal in dpkg-repos-admin-debian, dgit-ssh-dispatch
576 (using setup_sigwarn).
577 * tstunt/dpkg-parsechangelog: Make warnings fatal (directly).
578 * tstunt/dpkg-parsechangelog: Do not complain if PERLLIB is empty.
579 * Test suite: Honour DGIT_TEST_DEBUG=''.
580 * With -DDDD, print out all gitcfg references (copious!)
581 * Fix a debug message in the obsolete sshpsql archive access driver.
582 * Test suite: More automatic enumeration of tests.
583 * Test suite: Provide tests which check that all our various build
584 operations run the right targets as expected (ie, that we are massaging
585 the arguments to dpkg-buildpackage, and suppressing our clean target,
588 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Mon, 27 Jul 2015 16:34:31 +0100
590 dgit (1.0) unstable; urgency=medium
593 * Switch to new production git repositories for reading.
594 (this can no longer divert to alioth). Public readonly access
595 now works. Closes:#791447.
596 * Memoise git config lookups (big speedup!)
597 * Provide -wdd aka --clean=dpkg-source-d. Closes:#792433.
598 * Provide -wc aka --clean=check.
601 * Remove some obsolete caveats from BUGS.
602 * Reorganise and complete the configuration section.
603 * Remove obselete comment about DMs not being able to push.
604 We have, for now, a way to add keys manually. Closes:#720173.
607 * Remove configuration relating to alioth.
608 * Provide for different access mechanisms when pushing.
609 * Provide for configurable git url suffix.
610 * Allow git-url to be '' to force fallback to git-proto etc.
611 * Provide for checking git presence via http[s].
612 * Do some quoting on debug output (needed if the server might not
613 be trustworthy and might send us bad stuff).
614 * Talk to push.dgit.debian.org, rather than the .debian.net alias.
617 * Provide for mirroring git updates to a different server.
618 * Provide cgit-regen-config command for cgi-grnet-01.
619 * Make dgit-ssh-dispatch not spew (harmless) warnings if caller
620 tries for a shell session (ie SSH_ORIGINAL_COMMAND not set).
623 * Remove an obsolete comment from the code.
624 * Improve an error message from dgit-repos-policy-debian.
625 * Test suite: Break out t-make-hook-link.
626 * Fix a manpage typo.
628 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 19 Jul 2015 22:15:53 +0100
630 dgit (0.30) unstable; urgency=high
632 INCOMPATIBLE CHANGES:
634 * Client uses new infrastructure:
635 - Check for new dgit git service on dgit-git.debian.net (ie
636 gideon.debian.org), with transition plan based on diversion feature.
638 - Old versions of dgit will stop working when the server-side handle is
641 * dgit git trees no longer contain .pc for format `3.0 (quilt)' source
642 packages. Closes:#764606.
643 - It is deleted whenever we find it.
644 - Older versions of dgit will choke on trees without .pc.
645 - (When doing quilt fixup, we recreate a suitable .pc in a temporary
646 directory so that we can do dpkg-source --comit.)
648 * All users are urged to upgrade ASAP.
650 Other significant improvements:
652 * When generating quilt patches, try to linearise the git history into a
653 series of individual new patches for debian/patches. Closes:#770710.
655 * When receiving a push with dgit-repos-server, update the server's
656 refs/heads/master if we are pushing to what the distro regards as a
657 relevant branch, and the push would ff master. Closes:#728209.
659 * For non-Debian distros, distro version release tags contain distro
660 name a la DEP-14 (rather than hardcoding `debian/').
662 * Set up a merge driver for debian/changelog. Closes:#769291.
664 * --clean=git and --clean=none cause dgit to pass -nc to
665 dpkg-buildpackage, suppressing calls to the package's clean target.
666 Also, expand the documentation in this area slightly. Closes:#768590.
668 * Provide --clean=git-ff (aka -wgf), which is useful for dgit itself (!)
672 * Reduce some noise output and improve the clarity of some messages.
673 * Be more careful about tag updates during fetch: only update tags
674 referring to uploads to distro we are trying to fetch from.
675 * Change realpath dependency to `coreutils (>= 8.23-1~) | realpath'
680 * Fix handling of rmadison-based and gitless distros (e.g., Ubuntu).
681 * Add missing `gpgv' to test dependencies in debian/tests/control.
682 * Strip `-b <branch>' from contents of Vcs-Git header, when setting up
683 the vcs-git remote. Closes:#759374.
684 * Do not offer wget as an alternative dependency to curl. We always
685 unconditionally invoke curl and have no code to use wget.
687 * Complain about lack of cuddled values for value-taking single-letter
688 options, rather than thinking the user meat an empty value.
690 * Reject (rather than ignoring) further options merged witth -wn, -wg,
692 * Fix inaccurate error message when archive's git hash is not an
693 ancestor of git repo's git hash.
694 * Detect and bomb out on vendor-specific `3.0 (quilt)' patch series.
695 * Fix the rules clean target to remove test results and output.
697 Documentation improvements:
699 * Break out dgit(7) from dgit(1).
700 * Provide example workflow for dgit rpush. Closes:#763334.
701 (Also part of the fix for #768470.)
702 * Document that dgit repos are cloneable with git, in dgit(1)
703 section MODEL. [Andreas Barth.] Closes:#768470.
704 * Better documentation for quilt series handling.
705 * Document under `dgit push' that it is best to build with dgit too.
707 * Other minor clarifications and improvements.
709 Behind-the-scenes work:
711 * Use ftpmasterapi archive query method.
712 (Closes:#727702. Also partly obsoletes #768470.)
713 * New dgit-infrastructure binary package containing dgit-repos-server et
714 al. Client users probably don't want this stuff. Also, it provides a
715 convenient way to publish the dependencies.
716 * Many many bugfixes to the server side (dpkg-repos-server et al.).
717 * Add :..; prefix to ssh remote commands, for the benefit of future
718 forced command wrappers. Implicitly, this defines a new ssh-based
719 command protocol. Closes:#720174, #720175.
720 * Distro access configuration handling changes (should not be noticeable
722 * In places, significant restructuring or tidying up.
723 * Turn all perl warnings into errors using $SIG{__WARN__}.
725 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 05 Jul 2015 01:34:55 +0100
727 dgit (0.22.1) unstable; urgency=high
729 * Use Dpkg::Version::version_compare everywhere, not
730 Dpkg::Version::version_compare_string. The latter is entirely wrong,
731 meaning that dgit would get many version comparisons wrong.
734 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 04 Nov 2014 12:46:40 +0000
736 dgit (0.22) unstable; urgency=medium
739 * Clone removes destination directory on error. Closes:#736153.
740 * Work with wheezy-backports (and keep squeeze-backports working too).
742 * Work in read-only no-git-history mode with Ubuntu. You still have
743 to pass -dubuntu. Closes:#751781.
744 * Use mirror.ftp-master.debian.org DNS alias rather than coccia.
746 * Check hashes of files ourselves rather than running dget to
747 re-retreive the .dsc.
748 * Check SHA-256 of .dsc against hash from archive_query (ie projectb)
749 rather than letting dpkg-source do a signature verification.
750 Closes:#737619. Closes:#737625.
751 * Treat .dsc as bytes, just like everything else, rather than letting
752 HTTP::Message convert it to a Perl unicode string which the rest of
753 the program mishandles. Closes:#738536.
756 * Include canonicalised suite name in signed tag message.
757 * Mention cross-version dgit rpush incompatibility in manpage.
758 * Check for rpush protocol version incompatibility and crash early
760 * New script tests/using-intree for running tests on the source tree.
761 * Do not spew diff output to terminal (by default). Print sensible
762 message instead. Closes:#736526.
763 * Print better message for lack of configuration settings.
764 * Document that dgit rpush needs gnupg and your public key on the build
765 host. Closes:#736529.
766 * Fix a manpage reference to `--dget=' where `--dgit=' was intended.
767 * Provide t-archive-process-incoming and t-archive-query subroutines for
768 regression test scripts to use.
769 * Print better message for unknown operations.
770 * Provide `dgit clean'. Closes:#736527.
771 * When cloning, set up a remote `vcs-git' from the package's Vcs-Git
772 (and put an appropriate caveat in the manpage). Closes:#740687.
774 * Improve error message for .dsc having already been signed (iff
775 using libdpkg-perl 1.17.x). Closes:#731635.
776 * Improve error message for .dsc parsing failures more generally.
777 * Better reporting of child exit statuses (esp. deaths due to signals).
778 * In rpush, on protocol error talking to build host, check if the
779 subprocess died and report differently if so. Closes:#736528.
780 * Fixed a manpage typo.
781 * When tests invoke dgit, use --dgit= so that subprocesses use our
782 dgit rather than system one.
783 * Add a test for dgit rpush.
785 Major new feature, currently stalled awaiting server infrastructure:
786 * dgit-repos-server: New program for receiving signed-tag-based
787 pushes. Corresponding support in dgit itself, but not currently
788 used by default for any distro.
789 * Bring forward push of the version tag ref so it happens alongside
790 the push of the suite branch ref.
791 * New git-check and git-create methods "true" which are no-ops.
792 * test-dummy-drs `distro': for testing dgit and dgit-repos-server.
794 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 19 Aug 2014 11:24:02 +0100
796 dgit (0.21) unstable; urgency=medium
798 Bugfixes relating to unclean trees:
799 * Run a clean (of the specified type) before any build operation; do
800 this with `dpkg-buildpackage -T' clean if necessary, so -wd now works
801 with all the building methods.
802 * Refuse to do quilt fixup (explicitly requested, or as a result of
803 build) if the tree contains ignored files. Closes:#731632.
805 Error message improvements:
806 * Use failedcmd to report errors when ssh psql fails. Closes:#734281.
807 * failedcmd prints $us, not $_[0] - ie, dgit doesn't pretend,
808 in the error message, to be its child.
809 * Do not report the (irrelevant) $? when madison parsing fails.
811 Better workflow flexibility:
812 * Provide --build-products-dir option (and corresponding semantics
813 for -C) to specify where to find the files to upload. Closes:#731633.
815 Support for Debian backports suites:
816 * New quirks infrastructure in configuration and internals,
817 for suites (or perhaps distros) which are a bit like others.
818 * Use correct default archive location.
819 * Compute "-v" option default value correctly.
822 Packaging improvement:
823 * Add `Testsuite: autopkgtest' to debian/control. (This will only have
824 the right effect with recent enought dpkg; it will generate a harmless
825 warning with earlier versions of dpkg.)
827 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 19 Jan 2014 02:14:25 +0000
829 dgit (0.20) unstable; urgency=high
831 * Use newest (not oldest) version currently in suite when calculating
832 what value to use for -v<version> by default. Closes:#732781.
834 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sat, 21 Dec 2013 19:13:56 +0000
836 dgit (0.19) unstable; urgency=low
839 * Provide "test-dummy" distro with "dummycat" access method.
840 * Provide a selection of autopkgtest (DEP-8) tests.
842 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Wed, 27 Nov 2013 18:27:17 +0000
844 dgit (0.18.2) unstable; urgency=high
846 Bump archive upload urgency to high.
848 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 24 Nov 2013 17:42:57 +0000
849 dgit (0.18.1) unstable; urgency=low
852 * sshpsql archive query method passes LANG=C. Closes:#729788.
853 * Subcommand program or argument options containing hyphens work.
854 (Eg, --dpkg-buildpackage:blah was previously incorrectly rejected.)
858 * Depend on curl | wget, as dget needs one of those. (The dput package,
859 which contains dget, doesn't require them because dput itself works
862 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 24 Nov 2013 17:36:03 +0000
864 dgit (0.18) unstable; urgency=low
867 * Remote push (dgit rpush), a la debsign -r. Closes:#721185.
870 * dgit build, by default, uses the archive to find out what the correct
871 -v<version> option is to pass to dpkg-genchanges. Closes:#727200.
872 * Abolish the sshdakls method and replace it with sshpsql: that is, ssh
873 (to coccia, by default) and run sql commands on the ftpmaster
874 database. This is faster and has fewer bugs but is vulnerable to db
875 schema changes. Closes:#726955. Closes:#720170. Closes:#720176.
876 * When generating git tags, quote the (uncanonicalised) changelog's
877 Distribution field as the suite.
878 * Command execution reports from --dry-run go to stderr.
881 * Support --gpg=... to provide a replacement command for gpg.
882 * Support --ssh=... and --ssh:... to affect how we run ssh.
885 * When using sbuild, pass the arguments to mergechanges in the right
886 order so that we use the correct Description (the _source one,
887 not the one from sbuild which didn't get e.g. -v<version>).
888 * push actually takes an optional suite, like it says in the synopsis.
890 * Fix dgit --damp-run sbuild to actually work.
891 * Fix the "shellquote" internal subroutine. The bugs in it ought not to
892 have caused any real trouble in previous versions of dgit.
894 Documentation and message fixes:
895 * manpage: Clarify comments about orig tarballs. Closes: #723605.
896 * manpage: Remove comment in BUGS about lack of policy docs
897 for Dgit field, which is specified now. Closes:#720201.
898 * manpage: Make discussion of --existing-package less scary. The
899 default archive access method no longer needs it. Closes:#720171.
900 * Mention "git merge", not "git-merge", in helpful message.
903 Internal and debugging improvements:
904 * Report chdir actions in debugging output.
905 * Improvements to implementation of --dry-run and --damp-run.
906 * Some code motion and cleanups.
908 Note: changelog entries for the following versions, which were uploaded
909 to Debian experimental, have been collapsed into this single entry:
910 0.18~experimental2 0.18~experimental1
911 0.17~experimental7 0.17~experimental6 0.17~experimental5
912 0.17~experimental4 0.17~experimental3 0.17~experimental2
914 0.16~experimental3 0.16~experimental2 0.16~experimental1
915 We do describe here all the changes since 0.17.
917 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sat, 09 Nov 2013 10:12:13 +0000
919 dgit (0.17) unstable; urgency=high
921 * Do not grobble around in .git/refs/; instead, use git-show-ref.
922 This avoids breaking when git makes packed refs. Closes:728893.
923 * Clarify error message for missing refs/remotes/dgit/dgit/<suite>.
925 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 07 Nov 2013 00:02:47 +0000
927 dgit (0.16) unstable; urgency=high
929 * Format `(3.0) quilt' fixup does not mind extraneous other files
930 in the build tree (e.g., build products and logs). Closes: #727053.
931 * Set autoflush on stdout, to get better ordering of debugging
932 etc. output when stdout is redirected.
933 * New --damp-run mode, for more convenient and fuller testing etc.
935 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Tue, 22 Oct 2013 13:06:54 +0100
937 dgit (0.15) unstable; urgency=low
939 * Better handling of packages pushed using dgit and stuck in NEW.
940 (And, use of `--new' is not needed with fetch.) Closes: #722199.
941 * More comprehensive warnings in many cases of archive skew.
942 * Implement `dgit help' as well as `--help'. Closes: #721661.
943 * Provide `dgit version' and `--version'. Closes: #721654.
945 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 12 Sep 2013 00:14:05 +0100
947 dgit (0.14) unstable; urgency=low
949 * Include package name in tag message.
950 * Create directory .git/dgit when needed during build. Closes: #721428.
951 * Add Vcs-Git and Vcs-Browser [Richard Hartmann]. Closes: #721404.
952 These fields refer to the development branch, "master", on alioth,
953 not to the dgit suite refs (which are not accessible to git clone).
955 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 01 Sep 2013 18:30:44 +0100
957 dgit (0.13) unstable; urgency=low
959 * Reuse already-downloaded .orig files after checking their hashes.
960 Closes: #720526. (This introduces a dependency on Digest::SHA.)
961 * Do not always pointlessly fetch the .dsc twice. (That code was
962 erroneously duplicated during editing, apparently.)
963 * Remove DGET_UNPACK from the environment in case the user has set it.
964 * Remove scary warning from Description.
965 * When uploading to Debian, tell dput to upload to "ftp-master". This
966 avoids problems with derivatives whose dput has a different default.
968 * Fix some bugs in dgit fetch --dry-run which made dgit push
969 --dry-run often not work at all.
970 * Update the local tracking branch for the dgit remote, when pushing.
972 * Fix references in manpage to old Vcs-Dgit-Master field name.
973 * Reorganise manpage sections to be in a more conventional order.
974 * New manpage section on FILES IN THE SOURCE PACKAGE BUT NOT IN GIT.
977 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 29 Aug 2013 00:27:23 +0100
979 dgit (0.12) unstable; urgency=low
981 * Cope with packages with epoch. Closes: #720897.
982 * Improve error message for non-fast-forward push. Closes: #720896.
983 * New --ignore-dirty option to skip noncritical check. Closes: #720895.
984 * New --no-quilt-fixup option to suppress quilt fixup. RTFM.
985 * Add Closes line for #720595 to changelog entry for 0.11.
987 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Mon, 26 Aug 2013 16:50:39 +0100
989 dgit (0.11) unstable; urgency=low
991 * Location of dgit-repos is now git.debian.org:/git/dgit-repos/repos.
992 Closes: #720525. The rename on the server side will break older
994 * Fix bug which would make quilt patch fixup fail if git status
996 * Autogenerated quilt patch fixup patch Description contains several
997 recent git commits, rather than implying that the patch corresponds
998 exactly to the top git commit.
999 * Use "ftp.debian.org" not "http.debian.net" as the default Debian
1000 archive. (http.debian.net tends to defeat certain kinds of cacheing,
1001 and can also have more skew.)
1002 * dgit build uses dpkg-buildpackage; there is a dgit git-build
1003 for using git-buildpackage. Closes: #720595.
1004 * Better error message for use of UNRELEASED suite. Closes: #720523.
1005 * Do not canonicalise suite more than once. Related to: #720526.
1006 * Fix a badly open-coded copy of check_not_dirty. Closes: #720524.
1007 * Fix some bugs in building (eg build-source would fail to do the quilt
1008 fixup; the --clean check in build was wrong).
1009 * Add missing dependency on realpath.
1010 * git-build (git-buildpackage wrapper) does not bother canonicalising
1011 the suite if --git-ignore-branch is used.
1013 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 25 Aug 2013 17:00:43 +0100
1015 dgit (0.10) unstable; urgency=low
1017 * Create .pc/applied-patches - do not empty it (!)
1019 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sun, 25 Aug 2013 00:51:50 +0100
1021 dgit (0.9) unstable; urgency=low
1023 * New cleaning arrangements.
1024 * More comprehensive workaround for `3.0 (quilt)'.
1025 * In push, double-check the .changes against the changelog.
1026 * Better error when source package contains .git. Closes: #720555.
1027 * Change our .dsc field name to `Dgit'. Relevant to #720201.
1028 * Fix bug handling our synthetic merges when we see them in
1029 the remote suite branch.
1030 * `3.0 (quilt)' fixup creates .pc/applied-patches since modern
1031 dpkg-source creates it even though old ones didn't always.
1033 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sat, 24 Aug 2013 18:49:02 +0100
1035 dgit (0.8) unstable; urgency=low
1037 * Fix comparison of archive's .dsc's hash and git branch head
1039 * When creating repos in dgit-repos (using the ssh-cmd method),
1040 copy _template rather than using mkdir and git init.
1042 * In push, do git fetch as well as archive fetch, or archive
1045 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Fri, 23 Aug 2013 12:24:09 +0100
1047 dgit (0.7) unstable; urgency=low
1049 * If dak ls, or rmadison, reports multiple versions, look for them
1050 all, and pick the newest .dsc that doesn't give 404.
1051 * Manpage formatting fix.
1052 * Name the local remote tracking branch remotes/dgit/dgit/<suite>
1053 so that we avoid a warning from git about ambiguous branch names.
1055 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 22 Aug 2013 18:29:10 +0100
1057 dgit (0.6) unstable; urgency=low
1059 * Allow fetching when archive has out-of-date git hash in .dsc.
1062 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 22 Aug 2013 16:02:10 +0100
1064 dgit (0.5) unstable; urgency=low
1066 * Upload to unstable, as this version mostly works. (All the RC
1067 bugs of which I'm aware are now properly represented in the BTS.)
1069 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 22 Aug 2013 15:38:00 +0100
1071 dgit (0.4~pre2) experimental; urgency=low
1073 * Mangle debian/<version> tags the way git-buildpackage does
1074 (as of git-buildpackage 0.5.5, 3c6bbd0f4992f8da).
1075 * Support dgit-distro.<distro>.keyid config option.
1076 * Revert change to ssh to alioth CNAME, as the recommended CNAME
1077 is to something with no write access to the fs and the new CNAME
1078 has not yet been set up. This reintroduces #720172 :-/.
1080 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 22 Aug 2013 15:31:17 +0100
1082 dgit (0.4~pre1) experimental; urgency=low
1084 * Use dgit.debian.net vhost on alioth. Closes:#720172.
1085 * Usage message. Closes:#720085.
1086 * Provide "dgit sbuild".
1087 * Assorted manpage fixes and improvements.
1088 * Fail if a required config item is missing.
1089 * Much better error messages.
1090 * Better error checking when parsing RFC822-style control data.
1091 * Better checking that the supplied .dsc and debian/changes correspond.
1092 * Ordering improvement in push: don't add dsc field until git push done.
1093 * New --distro option (helps with unknown suites).
1096 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 22 Aug 2013 13:36:44 +0100
1098 dgit (0.3) experimental; urgency=low
1100 * New version which appears to be able to sort of work at least
1103 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Sat, 17 Aug 2013 09:18:04 +0100
1105 dgit (0.2) experimental; urgency=low
1107 * New version which might actually work but probably won't.
1109 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Fri, 16 Aug 2013 16:52:17 +0100
1111 dgit (0.1) experimental; urgency=low
1113 * Initial experimental (partial) version.
1115 -- Ian Jackson <ijackson@chiark.greenend.org.uk> Thu, 15 Aug 2013 12:09:01 +0100