]> git.decadent.org.uk Git - dak.git/blob - ChangeLog
* dak/process_unchecked.py: Import syck module directly, not "from
[dak.git] / ChangeLog
1 2008-03-11  Joerg Jaspert  <joerg@debian.org>
2
3         * dak/process_unchecked.py: Import syck module directly, not "from
4         syck import *"
5         (check_transition): Do the check for sourceful upload in here
6         Also adjust the syck loading commands, rename new_vers to
7         expected, curvers to current, to make it more clear what they mean.
8
9         * daklib/database.py (get_suite_version): Renamed from
10         get_testing_version. Also changed the cache variables name
11
12         * The above changes are based on modifications from Anthony.
13
14 2008-03-02  Joerg Jaspert  <joerg@debian.org>
15
16         * debian/control (Suggests): Add python-syck to Depends:
17
18         * dak/dak.py (init): Tell it about check_transitions
19
20         * dak/check_transitions.py (usage): Added, checks the transitions
21         file (if any)
22
23         * daklib/database.py (get_testing_version): Added. Returns the
24         version for the source in testing, if any
25
26         * dak/process_unchecked.py (check_transition): Added. Checks if a
27         release team member defined a transition, and rejects based on
28         that data.
29         (process_it): Use it.
30         (check_transition): Warn on broken transitions file and return,
31         not doing anything.
32         (check_transition): Moved out of here, into daklib/queue
33         (process_it): Call check_transitions only if
34         changes[architecture] has source included.
35         (check_transition): Now call the database.get_testing_version
36
37 2008-02-06  Joerg Jaspert  <joerg@debian.org>
38
39         * daklib/utils.py (check_signature): Make variable key available,
40         so we can access it.
41
42 2008-01-07  Joerg Jaspert  <joerg@debian.org>
43
44         * dak/examine_package.py (check_deb): Remove linda call. It
45         provides no added benefit to lintian anymore.
46
47 2008-01-06  Joerg Jaspert  <joerg@debian.org>
48
49         * dak/examine_package.py (do_lintian): lintian now supports html
50         coloring, so use it.
51         (do_command): Dont escape html chars if param escaped = 1
52
53 2007-12-31  Anthony Towns  <ajt@debian.org>
54
55         * dak/process_new.py (recheck): pass "" for prefix_str to reject()
56         when processing result of check_dsc_against_db so we don't promote
57         warnings to rejections.
58
59 2007-12-30  Joerg Jaspert  <joerg@debian.org>
60
61         * dak/dak.py (init): add show-new. This is based on a patch
62         submitted by Thomas Viehmann in Bug #408318, but large parts of
63         handling it are rewritten and show-new is done by me.
64
65         * dak/queue_report.py (table_row): Add link to generated html page
66         for NEW package.
67
68         * dak/show_new.py: new file, generates html overview for NEW
69         packages, similar to what we see with examine-package.
70
71         * config/debian/cron.hourly: Add show-new call
72
73         * config/debian/dak.conf: Add HTMLPath for Show-New
74
75         * dak/examine_package.py (print_copyright): ignore stderr when
76         finding copyright file.
77         (main): add html option
78         (html_escape): new function
79         (escape_if_needed): ditto
80         (headline): ditto
81         (colour_output): ditto
82         (print_escaped_text): ditto
83         (print_formatted_text): ditto
84         - use those functions everywhere where we generate output, as they
85         easily know if we want html or not and just DTRT
86         (do_lintian): new function
87         (check_deb): use it
88         (output_deb_info): Use print_escaped_text, not print_formatted_text.
89         Also import daklib.queue, determine_new now lives there
90
91         Also add a variable to see if we want html output. Default is
92         disabled, show_new enables it for its use.
93         Most of html, besides header/footer are in examine_package instead
94         of show_new, as it makes it a whole lot easier to deal with it at
95         the point the info is generated.
96
97
98         * dak/process_new.py (determine_new): Moved out of here.
99         (check_valid): Moved out of here.
100         (get_type): Moved out of here.
101
102         * daklib/queue.py (determine_new): Moved here.
103         (check_valid): Moved here.
104         (get_type): Moved here.
105
106         * dak/init_db.py (do_section): Remove non-US code
107
108         * dak/make_overrides.py (main): ditto
109
110         * dak/process_new.py (determine_new): ditto
111
112         * daklib/queue.py (Upload.in_override_p),
113         (Upload.check_override): ditto
114
115         * daklib/utils.py (extract_component_from_section):,
116         (poolify): ditto
117
118         * dak/import_archive.py (update_section): ditto
119
120         * dak/symlink_dists.py (fix_component_section): ditto
121
122         * scripts/debian/mkmaintainers: ditto
123
124         * scripts/debian/update-mirrorlists (masterlist): ditto
125
126         * config/debian-non-US/*: Remove subdir
127
128         * scripts/debian/update-readmenonus: Removed.
129
130
131 2007-12-28  Anthony Towns  <ajt@debian.org>
132
133         * daklib/utils.py (check_signature): add NOTATION_DATA and
134         NOTATION_NAME to known keywords.
135
136         * daklib/queue.py (Upload.check_source_against_db): 
137
138         * dak/make_suite_file_list.py: add -f/--force option.
139
140         * dak/generate_releases.py: add -a/--apt-conf=FILE and
141         -f/--force-touch options.  Pull version info from the database.
142         Make suite description optional.
143
144         * config/debian/dak.conf: update
145         Reject-Proposed-Updates::MoreInfoURL.  Comment out
146         Suite::Stable::Version and ::Description.
147
148         * config/debian/apt.conf: Add hurd-i386 to unstable
149         debian-installer stanza.
150
151 2007-12-28  Joerg Jaspert  <joerg@debian.org>
152
153         * KEYEXPIRED is actually a known keyword. We do check it earlier
154         on and reject in case the sig is bad (or unknown)
155
156 2007-12-24  Joerg Jaspert  <joerg@debian.org>
157
158         * Also run lintian on the .dsc file to check the source itself.
159
160         * Fix the direct usage of ar | tar etc to get the copyright file
161         and use dpkg-deb, which is made for this and makes us able to
162         process data.tar.bz2 (or whatever format it will be in the
163         future).
164
165 2007-12-21  Joerg Jaspert  <joerg@debian.org>
166
167         * Remove the (now useless) check for a pre-depends on dpkg for
168           binaries that contain bzip2 compressed data tarballs.
169
170 2007-08-28  Anthony Towns  <ajt@debian.org>
171
172         * process_unchecked.py: Add support for automatic BYHAND
173         processing.
174         * config/debian/dak.conf, scripts/debian/byhand-tag: Automatic
175         processing of tag-overrides.
176         * examine_package.py: Summarise duplicate copyright file entries
177         (same md5sum) with a reference to the previous instance, rather
178         than repeating them.
179         * process_new.py: When rejecting from the p-u-new or o-p-u-new
180         holding queues, don't worry if dak has its own reasons for
181         rejecting the package as well as the SRMs.
182
183 2007-06-19  Anthony Towns  <ajt@debian.org>
184
185         * Add nm.debian.org pseudopackage
186
187 2007-06-18  Anthony Towns  <ajt@debian.org>
188
189         * daklib/logging.py: Set umask to not exclude group-writability
190         so we don't get reminded at the start of each month. Thanks to
191         Random J.
192         * dak/override.py: More changes from Herr von Wifflepuck: warn
193         if section of source is different to binary section; restore
194         functionality on source-only overrides; croak if trying to set
195         priority of a source override; never set priority of source
196         overrides; correct typo in logging (s/priority/section/ at
197         one place)
198
199         * config/debian/apt.conf.oldstable: Added for oldstable point releases.
200         * config/debian/cron.daily: auotmatically accept/reject
201         oldstable-proposed-updates based on COMMENTS directory
202
203 2007-06-18  Anthony Towns  <ajt@debian.org>
204
205         * config/debian/apt.conf, config/debian/apt.conf.stable,
206         config/debian/dak.conf: update for 4.0r0 (etch), and 3.1r6
207         (sarge), support for oldstable-proposed-updates, dropping m68k
208         from etch, creating etch-m68k suite, creating lenny.
209
210         * config/debian/vars: update for lenny
211
212         * config/debian/dak.conf: typo fix for Dinstall::GPGKeyring,
213         drop upload limitations, add release postgres user
214         
215         * dak/process_new.py: support for automatically accepting and rejecting
216         packages from proposed-updates holding queues via COMMENTS directory
217         * cron.daily: automatically process COMMENTS-based approvals
218         and rejections for proposed-updates holding queues
219
220         * dak/process_unchecked.py: add support for oldproposedupdates
221         holding queue
222
223         * dak/control_suite.py: allow control-suite to work with etch-m68k
224
225         * dak/generate_releases.py: unlink old Release files before updating
226         them if nlinks > 1 (ie, if two files used to be the same, maybe they
227         shouldn't be when generate-releases is run)
228
229         * dak/generate_releases.py: add a couple of commented lines to make
230         it easier to deal with point releases
231
232         * dak/make_overrides.py: generate overrides for !contrib udebs
233
234         * docs/README.stable-point-release: update docs for doing a
235         point release
236
237 2007-03-05  Anthony Towns  <ajt@debian.org>
238
239         * config/debian/dak.conf: update for 3.1r5.
240         * scripts/debian/ssh-move: add ssh-move script from debbugs
241         * config/debian/cron.unchecked: push version info to debbugs using
242         ssh-move.
243
244 2007-02-14  James Troup  <troup@ries.debian.org>
245
246         * docs/README.config: remove Dinstall::GroupOverrideFilename.
247         * config/debian/dak.conf: likewise.
248         * config/debian-non-US/dak.conf: likewise.
249         * config/debian-security/dak.conf: likewise.
250
251         * daklib/queue.py (Upload.close_bugs): no longer handle NMUs or
252         experimental differently, just close the bugs and let version
253         tracking sort it out.
254          (nmu_p): remove entire class - now unused.
255          (Upload.__init__): don't use nmu_p.
256
257 2007-02-08  Anthony Towns  <ajt@debian.org>
258
259         * config/debian/dak.conf: update for 3.1r4.  Use new 'etch'
260         signing key.  Drop maximum index diffs down to 14.
261
262         * config/debian/apt.conf: add udeb support for non-free (testing,
263         unstable) and experimental.
264         * config/debian/dak.conf: likewise.
265
266         * dak/generate_releases.py (main): handle udebs in any component.
267
268         * daklib/queue.py (Upload.build_summaries): handle files without a
269         'type' gracefully.
270
271         * dak/generate_releases.py (print_sha256_files): new function.
272         (main): use it.
273
274         * dak/process_accepted.py (stable_install): fix name of template
275         mail.
276
277         * dak/process_unchecked.py (is_stableupdate): fix invocation of
278         database.get_suite_id().
279
280         * templates/process-new.bxa_notification: Update on request
281         of/after discussion with BIS staff.
282
283         * scripts/debian/mkfilesindices: also handle proposed-updates.
284
285 2007-02-08  Ryan Murray  <rmurray@debian.org>
286
287         * config/debian/cron.monthly: use $ftpgroup instead of hardcoding
288         group name for chgrp of mail archives.
289
290         * daklib/queue.py (Upload.check_dsc_against_db): handle multiple
291         orig.tar.gz's by picking the first one by file id.
292
293         * dak/override.py (main): limit to binary overrides only for now.
294         (usage): update to match.
295
296         * config/debian/cron.daily: track when we have the accepted lock
297         and clean it up on exit if we have it.  Take/check the
298         cron.unchecked lock just before traping to cleanup on exit.
299         Remove potato override handling.  Remove any dangling symlinks in
300         /srv/incoming.d.o/buildd.  Clean up apt-ftparchive's databases.
301
302         * config/debian/apt.conf: change default compression scheme for
303         both Sources and Packages to gzip and bzip2 rather than
304         uncompressed and gzip (Packages) and gzip (Sources).  Use old
305         defaults for proposed-updates.
306
307         * dak/control_overrides.py (main): refuse to operate on
308         untouchable suites.
309
310         * config/debian/pseudo-packages.maintainers: drop install,
311         installation, boot-floppy, slink-cd, potato-cd and
312         nonus.debian.org.  Update base.
313         * config/debian/pseudo-packages.description: likewise.
314
315         * daklib/utils.py (re_srchasver): new regex.
316         (parse_changes): use regex to split 'Source (Version)' style
317         Source fields into 'source' and 'source-version'.
318
319         * config/debian/cron.daily: use $base instead of hardcoding path
320         name.
321
322         * scripts/debian/mkfilesindices: source 'vars' file and use it's
323         variables instead of hardcoding path names.
324
325         * config/debian/apt.conf: switch from /org to /srv.
326         * config/debian/apt.conf.buildd: likewise.
327         * config/debian/apt.conf.stable: likewise.
328         * config/debian/cron.daily: likewise.
329         * config/debian/cron.hourly: likewise.
330         * config/debian/cron.monthly: likewise.
331         * config/debian/cron.unchecked: likewise.
332         * config/debian/cron.weekly: likewise.
333         * config/debian/dak.conf: likewise.
334         * config/debian/vars: likewise.
335         * scripts/debian/mkfilesindices: likewise.
336         
337 2007-02-08  James Troup  <james@nocrew.org>
338
339         * dak/process_unchecked.py (check_signed_by_key): new function to
340         ensure .changes files are signed by an authorized uploader.
341         (process_it): use it.
342
343         * config/debian/dak.conf (Binary-Upload-Restrictions): new stanza
344         to configure per suite/component/architecture binary upload
345         restrictions.
346
347 2006-10-09  James Troup  <james.troup@canonical.com>
348
349         * dak/process_unchecked.py (check_timestamps): change match to
350         search as recent versions of python-apt prefix the string with 'E: '.
351
352 2006-06-26  Ryan Murray  <rmurray@debian.org>
353
354         * dak/process_unchecked.py (check_files): strip optional source version
355         from Source: field in changes file, and ensure what is left is a valid
356         package name.
357
358 2006-06-23  Ryan Murray  <rmurray@debian.org>
359
360         * dak/process_unchecked.py (check_files): also check ProposedUpdates
361         queue for source.
362
363 2006-06-18  Ryan Murray  <rmurray@debian.org>
364
365         * dak/scripts/debian/update-ftpstats: look for dak named processes in
366         the log, too.
367
368         * dak/process_unchecked.py (check_files): only check embargoed and
369         unembargoed queues if the keys are set.
370
371         * dak/config/debian-security/apt.conf: set Packages::Compress to gzip
372         and bzip2 for etch.
373
374 2006-06-16  James Troup  <james@nocrew.org>
375
376         * dak/dak.py (init): add new-security-install.
377
378         * dak/new_security_install.py: cleanups and adapt for new naming
379         scheme and other changes.
380
381 2006-06-16  Anthony Towns  <ajt@debian.org>
382
383         * dak/new_security_install.py: initial version imported from
384         klecker.
385
386 2006-06-16  James Troup  <james@nocrew.org>
387
388         [Merged changes from klecker - original author unknown.]
389
390         * daklib/queue.py (Upload.dump_vars): also save changes["adv id"].
391
392         * dak/security_install.py (do_upload): fix check for oldstable and
393         upload file list handling.
394
395         * dak/process_unchecked.py (check_files): update "check for
396         source" code to also look in Embargoed and Unembargoed queues.
397         (is_unembargo): fix handling of Dir::Queue::Disembargo.
398
399         * dak/decode_dot_dak.py (main): add support for changes["adv id"].
400
401         * config/debian-security/vars (disembargo): add.
402
403         * config/debian-security/dak.conf (Dinstall::SigningKeyIds):
404         update.
405         (Process-Unchecked::AcceptedLockFile): add.
406         (Suite::Testing): clean up Version and Description.
407         (SuiteMappings): add silent map from etch-secure to testing.
408
409         * config/debian-security/cron.unchecked: add support for
410         disembargoed queues.
411
412         * config/debian-security/apt.conf.buildd: add bzip2ed Packages
413         files too.
414
415         * config/debian-security/apt.conf: add amd64 to architectures for
416         testing-security.
417
418 2006-06-11  James Troup  <troup@spohr.debian.org>
419
420         * config/debian/cron.daily: invoke process-accepted not
421         process-unchecked.
422
423         * config/debian/vars (scriptsdir): new variable.
424         * config/debian/cron.daily: use it.
425
426         * scripts/debian/mkmaintainers: put Maintainers_Versions-non-US in
427         $base/misc/ instead of versioned $masterdir.  Correct 'dak
428         make-maintainers' invocation to look in $configdir for
429         pseudo-packages.maintainers.
430
431         * daklib/queue.py (Upload.do_reject): use correct name for
432         rejection template.
433
434 2006-06-11  James Troup  <james@nocrew.org>
435
436         * dak/override.py (main): temporarily add content of old X-Katie
437         header back as the PTS apparently filters on it.
438         * dak/process_accepted.py (main): likewise.
439         * dak/process_new.py (main): likewise.
440         * dak/process_unchecked.py (main): likewise.
441         * dak/reject_proposed_updates.py (main): likewise.
442         * dak/rm.py (main): likewise.
443         * daklib/queue.py (Upload.do_reject): likewise.
444
445         * config/debian/cron.unchecked: set -u to error out on undefined
446         variables.  Preset LOCKDAILY to "" accordingly.
447         * config/debian/cron.hourly: likewise.
448         * config/debian/cron.monthly: likewise.
449         * config/debian/cron.weekly: likewise.
450
451         * config/debian/vars (configdir): add new variable pointing to
452         this directory.
453
454         * config/debian/cron.daily: use $configdir inplace of $masterdir
455         when that's what we mean, and don't cd into $masterdir just to run
456         dak scripts as we don't need to do that anymore.
457         * config/debian/cron.hourly: likewise.
458         * config/debian/cron.unchecked: likewise.
459         * config/debian/cron.weekly: likewise.
460
461         * config/debian/dak.conf
462         (Import-Users-From-Passwd::KnownPostgres): temporarily add 'katie'
463         user back to list of known users as it's non-trivial to entirely
464         change the owner of a database with postgresql 7.4.
465
466         * daklib/queue.py (Upload.source_exists): use string object
467         methods rather than string module.
468         (Upload.get_anyversion): likewise.
469
470         * daklib/utils.py (validate_changes_file_arg): update filename
471         slicing to cope with new .dak filenames.
472
473         * dak/ls.py (main): add back 'heidi' as a valid argument for
474         -f/--format as people are using it in scripts and breaking that
475         without warning seems rude.
476
477 2006-05-21  James Troup  <james@nocrew.org>
478
479         * dak/rm.py (main): use string .isdigit() rather than
480         utils.str_isnum().
481         * dak/process_new.py (edit_overrides): likewise.
482
483         * daklib/utils.py (str_isnum): removed accordingly.  Also drop
484         string import.
485
486 2006-05-21  James Troup  <james@nocrew.org>
487
488         * dak/check_archive.py (check_indices_files_exist): use list
489         comprehension instead of map().  No longer need to import
490         deprecated string module as a side-effect.
491         * dak/check_overrides.py (process): likewise.
492         (main): likewise.
493         * dak/cruft_report.py (do_obsolete_source): likewise.
494         (main): likewise.
495         * dak/ls.py (main): likewise.
496         * dak/make_suite_file_list.py (write_filelists): likewise.
497         * dak/process_accepted.py (stable_install): likewise.
498         * dak/rm.py (main): likewise.
499         * dak/stats.py (number_of_packages): likewise.
500         * daklib/logging.py (Logger.log): likewise.
501         * daklib/queue.py (Upload.source_exists): likewise.
502         (Upload.cross_suite_version_check): likewise.
503         * daklib/utils.py (parse_args): likewise.
504
505 2006-05-21  James Troup  <james@nocrew.org>
506
507         * daklib/utils.py (process_gpgv_output): new function, split out
508         of check_signature().
509         (check_signature): adapt accordingly.
510         (retrieve_key): new function that will try to retrieve the key
511         that signed a given file from a keyserver.
512         (check_signature): add 'autofetch' argument that if not set
513         defaults to the value of Dinstall::KeyAutoFetch (if that exists).
514         If 'autofetch' is true, invoke retrieve_key().  
515
516         * docs/README.config: document Dinstall::KeyAutoFetch and
517         Dinstall:KeyServer.
518
519 2006-05-20  James Troup  <james@nocrew.org>
520
521         * dak/find_null_maintainers.py (main):
522         s/createtimestamp/createTimestamp/ to make things work with modern
523         slapd.
524
525         * config/debian/dak.conf: Update StableRejector, MoreInfoURL,
526         Stable::Version and Stable::Description for 3.1r2.
527
528         * config/debian-non-US/dak.conf: sync with klecker - update
529         version number of 3.0 and MoreInfoURL.
530
531         * docs/README.stable-point-release: Add notes about updating
532         dak.conf and Reject-Proposed-Updates section in particular.
533         s/woody/stable/.  Also need to update README.html.
534
535         * scripts/debian/mklslar: drop support for uncompressed ls-lR file.
536
537         * config/debian/apt.conf: Add udeb tree for proposed-updates.
538
539 2006-05-20  Ryan Murray  <rmurray@debian.org>
540
541         * scripts/debian/update-ftpstats: new script to update daily
542         architecture size graph data.
543
544         * config/debian/cron.buildd: sync with spohr - due to ftp-master /
545         buildd split, simply ssh to buildd.d.o and call 'trigger.often'
546         there.
547
548         * config/debian/cron.daily: ssh to buildd and run 'trigger.daily'
549         before we finish.  Don't push to merkel.
550
551         * dak/process_unchecked.py (check_changes): Also look in
552         ProposedUpdates queue dir.
553         (check_files): likewise.
554
555 2006-05-20  Anthony Towns  <ajt@debian.org>
556
557         * scripts/debian/mkfilesindices: new script to generate file
558         indices used for partial mirroring.
559
560         * config/debian/cron.daily: add progress timestamps.
561
562         * config/debian/dak.conf: update Dinstall::SigningKeyIds. Add
563         amd64 to testing, unstable and experimental.  Drop sh from
564         experimental.  Move Experimental to dists/experimental.  Add
565         Dir::ProposedUpdates.  Add Architectures::amd64.
566
567         * config/debian/apt.conf: add amd64 to testing, unstable and
568         experimental.  Drop uncompressed Packages files from testing. Drop
569         sh from experimental.  Move experimental to dists/experimental/.
570
571         * config/debian/vars (archs): add amd64.
572
573         * dak/process_unchecked.py (action): Add support for
574         proposed-updates approval queue.
575         (is_stableupdate): new function - checks if the upload is targeted
576         at proposed-updates.
577         (do_stableupdate): likewise - moves upload to proposed-updates
578         holding area.
579
580         * dak/process_new.py (do_new): warn if original or new target
581         suite are invalid.
582
583         * dak/generate_releases.py (print_md5sha_files): less whitespace
584         between the hash and size.
585
586         * dak/generate_index_diffs.py (genchanges): don't say we're not
587         doing anything.  Better formatting of other messages.
588         (main): don't skip experimental and remove some 'doing stuff'
589         prints.
590
591 2006-05-18  James Troup  <james@nocrew.org>
592
593         * dak/clean_suites.py (clean_binaries): remove debug print of SQL
594         query.
595
596         * dak/init_dirs.py: pylint cleanups - long lines, unused globals,
597         docstrings, untabify, don't shadow builtins, lowercase non-global
598         variable names, spaces after commas.  Also bail if given any
599         arguments since we don't accept any.
600         * dak/init_db.py: likewise.  Also split large main() into
601         subfunctions and rename get() to sql_get().
602
603         * dak/init_db.py (main): check returned value from
604         database.get_archive_id().
605
606         * dak/dak.py: renamed from shell.py.  Update to support new source
607         layout.  Created init() and usage() functions.  Various
608         pylint-inspired cleanups.  Use daklib utils.warn() and
609         utils.fubar().  Change 'functionality' variable to only have
610         (command, description) and always invoke main() when running the
611         module.  Also support -h.
612
613 2006-05-17  James Troup  <james@nocrew.org>
614
615         * dak/check_archive.py: remove $Id$ and $Revision$ strings.  Update
616         imports of and calls to daklib modules.  Change script name
617         everywhere, i.e. in output, mails, comments and configuration tree
618         + filenames.  Also update references to other renamed scripts,
619         classes and templates.  Use '.dak' instead of '.katie' for the
620         queue info storage files.
621         (Renamed from tea)
622         * dak/check_overrides.py: likewise.  (Renamed from cindy)
623         * dak/check_proposed_updates.py: likewise.  (Renamed from jeri)
624         * dak/clean_proposed_updates.py: likewise.  (Renamed from halle)
625         * dak/clean_queues.py: likewise.  (Renamed from shania)
626         * dak/clean_suites.py: likewise.  (Renamed from rhona)
627         * dak/compare_suites.py: likewise.  (Renamed from andrea)
628         * dak/control_overrides.py: likewise.  (Renamed from natalie)
629         * dak/control_suite.py: likewise.  (Renamed from heidi)
630         * dak/cruft_report.py: likewise.  (Renamed from rene)
631         * dak/decode_dot_dak.py: likewise.  (Renamed from ashley)
632         * dak/find_null_maintainers.py: likewise.  (Renamed from rosamund)
633         * dak/generate_index_diffs.py: likewise.  (Renamed from tiffani)
634         * dak/generate_releases.py: likewise.  (Renamed from ziyi)
635         * dak/import_archive.py: likewise.  (Renamed from neve)
636         * dak/import_ldap_fingerprints.py: likewise. (Renamed from emilie)
637         * dak/import_users_from_passwd.py: likewise. (Renamed from julia)
638         * dak/init_db.py: likewise. (Renamed from alyson)
639         * dak/init_dirs.py: likewise. (Renamed from rose)
640         * dak/ls.py: likewise. (Renamed from madison)
641         * dak/make_maintainers.py: likewise.  (Renamed from charisma)
642         * dak/make_overrides.py: likewise.  (Renamed from denise)
643         * dak/make_suite_file_list.py: likewise.  (Renamed from jenna)
644         * dak/mirror_split.py: likewise.  (Renamed from billie)
645         * dak/override.py: likewise.  (Renamed from alicia)
646         * dak/poolize.py: likewise.  (Renamed from catherine)
647         * dak/process_accepted.py: likewise.  (Renamed from kelly)
648         * dak/process_new.py: likewise.  (Renamed from lisa)
649         * dak/process_unchecked.py: likewise.  (Renamed from jennifer)
650         * dak/queue_report.py: likewise.  (Renamed from helena)
651         * dak/reject_proposed_updates.py: likewise.  (Renamed from lauren)
652         * dak/rm.py: likewise.  (Renamed from melanie)
653         * dak/security_install.py: likewise.  (Renamed from amber)
654         * dak/split_done.py: likewise.  (Renamed from nina)
655         * dak/stats.py: likewise.  (Renamed from saffron)
656         * dak/symlink_dists.py: likewise.  (Renamed from saffron)
657         * daklib/database.py: likewise.  (Renamed from db_access)
658         * daklib/queue.py: likewise.  'Katie' class -> 'Upload'. (Renamed from katie)
659         * daklib/utils.py: likewise.
660
661         * dak/cruft_report.py: Use '[auto-cruft]' as the magic "this removal
662         doesn't need to notify anyone" string.
663         * dak/rm.py: likewise, look for '[auto-cruft]' as the magic string.
664
665         * dak/process_accepted.py (init): drop -V/--version argument.
666         * dak/process_new.py (init): likewise.
667         * dak/process_unchecked.py (init): likewise.
668         * dak/reject_proposed_updates.py (init): likewise
669
670         * dak/shell.py: Renamed from dak.  ".katie" -> ".dak"
671
672         * dak/stats.py: in usage() output change STAT to MODE.
673
674 2006-05-15  James Troup  <james@nocrew.org>
675
676         * dak/queue_report.py: remove unused encodings imports.
677
678         * dak/mirror_split.py: drop unused pg, pwd, db_access and logging
679         imports.  Initalize 'Cnf' as a global.
680         (BillieDB._internal_recurse): fix 'util.' typo.
681
682         * dak/import_ldap_fingerprints.py (main): drop unused time import and
683         commented out time check for LDAP search.
684
685 2005-12-16  Ryan Murray  <rmurray@debian.org>
686
687         * halle: add support for udebs
688         * kelly: stable_install: add support for binNMU versions
689
690 2005-12-05  Anthony Towns  <aj@erisian.com.au>
691
692         * katie.py: Move accept() autobuilding support into separate function 
693         (queue_build), and generalise to build different queues
694
695         * db_access.py: Add get_or_set_queue_id instead of hardcoding accepted=0
696
697         * jennifer: Initial support for enabling embargo handling with the
698         Dinstall::SecurityQueueHandling option.
699         * jennifer: Shift common code into remove_from_unchecked and move_to_dir
700         functions.
701
702         * katie.conf-security: Include embargo options
703         * katie.conf-security: Add Lock dir
704         * init_pool.sql-security: Create disembargo table
705         * init_pool.sql-security: Add constraints for disembargo table
706
707 2005-11-26  Anthony Towns  <aj@erisian.com.au>
708
709         * Merge of changes from klecker, by various people
710
711         * amber: special casing for not passing on amd64 and oldstable updates
712         * amber: security mirror triggering
713         * templates/amber.advisory: updated advisory structure
714         * apt.conf.buildd-security: update for sarge's release
715         * apt.conf-security: update for sarge's release
716         * cron.buildd-security: generalise suite support, update for sarge's release
717         * cron.daily-security: update for sarge's release, add udeb support
718         * vars-security: update for sarge's release
719         * katie.conf-security: update for sarge's release, add amd64 support,
720         update signing key
721
722         * docs/README.names, docs/README.quotes: include the additions
723
724 2005-11-25  Anthony Towns  <aj@erisian.com.au>
725
726         * Changed accepted_autobuild to queue_build everywhere.
727         * Add a queue table.
728         * Add a "queue" field in the queue_build table (currently always 0)
729
730         * jennifer: Restructure to make it easier to support special
731         purpose queues between unchecked and accepted.
732
733 2005-11-25  Anthony Towns  <aj@erisian.com.au>
734
735         * Finishing merge of changes from spohr, by various people still
736
737         * jennifer: If changed-by parsing fails, set variables to "" so REJECT
738         works
739         * jennifer: Re-enable .deb ar format checking
740         * katie.py: Convert to +bX binNMU special casing
741         * rhona: Add some debug output when deleting binaries
742         * cron.daily: Add emilie
743         * cron.unchecked: Add lock files
744
745 2005-11-15  Anthony Towns  <aj@erisian.com.au>
746
747         * Merge of changes from spohr, by various people.
748
749         * tiffani: new script to do patches to Packages, Sources and Contents
750         files for quicker downloads.
751         * ziyi: update to authenticate tiffani generated files
752
753         * dak: new script to provide a single binary with less arbitrary names
754         for access to dak functionality.
755
756         * cindy: script implemented
757
758         * saffron: cope with suites that don't have a Priority specified
759         * heidi: use get_suite_id()
760         * denise: don't hardcode stable and unstable, or limit udebs to unstable
761         * denise: remove override munging for testing (now done by cindy)
762         * helena: expanded help, added new, sort and age options, and fancy headers
763         * jennifer: require description, add a reject for missing dsc file
764         * jennifer: change lock file
765         * kelly: propogation support
766         * lisa: honour accepted lock, use mtime not ctime, add override type_id
767         * madison: don't say "dep-retry"
768         * melanie: bug fix in output (missing %)
769         * natalie: cope with maintainer_override == None; add type_id for overrides
770         * nina: use mtime, not ctime
771
772         * katie.py: propogation bug fixes
773         * logging.py: add debugging support, use | as the logfile separator
774
775         * katie.conf: updated signing key (4F368D5D)
776         * katie.conf: changed lockfile to dinstall.lock
777         * katie.conf: added Lisa::AcceptedLockFile, Dir::Lock
778         * katie.conf: added tiffani, cindy support
779         * katie.conf: updated to match 3.0r6 release
780         * katie.conf: updated to match sarge's release
781
782         * apt.conf: update for sarge's release
783         * apt.conf.stable: update for sarge's release
784         * apt.conf: bump daily max Contents change to 25MB from 12MB
785
786         * cron.daily: add accepted lock and invoke cindy  
787         * cron.daily: add daily.lock
788         * cron.daily: invoke tiffani
789         * cron.daily: rebuild accepted buildd stuff
790         * cron.daily: save rene-daily output on the web site
791         * cron.daily: disable billie
792         * cron.daily: add stats pr0n
793
794         * cron.hourly: invoke helena
795
796         * pseudo-packages.maintainers,.descriptions: miscellaneous updates
797         * vars: add lockdir, add etch to copyoverrides
798         * Makefile: add -Ipostgresql/server to CXXFLAGS
799
800         * docs/: added README.quotes
801         * docs/: added manpages for alicia, catherine, charisma, cindy, heidi,
802         julia, katie, kelly, lisa, madison, melanie, natalie, rhona.
803
804         * TODO: correct spelling of "conflicts"
805
806 2005-05-28  James Troup  <james@nocrew.org>
807
808         * helena (process_changes_files): use MTIME rather than CTIME (the
809         C's not for 'creation', stupid).
810         * lisa (sort_changes): likewise.
811
812         * jennifer (check_distributions): use has_key rather than an 'in'
813         test which doesn't work with python2.1.  [Probably by AJ]
814
815 2005-03-19  James Troup  <james@nocrew.org>
816
817         * rene (main): use Suite::<suite>::UdebComponents to determine
818         what components have udebs rather than assuming only 'main' does.
819
820 2005-03-18  James Troup  <james@nocrew.org>
821
822         * utils.py (rfc2047_encode): use codecs.lookup() rather than
823         encodings.<encoding>.Codec().decode() as encodings.utf_8 no longer
824         has a Codec() module in python2.4.  Thanks to Andrew Bennetts
825         <andrew@ubuntu.com>.
826
827 2005-03-06  Joerg Jaspert  <ganneff@debian.org>
828
829         * helena: add -n/--new HTML output option and improved sorting
830         options.
831
832 2005-03-06  Ryan Murray  <rmurray@debian.org>
833
834         * shania(main): use Cnf::Dir::Reject instead of REJECT
835
836 2005-02-08  James Troup  <james@nocrew.org>
837
838         * rene (main): add partial NBS support by checking that binary
839         packages are built by their real parent and not some random
840         stranger.
841         (do_partial_nbs): likewise.
842
843 2005-01-18  James Troup  <james@nocrew.org>
844
845         * katie.py (Katie.build_summaries): avoid leaking file handle when
846         extracting package description.
847         (Katie.force_reject): remember and close each file descriptor we
848         use.
849         (Katie.do_reject): s/file/temp_fh/ to avoid pychecker warning.
850         s/reason_file/reason_fd/ because it's a file descriptor.
851         (Katie.check_dsc_against_db): avoid leaking file handle whenever
852         invoking apt_pkg.md5sum().
853
854         * jennifer (check_deb_ar): new function: sanity check the ar
855         contents of a .deb.
856         (check_files): use it.
857         (check_timestamps): check for data.tar.bz2 if data.tar.gz can't be
858         found.
859         (check_files): accept 'raw-installer' as an alias for 'byhand'.
860
861 2005-01-14  Anthony Towns  <ajt@debian.org>
862
863         * kelly: when UNACCEPTing, don't double up the "Rejecting:"
864
865         * propup stuff (thanks to Andreas Barth)
866         * katie.conf: add stable MustBeOlderThan testing, add -security
867           propup
868         * jennifer: set distribution-version in .katie if propup may be needed
869         * katie.py: add propogation to cross_suite_version_check
870
871 2004-11-27  James Troup  <james@nocrew.org>
872
873         * nina: new script to split monolithic queue/done into date-based
874         hierarchy.
875
876         * rene (usage): document -s/--suite.
877         (add_nbs): use .setdefault().
878         (do_anais): likewise.
879         (do_nbs): don't set a string to "" and then += it.
880         (do_obsolete_source): new function - looks for obsolete source
881         packages (i.e source packages whose binary packages are ALL a)
882         claimed by someone else and b) newer when built from the other
883         source package).
884         (main): support -s/--suite.  Add 'obsolete source' to both 'daily'
885         and 'full' check modes.  Check for obsolete source packages.
886         linux-wlan-ng has been fixed - remove hideous bodge.
887
888         * jennifer (check_distributions): support 'reject' suite map type.
889
890         * utils.py (validate_changes_file_arg): s/file/filename/.
891         s/fatal/require_changes/.  If require_changes is -1, ignore errors
892         and return the .changes filename regardless.
893         (re_no_epoch): s/\*/+/ as there must be a digit in an epoch.
894         (re_no_revision): don't escape '-', it's not a special character.
895         s/\*/+/ as there must be at least one non-dash character after the
896         dash in a revision.  Thanks to Christian Reis for noticing both of
897         these.
898
899         * ashley (main): pass require_changes=-1 to
900         utils.validate_changes_file_arg().
901
902         * pseudo-packages.maintainers (kernel): switch to 'Debian Kernel
903         Team <debian-kernel@lists.debian.org>'.
904
905         * katie.py (Katie.in_override_p): fix .startswith() usage.
906
907         * katie.conf (Dinstall::DefaultSuite): add as 'unstable'.
908         (Lauren::MoreInfoURL): update to 3.0r3.
909         (Suite::Stable::Version): likewise.
910         (Suite::Stable::Description): likewise.
911
912         * cron.daily: disable automatic task override generation.
913
914         * cindy (process): restrict "find all packages" queries by
915         component.  Respect Options["No-Action"].
916         (main): add -n/--no-action support.  Only run on unstable.  Rename
917         type to otype (pychecker).
918
919 2004-11-27  Daniel Silverstone  <dsilvers@digital-scurf.org>
920
921         * katie.conf (Billie::BasicTrees): add all architectures.
922         (Billie::CombinationTrees): remove 'welovehp' and 'embedded', add
923         'everything'.
924
925         * cron.daily: Update a 'current' symlink when creating the
926         post-daily-cron-job database backup to aid mirroring to merkel.
927         Run billie.
928
929         * billie (BillieTarget.poolish_match): handle .udeb too.
930
931 2004-10-13  Ryan Murray  <rmurray@debian.org>
932
933         * amber (do_upload): Sort changes files in "katie" order so that
934           source always arrives before binary-only rebuilds
935         
936 2004-10-05  James Troup  <james@nocrew.org>
937
938         * jennifer (check_dsc): correct reject message on invalid
939         Maintainer field.
940
941 2004-09-20  James Troup  <james@nocrew.org>
942
943         * alicia: remove unused 'pwd' import.
944
945         * tea (check_override): underline suite name in output properly.
946
947         * rene (main): read a compressed Packages file.
948         * tea (validate_packages): likewise.
949
950         * katie.py (re_fdnic): add 'r' prefix.
951         (re_bin_only_nmu_of_mu): likewise.
952         (re_bin_only_nmu_of_nmu): likewise.
953
954         * madison (main): retrieve component information too and display
955         it if it's not 'main'.
956         * melanie (reverse_depends_check): likewise.
957
958         * utils.py (pp_dep): renamed...
959         (pp_deps): ... to this.
960         * jeri (check_dep): update calls to utils.pp_deps().
961         * melanie (reverse_depends_check): likewise.
962
963         * jennifer (check_changes): move initalization of email variables
964         from here...
965         (process_it): ...to here as we no longer always run
966         check_changes().  Don't bother to initialize
967         changes["architecture"].
968
969         * denise (list): renamed to...
970         (do_list): ...this to avoid name clash with builtin 'list'.
971         Similarly, s/file/output_file/, s/type/otype/.  Use .setdefault()
972         for dictionaries.
973         (main): Likewise for name clash avoidance and also
974         s/override_type/suffix/.  Adjust call to do_list().
975
976 2004-09-01  Ryan Murray  <rmurray@debian.org>
977
978         * tea (check_files): check the pool/ directory instead of dists/
979
980 2004-08-04  James Troup  <james@nocrew.org>
981
982         * jenna (cleanup): use .setdefault() for dictionaries.
983         (write_filelists): likewise.
984
985         (write_filelists): Use utils.split_args() not split() to split
986         command line arguments.
987         (stable_dislocation_p): likewise.
988
989         (write_filelists): Add support for mapping side of suite-based
990         "Arch: all mapping".
991         (do_da_do_da): ensure that if we're not doing all suites that we
992         process enough to be able correct map arch: all packages.
993
994         * utils.py (cant_open_exc): correct exception string,
995         s/read/open/, s/.$//.
996
997         * templates/amber.advisory: update to match reality a little
998         better.
999
1000         * melanie (reverse_depends_check): read Packages.gz rather than
1001         Packages.
1002
1003         * jennifer (check_files): check for unknown component before
1004         checking for NEWness.
1005
1006         * katie.py (Katie.in_override_p): use .startswith in favour of a
1007         slice.
1008
1009         * docs/melanie.1.sgml: document -R/--rdep-check.
1010
1011 2004-07-12  Daniel Silverstone  <dsilvers@digital-scurf.org>
1012
1013         * billie (main): Make the verbatim lists include all the README
1014           elements.
1015         * docs/README.names: Add billie in (correcting oversight)
1016
1017 2004-07-01  James Troup  <james@nocrew.org>
1018
1019         * emilie (main): handle woody's case-sensitive python-ldap,
1020         s/keyfingerprint/keyFingerPrint/.
1021
1022 2004-06-25  James Troup  <james@nocrew.org>
1023
1024         * debian/control (Depends): add dpkg-dev since jennifer uses
1025         dpkg-source.
1026
1027 2004-06-24  James Troup  <james@nocrew.org>
1028
1029         * melanie (main): s/file/temp_file/ and close file handle before
1030         removing the temporary file.
1031         (main): don't warn about needing a --carbon-copy if in no-action
1032         mode.
1033
1034         * rene (do_nbs): pcmcia-cs has been fixed - remove hideous bodge.
1035         (main): likewise.
1036
1037         * test/006/test.py (main): check bracketed email-only form.
1038
1039         * utils.py (fix_maintainer): if the Maintainer string is bracketed
1040         email-only, strip the brackets so we don't end up with
1041         <<james@nocrew.org>>.
1042
1043 2004-06-20  James Troup  <james@nocrew.org>
1044
1045         * jennifer (process_it): only run check_changes() if
1046         check_signature() returns something.  (Likewise)
1047
1048         * utils.py (changes_compare): if there's no changes["version"] use
1049         "0" rather than None.  (Avoids a crash on unsigned changes file.)
1050
1051 2004-06-17  Martin Michlmayr  <tbm@cyrius.com>
1052
1053         * jeri (pp_dep): moved from here to ...
1054         * utils.py (pp_dep): here.
1055
1056         * melanie (main): add reverse dependency checking.
1057
1058 2004-06-17  James Troup  <james@nocrew.org>
1059
1060         * jennifer (check_dsc): s/dsc_whitespace_rules/signing_rules/.
1061         * tea (check_dscs): likewise.
1062
1063         * utils.py (parse_changes): s/dsc_whitespace_rules/signing_rules/,
1064         change from boolean to a variable with 3 possible values, 0 and 1
1065         as before, -1 means don't require a signature.  Makes
1066         parse_changes() useful for parsing arbitary RFC822-style files,
1067         e.g. 'Release' files.
1068         (check_signature): add support for detached signatures by passing
1069         the files the signature is for as an optional third argument.
1070         s/filename/sig_filename/g.  Add a fourth optional argument to
1071         choose the keyring(s) to use.  Don't os.path.basename() the
1072         sig_filename before checking it for taint.
1073         (re_taint_free): allow '/'.
1074
1075 2004-06-11  James Troup  <james@nocrew.org>
1076
1077         * tea (check_files): make override.unreadable optional.
1078         (validate_sources): close the Sources file handle.
1079
1080         * docs/README.first: clarify that 'alyson' and running
1081         add_constraints.sql by hand is something you only want to do if
1082         you're not running 'neve'.
1083
1084         * docs/README.config (Location::$LOCATION::Suites): document.
1085
1086         * db_access.py (do_query): also print out the result of the query.
1087
1088 2004-06-10  James Troup  <james@nocrew.org>
1089
1090         * katie.py (Katie.cross_suite_version_check): post-woody versions
1091         of python-apt's apt_pkg.VersionCompare() function apparently
1092         returns variable integers for less than or greater than results -
1093         update our result checking to match.
1094         * jenna (resolve_arch_all_vs_any): likewise.
1095         * charisma (main): likewise.
1096
1097 2004-06-09  James Troup  <james@nocrew.org>
1098
1099         * jennifer (process_it): s/changes_valid/valid_changes_p/.  Add
1100         valid_dsc_p and don't run check_source() if check_dsc() failed.
1101         (check_dsc): on fatal failures return 0 so check_source() isn't
1102         run (since it makes fatal assumptions about the presence of
1103         mandatory .dsc fields).  
1104         Remove unused and obsolete re_bad_diff and re_is_changes regexps.
1105
1106 2004-05-07  James Troup  <james@nocrew.org>
1107
1108         * katie.conf (Rhona::OverrideFilename): unused and obsolete, remove.
1109         * katie.conf-non-US (Rhona::OverrideFilename): likewise.
1110
1111         * katie.conf (Dir::Override): remove duplicate definition.
1112
1113         * neve (get_or_set_files_id): add an always-NULL last_used column
1114         to output.
1115
1116 2004-04-27  James Troup  <james@nocrew.org>
1117
1118         * apt.conf-security (tree "dists/stable/updates"): add
1119         ExtraOverride - noticed by Joey Hess (#246050).
1120         (tree "dists/testing/updates"): likewise.
1121
1122 2004-04-20  James Troup  <james@nocrew.org>
1123
1124         * jennifer (check_files): check for existing .changes or .katie
1125         files of the same name in the Suite::<suite>::Copy{Changes,Katie}
1126         directories.
1127
1128 2004-04-19  James Troup  <james@nocrew.org>
1129
1130         * jennifer (check_source): handle failure to remove the temporary
1131          directory (used for source tree extraction) better, specifically:
1132          if we fail with -EACCES, chmod -R u+rwx the temporary directory
1133          and try again and if that works, REJECT the package.
1134
1135 2004-04-17  James Troup  <james@nocrew.org>
1136
1137         * docs/madison.1.sgml: document -b/--binary-type,
1138         -g/--greaterorequal and -G/--greaterthan.
1139
1140         * madison (usage): -b/--binary-type only takes a single argument.
1141         Document -g/--greaterorequal and -G/--greaterthan.
1142         (main): add support for -g/--greaterorequal and -G/--greaterthan.
1143
1144 2004-04-12  Daniel Silverstone  <dsilvers@digital-scurf.org>
1145
1146         * billie: Cleaned up a load of comments, added /README.non-US to
1147           the verbatim matches list.
1148
1149 2004-04-07  Daniel Silverstone  <dsilvers@digital-scurf.org>
1150
1151         * utils.py (size_type): Make it use real binary megabytes and
1152           kilobytes, instead of the marketing terms used before.
1153
1154 2004-04-07  James Troup  <james@nocrew.org>
1155
1156         * katie.py (Katie.check_dsc_against_db): in the case we're
1157         ignoring an identical-to-existing orig.tar.gz remember the path to
1158         the existent version in pkg.orig_tar_gz.  Adjust query to grab
1159         location.path too to be able to do so.
1160
1161 2004-04-03  James Troup  <james@nocrew.org>
1162
1163         * debian/control (Depends): add python2.1-email | python (>= 2.2)
1164         needed for new utils.rfc2047_encode() function.
1165
1166         * utils.py (re_parse_maintainer): allow whitespace inside the
1167         email address.
1168         (Error): new exception base class.
1169         (ParseMaintError): new exception class.
1170         (force_to_utf8): new function.
1171         (rfc2047_encode): likewise.
1172         (fix_maintainer): rework.  use force_to_utf8() to force name and
1173         rfc822 return values to always use UTF-8.  use rfc2047_encode() to
1174         return an rfc2047 value.  Validate the address to catch missing
1175         email addresses and (some) broken ones.
1176
1177         * katie.py (nmu_p.is_an_nmu): adapt for new utils.fix_maintainer()
1178         by adopting foo2047 return value.
1179         (Katie.dump_vars): add changedby2047 and maintainer2047 as
1180         mandatory changes fields.  Promote changes and maintainer822 to
1181         mandatory fields.
1182         (Katie.update_subst): default maintainer2047 rather than
1183         maintainer822.  User foo2047 rather than foo822 when setting
1184         __MAINTAINER_TO__ or __MAINTAINER_FROM__.
1185
1186         * jennifer (check_changes): set default changes["maintainer2047"]
1187         and changes["changedby2047"] values rather than their 822
1188         equivalents.  Makes changes["changes"] a mandatory field.  Adapt
1189         to new utils.fix_maintainer() - reject on exception and adopt
1190         foo2047 return value.
1191         (check_dsc): if a mandatory field is missing don't do any further
1192         checks and as a result reduce paranoia about dsc[var] existence.
1193         Validate the maintainer field by calling new
1194         utils.fix_maintainer().
1195
1196         * ashley (main): add changedby2047 and maintainer2047 to mandatory
1197         changes fields.  Promote maintainer822 to a mandatory changes
1198         field.  add "pool name" to files fields.
1199
1200         * test/006/test.py: new file - tests for new
1201         utils.fix_maintainer().
1202
1203 2004-04-01  James Troup  <james@nocrew.org>
1204
1205         * templates/lisa.prod (To): use __MAINTAINER_TO__ not __MAINTAINER__.
1206
1207         * jennifer (get_changelog_versions): create a symlink mirror of
1208         the source files in the temporary directory.
1209         (check_source): if check_dsc_against_db() couldn't find the
1210         orig.tar.gz bail out.
1211
1212         * katie.py (Katie.check_dsc_against_db): if the orig.tar.gz is not
1213         part of the upload store the path to it in pkg.orig_tar_gz and if
1214         it can't be found set pkg.orig_tar_gz to -1.
1215
1216         Explicitly return the second value as None in the (usual) case
1217         where we don't have to reprocess.  Remove obsolete diagnostic
1218         logs.
1219
1220         * lisa (prod_maintainer): don't return anything, no one cares. (pychecker)
1221
1222         * utils.py (temp_filename): new helper function that wraps around
1223         tempfile.mktemp().
1224
1225         * katie.py (Katie.do_reject): use it and don't import tempfile.
1226         * lisa (prod_maintainer): likewise.
1227         (edit_note): likewise.
1228         (edit_new): likewise.
1229         * lauren (reject): likewise.
1230         * melanie (main): likewise.
1231         * neve (do_sources): likewise.
1232         * rene (main): likewise.
1233         * tea (validate_sources): likewise.
1234
1235 2004-03-31  James Troup  <james@nocrew.org>
1236
1237         * tea (validate_sources): remove unused 's' temporary variable.
1238
1239 2004-03-15  James Troup  <james@nocrew.org>
1240
1241         * jennifer (check_dsc): check changes["architecture"] for
1242         source before we do anything else.
1243
1244 2004-03-21  Daniel Silverstone  <dsilvers@digital-scurf.org>
1245
1246         * billie: Added
1247         * katie.conf (Billie): Added sample Billie stanza to katie.conf
1248
1249 2004-03-12  James Troup  <james@nocrew.org>
1250
1251         * docs/README.config (Dir::Queue::BTSVersionTrack): document.
1252
1253         * katie.conf (Dir::Queue::BTSVersionTrack): define.
1254
1255         * katie.py (Katie.accept): add support for DebBugs Version
1256         Tracking by writing out .versions (generated in jennifer's
1257         get_changelog_versions()) and .debinfo (mapping of binary ->
1258         source) files.
1259
1260         * ashley (main): add dsc["bts changelog"].
1261
1262         * katie.py (Katie.dump_vars): store dsc["bts changelog"] too.
1263
1264         * jennifer (check_diff): obsoleted by check_source(), removed.
1265         (check_source): new function: create a temporary directory and
1266         move into it and call get_changelog_versions().
1267         (get_changelog_versions): new function: extract the source package
1268         and optionally parse debian/changelog to obtain the version
1269         history for the BTS.
1270         (process_it): call check_source() rather than check_diff().
1271
1272 2004-03-08  James Troup  <james@nocrew.org>
1273
1274         * lisa (edit_index): Fix logic swapo from 'use "if varfoo in
1275         listbar" rather than "if listbar.count(varfoo)"' change on
1276         2004-02-24.
1277
1278 2004-03-05  James Troup  <james@nocrew.org>
1279
1280         * alicia (main): don't warn about not closing bugs - we don't
1281         manage overrides through the BTS.
1282
1283 2004-02-27  Martin Michlmayr  <tbm@cyrius.com>
1284
1285         * docs/README.config: lots of updates and corrections.
1286         * docs/README.first: likewise.
1287
1288         * docs/README.config: drop unused Dir::Queue::Root.
1289         * katie.conf-non-US: likewise.
1290         * katie.conf: likewise.
1291         * katie.conf-security: likewise.
1292
1293 2004-02-27  James Troup  <james@nocrew.org>
1294
1295         * rose (process_tree): use 'if var in [ list ]' rather than long
1296         'if var == foo or var == bar or var == baz'.  Suggested by Martin
1297         Michlmayr.
1298
1299         * jennifer (check_files): reduce 'if var != None' to 'if var' as
1300         suggested by Martin Michlmayr.
1301         * catherine (poolize): likewise.
1302         * charisma (main): likewise.
1303         * halle (check_changes): likewise.
1304         * heidi (main): likewise.
1305         (process_file): likewise.
1306         * kelly (install): likewise.
1307         (stable_install): likewise.
1308         * utils.py (fix_maintainer): likewise.
1309
1310         * apt.conf: add support for debian-installer in testing-proposed-updates.
1311         * katie.conf (Suite::Testing-Proposed-Updates::UdebComponents):
1312         add - set to main.
1313
1314         * mkmaintainers: add "-T15" option to wget of non-US packages file
1315         so that we don't hang cron.daily if non-US is down.
1316
1317         * templates/lisa.prod (Subject): Prefix with "Comments regarding".
1318
1319         * templates/jennifer.bug-close: add Source and Source-Version
1320         pseudo-headers that may be used for BTS Version Tracking someday
1321         [ajt@].
1322
1323         * rene (do_nbs): special case linux-wlan-ng like we do for pcmcia.
1324         (main): likewise.
1325
1326         * cron.unchecked: it's /org/ftp.debian.org not ftp-master.
1327
1328 2004-02-25  James Troup  <james@nocrew.org>
1329
1330         * katie.conf (SuiteMappings): don't map testing-security to
1331         proposed-updates.
1332
1333 2004-02-24  James Troup  <james@nocrew.org>
1334
1335         * katie.py (Katie.__init__): remove unused 'values' field.
1336
1337         * utils.py (extract_component_from_section): use 's.find(c) != -1'
1338         rather than 's.count(c) > 0'.
1339
1340         * katie.py (Katie.source_exists): use "if varfoo in listbar"
1341         rather than "if listbar.count(varfoo)".
1342         * halle (check_joey): likewise.
1343         * jeri (check_joey): likewise.
1344         * lisa (edit_index): likewise.
1345         * jenna (stable_dislocation_p): likewise.
1346
1347         * jennifer (main): remove unused global 'nmu'.
1348
1349 2004-02-03  Daniel Silverstone  <dsilvers@digital-scurf.org>
1350
1351         * pseudo-packages.maintainers (ftp.debian.org): Changed the maintainer
1352           to be ftpmaster@ftp-master.debian.org to bring it into line with how
1353           the dak tools close bugs.
1354
1355 2004-02-02  Daniel Silverstone  <dsilvers@digital-scurf.org>
1356
1357         * katie.conf (Alicia): Added an Alicia section with email address
1358         * templates/alicia.bug-close: Added
1359         * docs/alicia.1.sgml: Added the docs for the -d/--done argument
1360         * alicia (main): Added a -d/--done argument
1361
1362 2004-02-02  Daniel Silverstone  <dsilvers@digital-scurf.org>
1363
1364         * templates/lisa.prod: Oops, missed a BITCH->PROD conversion
1365
1366 2004-01-29  Daniel Silverstone  <dsilvers@digital-scurf.org>
1367
1368         * lisa (prod_maintainer): Added function to prod the maintainer without
1369           accepting or rejecting the package
1370         * templates/lisa.prod: Added this template for the prodding mail
1371
1372         * .cvsignore: Added neve-files which turns up in new installations
1373
1374 2004-01-30  Daniel Silverstone  <dsilvers@digital-scurf.org>
1375
1376         * alicia (usage): Fixed usage message to offer section and priority
1377           as seperately optional arguments.
1378         * alicia (main): Added a % (arg) interpolation needed when only
1379           one of section or priority is provided and it cannot be found.
1380
1381 2004-01-29  Daniel Silverstone  <dsilvers@digital-scurf.org>
1382
1383         * alicia: Added
1384         * docs/alicia.1.sgml: Added
1385         * docs/Makefile: Added alicia to the list of manpages to build
1386         * docs/README.names: Noted what alicia does
1387         * docs/README.first: Noted where alicia is useful
1388
1389 2004-01-21  James Troup  <james@nocrew.org>
1390
1391         * madison (main): add -b/--binary-type.
1392         (usage): likewise.
1393
1394         * denise (main): generate debian-installer overrides for testing
1395         too.
1396         * apt.conf: add support for debian-installer in testing.
1397         * katie.conf (Suite::Testing::UdebComponents): set to main.
1398
1399         * katie.conf (Dinstall::SigningKeyIds): 2004 key.
1400         * katie.conf-non-US (Dinstall::SigningKeyIds): likewise.
1401         * katie.conf-security (Dinstall::SigningKeyIds): likewise.
1402
1403         * utils.py (parse_changes): don't process data not inside the
1404         signed data.  Thanks to Andrew Suffield <asuffield@debian.org> for
1405         pointing this out.
1406         * test/005/test.py (main): new test to test for above.
1407
1408 2004-01-04  James Troup  <james@nocrew.org>
1409
1410         * jenna (write_filelists): correct typo, s/Components/Component/
1411         for Options.
1412
1413 2004-01-04  Ryan Murray  <rmurray@debian.org>
1414
1415         * cron.buildd: move update of overrides and Packages file...
1416         * cron.unchecked: to here.
1417         * katie.conf-non-US: (Dinstall::SingingKeyIds) update for 2003v2 key
1418         * katie.conf-security: likewise
1419
1420 2003-11-20  James Troup  <james@nocrew.org>
1421
1422         * jenna (main): don't use utils.try_with_debug(), it produces way
1423         too much output.
1424
1425         * halle (check_changes): don't error out if a .changes refers to a
1426         non-existent package, just warn and skip the file.
1427
1428         * docs/README.stable-point-release: mention halle and .changes
1429         obsoleted by removal through melanie.  Update for 3.0r2.
1430
1431         * katie.conf (Suite::Stable::Version): bump to 3.0r2.
1432         (Suite::Stable::Description): update for 3.0r2.
1433         (Lauren::MoreInfoURL): likewise.
1434         * katie.conf-non-US (Suite::Stable::Version): likewise.
1435         (Suite::Stable::Description): likewise.
1436         (Lauren::MoreInfoURL): likewise.
1437
1438         * apt.conf.stable (Default): don't define MaxContentsChange.
1439         * apt.conf.stable-non-US (Default): likewise.
1440
1441         * lauren (reject): hack to work around partial replacement of an
1442         upload, i.e. one or more binaries superseded by another source
1443         package.
1444
1445 2003-11-17  James Troup  <james@nocrew.org>
1446
1447         * pseudo-packages.maintainers: point installation-reports at
1448         debian-boot@l.d.o rather than debian-testing@l.d.o at jello@d.o's
1449         request.
1450
1451         * utils.py (parse_changes): calculate the number of lines once
1452         with len() rather than max().
1453
1454         * jennifer (check_dsc): handle the .orig.tar.gz disappearing from
1455         files, since check_dsc_against_db() deletes the .orig.tar.gz
1456         entry.
1457
1458 2003-11-13  Ryan Murray  <rmurray@debian.org>
1459
1460         * apt.conf: specify a src override file for debian-installer
1461
1462 2003-11-10  James Troup  <james@nocrew.org>
1463
1464         * fernanda.py (strip_pgp_signature): new function - strips PGP
1465         signature from a file and returns the modified contents of the
1466         file in a string.
1467         (display_changes): use it.
1468         (read_dsc): likewise.
1469
1470 2003-11-09  Ryan Murray  <rmurray@debian.org>
1471
1472         * cron.buildd: export accepted_autobuild table for unstable, and use
1473         it to generate the incoming Packages/Sources rather than having apt
1474         walk the directory.
1475         * apt.conf.buildd: use exported table from cron.buildd to generate
1476         Packages/Sources
1477
1478 2003-11-07  James Troup  <james@nocrew.org>
1479
1480         * kelly: import errno.
1481
1482         * katie.py (Katie.build_summaries): sort override disparities.
1483
1484         * kelly (install): set dsc_component based on the .dsc's component
1485         not a random binaries.
1486
1487 2003-10-29  James Troup  <james@nocrew.org>
1488
1489         * katie.py (Katie.build_summaries): don't assume changes["source"]
1490         exists since it might not.
1491
1492 2003-10-20  James Troup  <james@nocrew.org>
1493
1494         * pseudo-packages.maintainers: update security.d.o to use
1495         team@s.d.o at joy@'s request.
1496
1497 2003-10-17  James Troup  <james@nocrew.org>
1498
1499         * jennifer (check_dsc): use .startswith rather than .find() == 0.
1500
1501 2003-10-17  Martin Michlmayr  <tbm@cyrius.com>
1502
1503         * tea (chk_bd_process_dir): use .endswith rather than slice.
1504
1505 2003-10-14  James Troup  <james@nocrew.org>
1506
1507         * tea (check_build_depends): new function.
1508         (chk_bd_process_dir): likewise.  Validates build-depends in .dsc's
1509         in the archive.
1510         (main): update for new function.
1511         (usage): likewise.
1512
1513         * katie.py (Katie.do_reject): sanitize variable names,
1514         s/reject_filename/reason_filename/, s/fd/reason_fd/.  Move shared
1515         os.close() to outside if clause.
1516
1517         * jennifer (check_dsc): check build-depends and
1518         build-depends-indep by running them past apt_pkg.ParseSrcDepends.
1519         Fold the ARRAY check into the same code block and tidy up it's
1520         rejection message.
1521         (check_changes): ensure that the Files field is non-empty.
1522         Suggested by Santiago Vila <sanvila@unex.es>
1523         (check_changes): normalize reject messages.
1524         (check_dsc): instead of doing most of the checks inside a for loop
1525         and an if, find the dsc_filename in a short loop over files first
1526         and then do all the checks.  Add check for more than one .dsc in a
1527         .changes which we can't handle.  Normalize reject messages.
1528
1529 2003-10-13  James Troup  <james@nocrew.org>
1530
1531         * katie.conf (Dinstall::Reject::NoSourceOnly): set to true.
1532         * katie.conf-non-US (Dinstall::Reject::NoSourceOnly): likewise.
1533
1534         * jennifer (check_files): Set 'has_binaries' and 'has_source'
1535         variables while iterating over 'files'.  Don't regenerate it when
1536         checking for source if source is mentioned.
1537
1538         Reject source only uploads if the config variable
1539         Dinstall::Reject::NoSourceOnly is set.
1540
1541 2003-10-03  James Troup  <james@nocrew.org>
1542
1543         * rene (main): add nasty hardcoded reference to debian-installer
1544         so we detect NBS .udebs.
1545
1546 2003-09-29  James Troup  <james@nocrew.org>
1547
1548         * apt.conf (old-proposed-updates): remove.
1549         * apt.conf-non-US (old-proposed-updates): likewise.
1550
1551 2003-09-24  James Troup  <james@nocrew.org>
1552
1553         * tea (check_files_not_symlinks): new function, ensure files
1554         mentioned in the database aren't symlinks.  Includes code to
1555         update any files that are like this to their real filenames +
1556         location; commented out by though.
1557         (usage): update for new function.
1558         (main): likewise.
1559
1560 2003-09-24  Anthony Towns  <ajt@debian.org>
1561
1562         * vars: external-overrides variable added
1563         * cron.daily: Update testing/unstable Task: overrides from joeyh
1564         managed external source.
1565
1566 2003-09-22  James Troup  <james@nocrew.org>
1567
1568         * kelly (install): if we can't move the .changes into queue/done,
1569         fail don't warn and carry on.  The old behaviour pre-dates NI and
1570         doesn't make much sense now since jennifer checks both
1571         queue/accepted and queue/done for any .changes files it's
1572         processing.
1573
1574         * utils.py (move): don't throw exceptions on existing files or
1575         can't overwrite, instead just fubar out.
1576
1577         * jennifer (check_dsc): also check Build-Depends-Indep for
1578         ARRAY-lossage.  Noticed by Matt Zimmerman <mdz@debian.org>.
1579
1580 2003-09-18  James Troup  <james@nocrew.org>
1581
1582         * katie.py (Katie.close_bugs): only log the bugs we've closed
1583         once.
1584
1585         * kelly (main): log as 'kelly', not 'katie'.
1586
1587 2003-09-16  James Troup  <james@nocrew.org>
1588
1589         * katie.py (Katie.check_binary_against_db): likewise noramlize.
1590
1591         * jennifer (check_changes): normalize reject message for "changes
1592         file already exists" to be %s: <foo>.
1593         (check_dsc): add a check for 'Build-Depends: ARRAY(<hex>)'
1594         produced by broken dpkg-source in 1.10.11.  Tone down and
1595         normalize rejection message for incompatible 'Format' version
1596         numbers.
1597         (check_diff): likewise tone down and normalize.
1598
1599 2003-09-07  James Troup  <james@nocrew.org>
1600
1601         * utils.py (parse_changes): if dsc_whitespace_rules is false,
1602         don't bomb out on bogus empty lines.
1603         (build_file_list): check for changes["files"] earlier.  use Dict
1604         to create files[name] dictionary.
1605         (send_mail): don't bother validating arguments.
1606         (check_signature): minor improvements to some of the rejection
1607         messages including listing the key id of the key that wasn't found
1608         in the keyring.
1609         (wrap): new function.
1610
1611         * tea: add new check 'validate-indices' that ensures all files
1612         mentioned in indices (Packages, Sources) files do in fact exist.
1613
1614         * catherine (poolize): use a local re_isadeb which handles legacy
1615         (i.e. no architecture) style .deb filenames.
1616
1617         * rosamund: new script.
1618
1619         * rhona (check_binaries): when checking for binary packages not in
1620         a suite, don't bother selecting files that already have a
1621         last_used date.
1622         (check_sources): likewise.
1623
1624         * rhona: change all SQL EXISTS sub-query clauses to use the
1625         postgres suggested convention of "SELECT 1 FROM".
1626         * andrea (main): likewise.
1627         * tea (check_override): likewise.
1628         * catherine (main): likewise.
1629
1630         * katie.conf (Suite): remove OldStable and Old-Proposed-Updates
1631         entries and in other suites MustBeNewerThan's.
1632         (SuiteMappings): likewise
1633         * katie.conf-non-US: likewise.
1634         * katie.conf-security: likewise.
1635
1636         * apt.conf-security: remove oldstable.
1637         * apt.conf.stable: likewise.
1638         * apt.conf.stable-non-US: likewise.
1639         * cron.buildd-security: likewise.
1640         * cron.daily-security: likewise.
1641         * vars-security (suites): likewise.
1642         * wanna-build/trigger.daily: likewise.
1643
1644         * claire.py (clean_symlink): move...
1645         * utils.py (clean_symlink): here.
1646
1647         * claire.py (find_dislocated_stable): update accordingly.
1648
1649 2003-08-16  Anthony Towns  <ajt@debian.org>
1650
1651         * katie.py (source_exists): expand the list of distributions
1652         the source may exist in to include any suite that's mapped to
1653         the destination suite (even transitively (a->b->c)). This should
1654         unbreak binary uploads to *-proposed-updates.
1655
1656 2003-08-09  Randall Donald  <rdonald@debian.org>
1657
1658         * lisa (recheck): change changes["distribution"].keys() to
1659         Katie.pkg.changes...
1660
1661 2003-08-08  Randall Donald  <rdonald@debian.org>
1662
1663         * katie.py: only tag bugs as fixed-in-experimental for
1664         experimental uploads
1665
1666 2003-07-26  Anthony Towns  <ajt@debian.org>
1667
1668         * katie.py (source_exists): add an extra parameter to limit the
1669         distribution(s) the source must exist in.
1670         * kelly, lisa, jennifer: update to use the new source_exists
1671
1672 2003-07-15  Anthony Towns  <ajt@debian.org>
1673
1674         * ziyi: quick hack to support a FakeDI line in apt.conf to generate
1675         checksums for debian-installer stuff even when it's just a symlink to
1676         another suite
1677
1678         * apt.conf: add the FakeDI line
1679
1680 2003-06-09  James Troup  <james@nocrew.org>
1681
1682         * kelly (check): make sure the 'file' we're looking for in 'files'
1683         hasn't been deleted by katie.check_dsc_against_db().
1684
1685 2003-05-07  James Troup  <james@nocrew.org>
1686
1687         * helena (time_pp): fix s/years/year/ typo.
1688
1689 2003-04-29  James Troup  <james@nocrew.org>
1690
1691         * madison (usage): document -c/--component.
1692
1693         * madison (usage): Fix s/seperated/separated/.
1694         * melanie (usage): likewise.
1695         * jenna (usage): likewise.
1696
1697 2003-04-24  James Troup  <james@nocrew.org>
1698
1699         * cron.daily-non-US: if there's nothing for kelly to install, say
1700         so.
1701
1702         * jennifer (check_timestamps): print sys.exc_value as well as
1703         sys.exc_type when capturing exceptions.  Prefix 'timestamp check
1704         failed' with 'deb contents' to make it clearer what timestamp(s)
1705         are being checked.
1706
1707 2003-04-15  James Troup  <james@nocrew.org>
1708
1709         * cron.daily-non-US: only run kelly if there are some .changes
1710         files in accepted.
1711
1712         * rene: add -m/--mode argument which can be either daily (default)
1713         or full.  In daily mode only 'nviu' and 'nbs' checks are run.
1714         Various changes to make this possible including a poor attempt at
1715         splitting main() up a little.  De-hardcode suite numbers from SQL
1716         queries and return quietly from do_nviu() if experimental doesn't
1717         exist (i.e. non-US).  Hardcode pcmcia-cs as dubious NBS since it
1718         is.
1719
1720         * debian/control (Depends): remove python-zlib as it's obsolete.
1721
1722         * charisma (main): don't slice the \n off strings when we're
1723         strip()-ing it anyway.
1724         * heidi (set_suite): likewise.
1725         (process_file): likewise.
1726         * natalie (process_file): likewise.
1727
1728 2003-04-08  James Troup  <james@nocrew.org>
1729
1730         * katie.py (Katie.check_dsc_against_db): improve the speed of two
1731         slow queries by using one LIKE '%foo%' and then matching against
1732         '%s' or '/%s$' in python.  Also only join location when we need it
1733         (i.e. the .orig.tar.gz query).  On auric, this knocks ~3s of each
1734         query, so 6s for each sourceful package.
1735
1736         * cron.daily: invoke rene and send the report to ftpmaster.
1737         * cron.daily-non-US: likewise.
1738
1739 2003-03-14  James Troup  <james@nocrew.org>
1740
1741         * utils.py (send_mail): default filename to blank.
1742         * amber (make_advisory): adapt.
1743         * jennifer (acknowledge_new): likewise.
1744         * katie.py (Katie.close_bugs): likewise.
1745         (Katie.announce): likewise.
1746         (Katie.accept): likewise.
1747         (Katie.check_override): likewise.
1748         (Katie.do_reject): likewise.
1749         * kelly (do_reject): likewise.
1750         (stable_install): likewise.
1751         * lisa (do_bxa_notification): likewise.
1752         * lauren (reject): likewise.
1753         * melanie (main): likewise.
1754
1755         * rene (add_nbs): check any NBS packages against unstable to see
1756         if they haven't been removed already.
1757
1758         * templates/katie.rejected: remove paragraph about rejected files
1759         since they're o-rwx due to c-i-m and the uploader can't do
1760         anything about them and shania will take care of them anyway.
1761
1762         * madison (usage): update usage example to use comma seperation.
1763         * melanie (usage): likewise.
1764
1765         * utils.py (split_args): new function; splits command line
1766         arguments either by space or comma (whichever is used).  Also has
1767         optional-but-default DWIM spurious space detection to avoid
1768         'command -a i386, m68k' problems.
1769         (parse_args): use it.
1770         * melanie (main): likewise.
1771
1772         * melanie (main): force the admin to tell someone if we're not
1773         doing a rene-led removal (or closing a bug, which counts as
1774         telling someone).
1775
1776 2003-03-05  James Troup  <james@nocrew.org>
1777
1778         * katie.conf (Section): add embedded, gnome, kde, libdevel, perl
1779         and python sections.
1780         * katie.conf-security (Section): likewise.
1781
1782         * add_constraints.sql: add uid and uid_id_seq to grants.
1783
1784         * lisa (determine_new): also warn about adding overrides to
1785         oldstable.
1786
1787         * madison (main): make the -S/--source-and-binary query obey
1788         -s/--suite restrictions.
1789
1790 2003-03-03  James Troup  <james@nocrew.org>
1791
1792         * madison (main): if the Archive_Maintenance_In_Progress lockfile
1793         exists, warn the user that our output might seem strange.  (People
1794         get confused by multiple versions in a suite which happens
1795         post-kelly but pre-jenna.)
1796
1797 2003-02-21  James Troup  <james@nocrew.org>
1798
1799         * kelly (main): we don't need to worry about StableRejector.
1800
1801         * melanie (main): sort versions with apt_pkg.VersionCompare()
1802         prior to output.
1803
1804         * lauren: new script to manually reject packages from
1805         proposed-updates.  Updated code from pre-NI kelly (nee katie).
1806
1807 2003-02-20  James Troup  <james@nocrew.org>
1808
1809         * kelly (init): remove unused -m/--manual-reject argument.
1810
1811         * katie.py (Katie.force_reject): renamed from force_move to make
1812         it more explicit what this function does.
1813         (Katie.do_reject): update to match.
1814
1815         * utils.py (prefix_multi_line_string): add an optional argument
1816         include_blank_lines which defaults to 0.  If non-zero, blank lines
1817         will be includes in the output.
1818
1819         * katie.py (Katie.do_reject): don't add leading space to each line
1820         of the reject message.  Include blank lines when showing the
1821         message to the user.
1822
1823 2003-02-19  Martin Michlmayr  <tbm@cyrius.com>
1824
1825         * utils.py (fix_maintainer): replace pointless re.sub() with
1826         simple string format.
1827
1828 2003-02-11  James Troup  <james@nocrew.org>
1829
1830         * lisa (edit_overrides): only strip-to-one-char and upper-case
1831         non-numeric answers.  Fixes editing of items with indices >= 10;
1832         noticed by Randall.
1833         (edit_overrides): correct order of arguments to "not a valid
1834         index" error message.
1835
1836         * jenna (cleanup): call resolve_arch_all_vs_any() rather than
1837         remove_duplicate_versions(); thanks to aj for the initial
1838         diagnosis.
1839         (remove_duplicate_versions): correct how we return
1840         dominant_versions.
1841         (resolve_arch_all_vs_any): arch_all_versions needs to be a list of
1842         a tuple rather than just a tuple.
1843
1844 2003-02-10  James Troup  <james@nocrew.org>
1845
1846         * emilie: new script - sync fingerprint and uid tables with a
1847         debian.org LDAP DB.
1848
1849         * init_pool.sql: new table 'uid'; contains user ids.  Reference it
1850         in 'fingerprint'.
1851
1852         * db_access.py (get_or_set_uid_id): new function.
1853
1854         * jennifer (main): update locking to a) not used FCNTL (deprecated
1855         in python >= 2.2) and b) acknowledge upstream's broken
1856         implementation of lockf (see Debian bug #74777), c) try to acquire
1857         the lock non-blocking.
1858         * kelly (main): likewise.
1859
1860         * contrib/python_1.5.2-fcntl_lockf.diff: obsolete, removed.
1861
1862         * madison (main): only append the package to new_packages if it's
1863         not already in there; fixes -S/--source-and-binary for cases where
1864         the source builds a binary package of the same name.
1865
1866 2003-02-10  Anthony Towns  <ajt@debian.org>
1867
1868         * madison (main): use explicit JOIN syntax for
1869         -S/--source-and-binary queries to reduce the query's runtime from
1870         >10 seconds to negligible.
1871
1872 2003-02-08  James Troup  <james@nocrew.org>
1873
1874         * rene (main): in the NVIU output, append items to lists, not
1875         extend them; fixes amusing suggestion that "g n u m e r i c" (sic)
1876         should be removed.
1877
1878 2003-02-07  James Troup  <james@nocrew.org>
1879
1880         * apt.conf (tree "dists/unstable"): Add bzip2-ed Packages and
1881         Sources [aj].
1882
1883         * pseudo-packages.maintainers (bugs.debian.org): s/Darren
1884         O. Benham/Adam Heath/.
1885
1886         * katie.conf (Suite::Stable::Version): bump to 3.0r1a.
1887         (Suite::Stable::Description): update for 3.0r1a.
1888         (Dinstall::SigningKeyIds): update for 2003 key [aj].
1889
1890         * utils.py (gpgv_get_status_output): rename from
1891         get_status_output().
1892
1893         * neve (check_signature): use gpgv_get_status_output and Dict from
1894         utils().  Add missing newline to error message about duplicate tokens.
1895
1896         * saffron (per_arch_space_use): also print space used by source.
1897         (output_format): correct string.join() invocation.
1898
1899         * jennifer (check_signature): ignored duplicate EXPIRED tokens.
1900
1901 2003-02-04  James Troup  <james@nocrew.org>
1902
1903         * cron.buildd: correct generation of Packages/Sources and grep out
1904         non-US/non-free as well as non-free.
1905
1906 2003-02-03  Ryan Murray  <rmurray@debian.org>
1907
1908         * cron.buildd: generate quinn-diff output with full Packages/Sources
1909           files to get out-of-date vs. uncompiled right.
1910         * apt.conf.buildd: no longer generate uncompressed files, as they
1911           are generated in cron.buildd instead
1912         * add -i option to quinn-diff to ignore binary-all packages
1913         * apt.conf.buildd: remove and readd udeb to extensions.  If the udebs
1914           aren't in the packages file, the arch that uploaded them will build
1915           them anyways...
1916
1917 2003-01-30  James Troup  <james@nocrew.org>
1918
1919         * rene (main): only print suggested melanie command when there's
1920         some NBS to remove.
1921
1922 2003-01-30  Ryan Murray  <rmurray@debian.org>
1923
1924         * cron.buildd: fix incorrectly inverted lockfile check
1925
1926 2003-01-29  Ryan Murray  <rmurray@debian.org>
1927
1928         * cron.buildd: generate override.sid.all3.src
1929         * apt.conf.buildd: use generated override.sid.all3.src
1930
1931 2003-01-27  Martin Michlmayr  <tbm@cyrius.com>
1932
1933         * utils.py (get_status_output): moved from jennifer.
1934         (Dict): likewise.
1935         (check_signature): likewise.
1936
1937         * jennifer (get_status_output): moved to utils.py.
1938         (Dict): likewise.
1939         (check_signature): likewise.
1940
1941         * utils.py (check_signature): add an argument to specifiy which
1942         function to call when an error was found.
1943         (check_signature): document this function better.
1944
1945         * jennifer (check_files): pass the reject function as an argument
1946         to utils.check_signature.
1947         (process_it): likewise.
1948
1949 2003-01-20  James Troup  <james@nocrew.org>
1950
1951         * rene (main): lots of changes to improve the output and make it
1952         more useful.
1953
1954         * katie.py (Katie.check_override): make the override messages
1955         clearer (hopefully).
1956
1957 2002-12-26  James Troup  <james@nocrew.org>
1958
1959         * ziyi (usage): document the ability to pass suite(s) as
1960         argument(s).
1961         (main): read apt.conf after checking for -h/--help.
1962
1963         * tea (main): take the check to run as an argument.
1964
1965         * saffron.R: R script to graph daily install runs.
1966
1967         * saffron: new script; various stats functions.
1968
1969         * rhona (main): connect to the database after checking for -h/--help.
1970
1971         * neve (do_da_do_da): if no -a/--action option is given, bail out.
1972
1973         * melanie (main): sort versions with utils.arch_compare_sw().
1974
1975         * madison (usage): alphabetize order of options.
1976         * melanie (usage): likewise.
1977
1978         * kelly (usage): fix usage short description (we aren't dinstall).
1979
1980         * julia (usage): fix usage description and alphabetize order of
1981         options.
1982
1983         * jeri (usage): fix usage short description.
1984
1985         * jennifer (main): move --help and --version checks from here...
1986         (init): to here so that they work with an empty katie.conf.
1987         * kelly: likewise.
1988
1989         * alyson (usage): new function.
1990         (main): use it.
1991         * andrea: likewise.
1992         * ashley: likewise.
1993         * cindy: likewise.
1994         * denise: likewise.
1995         * helena: likewise.
1996         * neve: likewise.
1997         * rene: likewise.
1998         * rose: likewise.
1999         * tea: likewise.
2000
2001         * apt.conf.stable (tree "dists/stable"): add missing ExtraOverride
2002         entry that caused tasks to be omitted from 3.0r1.
2003
2004 2002-12-10  James Troup  <james@nocrew.org>
2005
2006         * jennifer (check_files): sanity check the Depends field to ensure
2007         it's non-empty if present since apt chokes on an empty one.
2008         Thanks to Ryan Murray for the idea.
2009
2010 2002-12-08  James Troup  <james@nocrew.org>
2011
2012         * katie.conf-security (Helena::Directories): new; include accepted
2013         in addition to byhand and new.
2014
2015         * helena (process_changes_files): use utils.arch_compare_sw().
2016         Justify things based on the longest [package, version,
2017         architecture].  Reduce '[note]' to '[N]' to save space, and remove
2018         the commas in architecture and version lists for the same reason.
2019         (main): make directories we process configurable through
2020         Helena::Directories in the config file; if that doesn't exist
2021         default to the old hardcoded values (byhand & new).
2022
2023         * utils.py (arch_compare_sw): moved here from madison.
2024         * madison (main): adjust to compensate.
2025
2026 2002-12-06  James Troup  <james@nocrew.org>
2027
2028         * ziyi (main): fix "suite foo not in apt.conf" msg to use the
2029         right filename.
2030
2031 2002-12-05  James Troup  <james@nocrew.org>
2032
2033         * katie.conf-non-US (Julia::KnownPostgres): add 'udmsearch'.
2034
2035 2002-11-28  Randall Donald  <rdonald@debian.org>
2036
2037         * fernanda.py (read_control): fix typo of 'Architecture'.
2038
2039 2002-11-26  James Troup  <james@nocrew.org>
2040
2041         * lisa (check_pkg): call less with '-R' so we see the colour from
2042         Randall's fernanda changes.
2043
2044         * neve (process_sources): if Directory points to a legacy location
2045         but the .dsc isn't there; assume it's broken and look in the pool.
2046         (update_section): new, borroed from alyson.
2047         (do_da_do_da): use it.
2048         (process_packages): add suite_it to the cache key used for
2049         arch_all_cache since otherwise we only add a package to the first
2050         suite it's in and ignore any subsequent ones.
2051
2052         * katie.conf-non-US (Location): fixed to reflect reality (all
2053         suites, except old-proposed-updates (which is legacy-mixed)) are
2054         pool.
2055
2056         * utils.py (try_with_debug): wrapper for print_exc().
2057         * jenna (main): use it.
2058         * neve (main): likewise.
2059
2060 2002-11-25  Randall Donald  <rdonald@debian.org>
2061
2062         * fernanda.py (main): added -R to less command line for raw control
2063         character support to print colours
2064         (check_deb): Instead of running dpkg -I on deb file, call
2065         output_deb_info, the new colourized control reporter.
2066         (check_dsc): add call to colourized dsc info reader, read_dsc, instead
2067         of printing out each .dsc line.
2068         (output_deb_info): new function. Outputs each key/value pair from
2069         read_control except in special cases where we highlight section,
2070         maintainer, architecture, depends and recommends.
2071         (create_depends_string): new function. Takes Depends tree and looks
2072         up it's compontent via projectb db, colourizes and constructs a
2073         depends string in original order.
2074         (read_dsc): new function. reads and parses .dsc info via
2075         utils.parse_changes. Build-Depends and Build-Depends-Indep are
2076         colourized.
2077         (read_control): new function. reads and parses control info via
2078         apt_pkg. Depends and Recommends are split in to list structures,
2079         Section and Architecture are colourized. Maintainer is colourized
2080         if it has a localhost.localdomain address.
2081         (split_depends): new function. Creates a list of lists of
2082         dictionaries of depends (package,version relation). Top list is
2083         colected from comma delimited items. Sub lists are | delimited.
2084         (get_comma_list): new function. splits string input among commas
2085         (get_or_list): new function. splits string input among | delimiters
2086         (get_depends_parts): new function. Creates dictionary of package name
2087         and version relation from dependancy string.
2088         Colours for section and depends are per component. Unfound depends
2089         are in bold. Lookups using version info is not supported yet.
2090
2091 2002-11-22  James Troup  <james@nocrew.org>
2092
2093         * katie.conf-security (Julia::KnownPostgres): add 'www-data' and
2094         'udmsearch'.
2095
2096         * amber (make_advisory): string.atol() is deprecated and hasn't
2097         been ported to string methods.  Use long() instead.
2098
2099         * init_pool.sql: explicitly specify the encoding (SQL_ASCII) when
2100         creating the database since we'll fail badly if it's created with
2101         e.g. UNICODE encoding.
2102
2103         * rose (main): AptCnf is a global.
2104
2105         * neve (get_location_path): new function determines the location
2106         from the the first (left-most) directory of a Filename/Directory.
2107         (process_sources): don't need 'location' anymore.  Use
2108         utils.warn().  Use the Directory: field for each package to find
2109         the .dsc.  Use get_location_path() to determine the location for
2110         each .dsc.
2111         (process_packages): do't need 'location' anymore.  Use
2112         utils.warn().  Use get_location_path().
2113         (do_sources): don't need 'location', drop 'prefix' in favour of
2114         being told the full path to the Sources file, like
2115         process_packages().
2116         (do_da_do_da): main() renamed, so that main can call us in a
2117         try/except.  Adapt for the changes in do_sources() and
2118         process_packages() above.  Assume Sources and Packages file are in
2119         <root>/dists/<etc.>.  Treat pool locations like we do legacy ones.
2120
2121         * katie.conf-security (Location): fixed to reflect reality (all
2122         suites are pool, not legacy).
2123
2124         * utils.py (print_exc): more useful (i.e. much more verbose)
2125         traceback; a recipe from the Python cookbook.
2126         * jenna (main): use it.
2127         * neve (main): likewise.
2128
2129 2002-11-19  James Troup  <james@nocrew.org>
2130
2131         * kelly (install): fix brain-damaged CopyChanges/CopyKatie
2132         handling which was FUBAR for multi-suite uploads.  Now we just
2133         make a dictionary of destinations to copy to and iterate over
2134         those.
2135
2136         * fernanda.py (check_deb): run linda as well as lintian.
2137
2138 2002-10-21  James Troup  <james@nocrew.org>
2139
2140         * melanie (main): change X-Melanie to X-Katie and prefix it with
2141         'melanie '.
2142
2143         * lisa (main): prefix X-Katie with 'lisa '.
2144
2145         * jennifer (clean_holding): fix typo in string method changes;
2146         s/file.find(file/file.find(/.
2147
2148         * cron.daily: invoke helena and send the report to ftpmaster.
2149         * cron.daily-non-US: likewise.
2150
2151 2002-10-16  James Troup  <james@nocrew.org>
2152
2153         * kelly (check): call reject() with a blank prefix when parsing
2154         the return of check_dsc_against_db() since it does its own
2155         prefix-ing.
2156
2157         * rose: new script; only handles directory creation initally.
2158
2159         * katie.conf (Dinstall::NewAckList): obsolete, removed.
2160         * katie.conf-non-US (Dinstall::NewAckList): likewise.
2161
2162 2002-10-06  James Troup  <james@nocrew.org>
2163
2164         * rene (main): remove bogus argument handling.
2165
2166         * kelly: katie, renamed.
2167         * cron.daily: adapt for katie being renamed to kelly.
2168         * cron.daily-non-US: likewise.
2169         * amber (main): likewise.
2170
2171         * Changes for python 2.1.
2172
2173         * kelly: time.strftime no longer requires a second argument of
2174         "time.localtime(time.time())".
2175         * logging.py: likewise.
2176         * rhona: likewise.
2177         * shania (init): likewise.
2178
2179         * amber: use augmented assignment.
2180         * catherine (poolize): likewise.
2181         * claire.py (fix_component_section): likewise.
2182         * halle (check_changes): likewise.
2183         * helena: likewise.
2184         * jenna: likewise.
2185         * jennifer: likewise.
2186         * jeri: likewise.
2187         * katie.py: likewise.
2188         * kelly: likewise.
2189         * lisa: likewise.
2190         * madison (main): likewise.
2191         * melanie: likewise.
2192         * natalie: likewise.
2193         * neve: likewise.
2194         * rhona: likewise.
2195         * tea: likewise.
2196         * utils.py: likewise.
2197         * ziyi: likewise.
2198
2199         * amber: use .endswith.
2200         * fernanda.py: likewise.
2201         * halle (main): likewise.
2202         * jennifer: likewise.
2203         * jeri: likewise.
2204         * katie.py: likewise.
2205         * kelly: likewise.
2206         * lisa: likewise.
2207         * neve: likewise.
2208         * shania (main): likewise.
2209         * utils.py: likewise.
2210
2211         * alyson: use string methods.
2212         * amber: likewise.
2213         * andrea: likewise.
2214         * ashley: likewise.
2215         * catherine: likewise.
2216         * charisma: likewise.
2217         * claire.py: likewise.
2218         * db_access.py: likewise.
2219         * denise: likewise.
2220         * halle: likewise.
2221         * heidi: likewise.
2222         * helena: likewise.
2223         * jenna: likewise.
2224         * jennifer: likewise.
2225         * jeri: likewise.
2226         * julia: likewise.
2227         * katie.py: likewise.
2228         * kelly: likewise.
2229         * lisa: likewise.
2230         * logging.py: likewise.
2231         * madison: likewise.
2232         * melanie: likewise.
2233         * natalie: likewise.
2234         * neve: likewise.
2235         * rene: likewise.
2236         * tea: likewise.
2237         * utils.py: likewise.
2238         * ziyi: likewise.
2239
2240 2002-09-20  Martin Michlmayr  <tbm@cyrius.com>
2241
2242         * utils.py (parse_changes): use <string>.startswith() rather than
2243         string.find().
2244
2245 2002-08-27  Anthony Towns  <ajt@debian.org>
2246
2247         * katie.py (in_override_p): when searching for a source override,
2248         and the dsc query misses, search for both udeb and deb overrides
2249         as well. Should fix the UNACCEPT issues with udebs.
2250
2251 2002-08-24  James Troup  <james@nocrew.org>
2252
2253         * melanie (main): remove gratuitous WHERE EXISTS sub-select from
2254         source+binary package finding code which was causing severe
2255         performance degradation with postgres 7.2.
2256
2257 2002-08-14  James Troup  <james@nocrew.org>
2258
2259         * julia (main): use the pwd.getpwall() to get system user info
2260         rather than trying to read a password file.  Add a -n/--no-action
2261         option.
2262
2263         * cron.hourly: julia no longer takes any arguments.
2264         * cron.hourly-non-US: likewise.
2265
2266 2002-08-07  James Troup  <james@nocrew.org>
2267
2268         * katie (install): handle multi-suite uploads when CopyChanges
2269         and/or CopyKatie are in use, ensuring we only copy stuff once.
2270
2271 2002-08-01  Ryan Murray  <rmurray@debian.org>
2272
2273         * wanna-build/trigger.daily: initial commit, with locking
2274         * cron.buildd: add locking against daily run
2275
2276 2002-07-30  James Troup  <james@nocrew.org>
2277
2278         * melanie (main): readd creation of suite_ids_list so melanie is
2279         remotely useful again.
2280
2281         * katie.conf: adopt for woody release; diable
2282         StableDislocationSupport, add oldstable, adjust other suites and
2283         mappings, fix up location.
2284         * katie.conf-non-US: likewise.
2285         * katie.conf-security: likewise.
2286
2287         * apt.conf.stable: adapt for woody release; add oldstable, adjust
2288         stable.
2289         * apt.conf.stable-non-US: likewise.
2290
2291         * apt.conf-security: adapt for woody release; adding oldstable,
2292         oldstable, adjust stable and testing.
2293         * cron.daily-security: likewise.
2294         * cron.buildd-security: likewise.
2295
2296         * apt.conf: adapt for woody release; rename woody-proposed-updates
2297         to testing-proposed-updates and proposed-updates to
2298         old-proposed-updates.
2299         * apt.conf-non-US: likewise.
2300
2301         * vars-non-US (copyoverrides): add sarge.
2302         * vars (copyoverrides): likewise.
2303
2304         * vars-security (suites): add oldstable.
2305
2306 2002-07-22  Ryan Murray  <rmurray@debian.org>
2307
2308         * apt.conf.security-buildd: use suite codenames instead of
2309           distnames.
2310
2311 2002-07-16  James Troup  <james@nocrew.org>
2312
2313         * denise (main): fix filenames for testing override files.
2314
2315 2002-07-14  James Troup  <james@nocrew.org>
2316
2317         * jennifer (process_it): call check_md5sums later so we can check
2318         files in the .dsc too
2319         (check_md5sums): check files in the .dsc too.  Check both md5sum
2320         and size.
2321
2322         * melanie (main): use parse_args() and join_with_commas_and() from
2323         utils.  If there's nothing to do, say so and exit, don't ask for
2324         confirmation etc.
2325
2326         * amber (join_with_commas_and): moved from here to ...
2327         * utils.py (join_with_commas_and): here.
2328
2329 2002-07-13  James Troup  <james@nocrew.org>
2330
2331         * madison (main): use parse_args() from utils.  Support
2332         -c/--component.
2333
2334         * jenna (parse_args): moved from here to ...
2335         * utils.py (parse_args): here.
2336
2337         * katie.conf (Architectures): minor corrections to the description
2338         for arm, mips and mipsel.
2339         * katie.conf-non-US (Architectures): likewise.
2340         * katie.conf-security (Architectures): likewise.
2341
2342         * cron.daily-security: use natalie's new -a/--add functionality to
2343         flesh out the security overrides.
2344
2345 2002-07-12  James Troup  <james@nocrew.org>
2346
2347         * cron.buildd (ARCHS): add arm.
2348
2349         * katie.conf: 2.2r7 was released.
2350         * katie.conf-non-US: likewise.
2351
2352         * utils.py (parse_changes): handle a multi-line field with no
2353         starting line.
2354
2355 2002-06-25  James Troup  <james@nocrew.org>
2356
2357         * templates/amber.advisory (To): add missing email address since
2358         __WHOAMI__ is only a name.
2359
2360         * katie.conf-security (Melane::LogFile): correct to go somewhere
2361         katie has write access to.
2362         (Location::/org/security.debian.org/ftp/dists/::Suites): add
2363         Testing.
2364
2365         * natalie: add support for -a/-add which adds packages only
2366         (ignoring changes and deletions).
2367
2368         * katie.py (Katie.announce): Dinstall::CloseBugs is a boolean so
2369         use FindB, not get.
2370
2371 2002-06-22  James Troup  <james@nocrew.org>
2372
2373         * jennifer (check_files): validate the package name and version
2374         field.  If 'Package', 'Version' or 'Architecture' are missing,
2375         don't try any further checks.
2376         (check_dsc): likewise.
2377
2378         * utils.py (re_taint_free): add '~' as a valid character.
2379
2380 2002-06-20  Anthony Towns  <ajt@debian.org>
2381
2382         * katie.conf-non-US: add OverrideSuite for w-p-u to allow uploads
2383
2384 2002-06-09  James Troup  <james@nocrew.org>
2385
2386         * jennifer (check_files): reduce useless code.
2387
2388         * cron.daily-security: run symlinks -dr on $ftpdir.
2389
2390         * vars-security (ftpdir): add.
2391
2392 2002-06-08  James Troup  <james@nocrew.org>
2393
2394         * neve (update_override_type): transaction is handled higher up in
2395         main().
2396         (update_priority): likewise.
2397         (process_sources): remove code that makes testing a duplicate of
2398         stable.
2399         (process_packages): likewise.
2400
2401         * templates/amber.advisory: add missing mail headers.
2402
2403         * cron.daily-security: also call apt-ftparchive clean for
2404         apt.conf.buildd-security.
2405         * cron.weekly: likewise.
2406
2407         * amber (do_upload): write out a list of source packages (and
2408         their version) uploaded for testing.
2409         (make_advisory): add more Subst mappings for the mail headers.
2410         (spawn): check for suspicious characters in the command and abort
2411         if their found.
2412
2413 2002-06-07  James Troup  <james@nocrew.org>
2414
2415         * ziyi (main): remove the 'nonus'/'security' hacks and use
2416         Dinstall::SuiteSuffix (if it exists) instead.  Always try to write
2417         the lower level Release files, even if they don't exist.  fubar
2418         out if we can't open a lower level Release file for writing.
2419
2420         * katie.conf-non-US (Dinstall): add SuiteSuffix, used to simplify
2421         ziyi.
2422         * katie.conf-security (Dinstall): likewise.
2423
2424         * amber (do_upload): renamed from get_file_list().  Determine the
2425         upload host from the original component.
2426         (init): Add a -n/--no-action option.  Fix how we get changes_files
2427         (i.e. from the return value of apt_pkg.ParseCommandLine(), not
2428         sys.argv).  Add an Options global.
2429         (make_advisory): support -n/--no-action.
2430         (spawn): likewise.
2431         (main): likewise.
2432         (usage): document -n/--no-action.
2433
2434         * cron.buildd-security: fix path to Packages-arch-specific in
2435         quinn-diff invocation.
2436
2437         * katie.conf-security (Dinstall::AcceptedAutoBuildSuites): change
2438         to proper suite names (i.e. stable, testing) rather than codenames
2439         (potato, woody).
2440         (Dinstall::DefaultSuite): likewise.
2441         (Suite): likewise.
2442         (Location::/org/security.debian.org/ftp/dists/::Suites): likewise.
2443         * vars-security (suites): likewise.
2444         * apt.conf-security: likewise.
2445
2446         * katie.conf-security (Component): add "updates/" prefix.
2447         (Suite::*::Components): likewise.
2448         (ComponentMappings): new; map all {ftp-master,non-US} components
2449         -> updates/<foo>.
2450
2451         * katie.conf-security (Natalie): removed; the options have
2452         defaults and ComponentPosition is used by alyson which doesn't
2453         work on security.d.o.
2454         (Amber): replace UploadHost and UploadDir with ComponentMappings
2455         which is a mapping of components -> URI.
2456         (Suite::*::CodeName): strip bogus "/updates" suffix hack.
2457         (SuiteMappings): use "silent-map" in preference to "map".
2458
2459         * cron.unchecked-security: fix call to cron.buildd-security.
2460
2461         * cron.daily-security: map local suite (stable) -> override suite
2462         (potato) when fixing overrides.  Correct component in natalie call
2463         to take into account "updates/" prefix.  Fix cut'n'waste in
2464         override.$dist.all3 generation, the old files weren't being
2465         removed, so they were endlessly growing.
2466
2467         * neve (main): don't use .Find for the CodeName since we require
2468         it.  Location::*::Suites is a ValueList.
2469         (check_signature): ignore duplicate SIGEXPIRED tokens.  Don't bomb
2470         out on expired keys, just warn.
2471         (update_override_type): new function; lifted from alyson.
2472         (update_priority): likewise.
2473         (main): use update_{override_type,priority}().
2474
2475         * jennifer (check_distributions): remove redunant test for
2476         SuiteMappings; ValueList("does-not-exist") returns [] which is
2477         fine.  Add support for a "silent-map" type which doesn't warn
2478         about the mapping to the user.
2479         (check_files): add support for ComponentMappings, similar to
2480         SuiteMappings, but there's no type, just a source and a
2481         destination and the original component is stored in "original
2482         component".
2483         * katie.py (Katie.dump_vars): add "original component" as an
2484         optionsal files[file] dump variable.
2485
2486         * claire.py (find_dislocated_stable): dehardcode 'potato' in SQL
2487         query.  Add support for section-less legacy locations like current
2488         security.debian.org through YetAnotherConfigBoolean
2489         'LegacyStableHasNoSections'.
2490         * katie.conf-security (Dinstall): LegacyStableHasNoSections is true.
2491
2492         * utils.py (real_arch): moved here from ziyi.
2493         * ziyi (real_arch): moved to utils.py.
2494         * ziyi (main): likewise.
2495
2496         * claire.py (find_dislocated_stable): use real_arch() with
2497         filter() to strip out source and all.
2498         * neve (main): likewise.
2499         * rene (main): likewise.
2500         * jeri (parse_packages): likewise.
2501
2502 2002-06-06  James Troup  <james@nocrew.org>
2503
2504         * tea (check_missing_tar_gz_in_dsc): modifed patch from Martin
2505         Michlmayr <tbm@cyrius.com> to be more verbose about what we're
2506         doing.
2507
2508 2002-05-23  Martin Michlmayr  <tbm@cyrius.com>
2509
2510         * jeri (check_joey): check if the line contains two elements
2511         before accessing the second.  Also, strip trailing spaces as well
2512         as the newline.
2513         * halle (check_joey): likewise.
2514
2515 2002-06-05  James Troup  <james@nocrew.org>
2516
2517         * cron.unchecked-security: new file; like cron.unchecked but if
2518         there's nothing to do exit so we don't call cron.buildd-security.
2519
2520         * apt.conf.buildd-security: new file.
2521
2522         * vars (archs): alphabetize.
2523         * vars-non-US (archs): likewise.
2524
2525         * vars-security: add unchecked.
2526
2527         * madison (main): reduce rather bizarrely verbose and purposeless
2528         code to print arches to a simple string.join.
2529
2530         * katie.conf (Suites::Unstable): add UdebComponents, a new
2531         valuelist of suites, used by jenna to flesh out the list of
2532         <suite>_main-debian-installer-binary-<arch>.list files generated.
2533         (Dinstall): add StableDislocationSupport, a new boolean used by
2534         jenna to enable or disable stable dislocation support
2535         (i.e. claire), as true.
2536
2537         * katie.conf (Dinstall): add StableDislocationSupport, a new
2538         boolean used by jenna to enable or disable stable dislocation
2539         support (i.e. claire), as true.
2540         * katie.conf-non-US: likewise.
2541         * katie.conf-security: likewise.
2542
2543         * cron.daily-security: generate .all3 overrides for the buildd
2544         support.  Freshen a local copy of Packages-arch-specific from
2545         buildd.debian.org.
2546
2547         * claire.py (find_dislocated_stable): disable the support for
2548         files in legacy-mixed locations since none of the Debian archives
2549         have any anymore.
2550
2551         * helena: new script; produces a report on NEW and BYHAND
2552         packages.
2553
2554         * jenna: rewritten from scratch to fix speed problems.  Run time
2555         on auric goes down from 31.5 minutes to 3.5 minutes.  Of that 3.5
2556         minutes, 105 seconds are the monster query and 70 odd seconds is
2557         claire.
2558
2559         * apt.conf.buildd (Default): remove MaxContentsChange as it's
2560         irrelevant.
2561
2562 2002-06-05  Ryan Murray  <rmurray@debian.org>
2563
2564         * cron.buildd-security: new file.
2565
2566 2002-06-05  Matt Kraai  <kraai@alumni.cmu.edu>
2567
2568         * denise (list): take a file argument and use it.
2569         (main): don't abuse sys.stdout, just write to the file.
2570
2571         * claire.py (usage): Fix misspelling.
2572         (clean_symlink): Simplify.
2573         (find_dislocated_stable): Avoid unnecessary work.
2574
2575 2002-05-29  James Troup  <james@nocrew.org>
2576
2577         * cameron: removed; apt-ftparchive can simply walk the directory.
2578
2579 2002-05-26  Anthony Towns  <ajt@debian.org>
2580
2581         * katie.conf{,-non-US}: Map testing to testing-proposed-updates
2582         for the autobuilders.
2583
2584 2002-05-24  Ryan Murray  <rmurray@debian.org>
2585
2586         * cron.buildd: update override files before running apt-ftparchive
2587
2588 2002-05-23  Martin Michlmayr  <tbm@cyrius.com>
2589
2590         * amber (main): remove extra space in prompt.
2591
2592         * utils.py (validate_changes_file_arg): use original filename in
2593         error messages.
2594
2595         * jeri (check_joey): close file after use.
2596         (parse_packages): likewise.
2597         (main): setup debug option properly.
2598
2599         * melanie (main): remove unused packages variable and simplify the
2600         code to build up con_packages by using repr().
2601
2602 2002-05-23  James Troup  <james@nocrew.org>
2603
2604         * lisa (recheck): when we reject, also return 0 so the package is
2605         skipped.
2606         (sg_compare): fix note sorting.
2607         (recheck): remove the .katie file after rejection.
2608
2609         * katie.py (Katie.accept): accepted auto-build support take 3;
2610         this time adding support for security.  Security needs a) non-pool
2611         files copied rather than symlinked since accepted is readable only
2612         by katie/security and www-data needs to be able to see the files,
2613         b) needs per-suite directories.  SpecialAcceptedAutoBuild becomes
2614         AcceptedAutoBuildSuites and is a ValueList containing the suites.
2615         SecurityAcceptedAutoBuild is a new boolean which controls whether
2616         or not normal or security style is used.  The unstable_accepted
2617         table was renamed to accepted_autobuild and a suite column added.
2618         Also fix a bug noticed by Ryan where an existent orig.tar.gz
2619         didn't have it's last_used/in_accepted flags correctly updated.
2620         * katie (install): likewise.
2621         * rhona (clean_accepted_autobuild): likewise.
2622
2623 2002-05-22  James Troup  <james@nocrew.org>
2624
2625         * lisa (sort_changes): new function; sorts changes properly.
2626         Finally.
2627         (sg_compare): new function; helper for sort_changes().  Sorts by
2628         have note and time of oldest upload.
2629         (indiv_sg_compare): new function; helper for sort_changes().
2630         Sorts by source version, have source and filename.
2631         (main): use sort_changes().
2632         (changes_compare): obsoleted; removed.
2633
2634 2002-05-20  James Troup  <james@nocrew.org>
2635
2636         * rhona (clean_accepted_autobuild): don't die if a file we're
2637         trying to remove doesn't exist.  Makes rhona more friendly to
2638         katie/katie.py crashes/bugs without any undue cost.
2639
2640 2002-05-19  James Troup  <james@nocrew.org>
2641
2642         * lisa (main): if sorting a large number of changes give some
2643         feedback.
2644         (recheck): new function, run the same checks (modulo NEW,
2645         obviously) as katie does, if they fail do the standard
2646         reject/skip/quit dance.
2647         (do_pkg): use it.
2648
2649         * katie (install): don't try to unlink the symlink in the
2650         AcceptedAutoBuild support if the destination is not a symlink (or
2651         doesn't exist).  Avoids unnecessary bombs on previous partial
2652         accepts and will still bomb hard if the file exists and isn't a
2653         symlink.
2654
2655         * utils.py: blah, commands _is_ used when the mail stuff isn't
2656         commented out like it is in my test environment.
2657
2658         * lisa (changes_compare): "has note" overrides everything else.
2659         Use .katie files rather than running parse_changes, faster and
2660         allows "has note" to work.  Correct version compare, it was
2661         reversed.  Ctime check should only kick in if the source packages
2662         are not the same.
2663         (print_new): print out and return any note.  Rename 'ret_code' to
2664         'broken'.
2665         (edit_new): renamed from spawn_editor.  Don't leak file
2666         descriptors.  Clean up error message if editor fails.
2667         (edit_note): new function, allows one to edit notes.
2668         (do_new): add note support, editing and removing.
2669         (init): kill -s/--sort; with notes we always want to use our
2670         sorting method.
2671         (usage): likewise.
2672
2673         * katie.py (Katie.dump_vars): add "lisa note" as an optional
2674         changes field.
2675
2676         * utils.py (build_file_list): rename 'dsc' to 'is_a_dsc' and have
2677         it default to 0.  Adapt tests to assume it's boolean.
2678         * fernanda.py (check_changes): adjust call appropriately.
2679         * halle (check_changes): likewise.
2680         * jennifer (check_changes): likewise.
2681         * jeri (check_changes): likewise.
2682         * shania (flush_orphans): likewise.
2683
2684         * jennifer (check_dsc): pass is_a_dsc by name when calling
2685         build_file_list() for clarity.
2686         * shania (flush_orphans): likewise.
2687         * tea (check_missing_tar_gz_in_dsc): likewise.
2688
2689         * jennifer (check_dsc): pass dsc_whitespace_rules by name when
2690         calling parse_changes() for clarity.
2691         * tea (check_dscs): likewise.
2692
2693         * utils.py (parse_changes): make dsc_whitespace_rules default to
2694         not true.
2695         * halle (check_changes): adjust call appropriately.
2696         * jennifer (check_changes): likewise.
2697         * jeri (check_changes): likewise.
2698         * lisa (changes_compare): likewise.
2699         * utils.py (changes_compare): likewise.
2700         * melanie (main): likewise.
2701         * shania (flush_orphans): likewise.
2702         * fernanda.py (check_changes): likewise.
2703
2704 2002-05-18  James Troup  <james@nocrew.org>
2705
2706         * katie.py (Katie.dump_vars): make the .katie file unreadable,
2707         it's not useful and by and large a duplication of information
2708         available in readable format in other files.
2709
2710 2002-05-16  Ryan Murray  <rmurray@debian.org>
2711
2712         * melanie: Dir::TemplatesDir -> Dir::Templates
2713
2714 2002-05-15  Ryan Murray  <rmurray@debian.org>
2715
2716         * cameron: correct the use of os.path.join
2717
2718 2002-05-15  Anthony Towns  <ajt@debian.org>
2719
2720         * ziyi: Update to match the new format for Architectures/Components
2721         in katie.conf.
2722
2723 2002-05-14  James Troup  <james@nocrew.org>
2724
2725         * amber: new script; 'installer' wrapper script for the security
2726         team.
2727
2728         * katie.py (Katie.announce): remove unused 'dsc' local
2729         variable. (pychecker)
2730
2731         * ziyi: pre-define AptCnf and out globals to None. (pychecker)
2732
2733         * neve: don't import sys, we don't use it. (pychecker)
2734         (check_signature): fix return type mismatch. (pychecker)
2735
2736         * utils.py: don't import commands, we don't use it.  (pychecker)
2737
2738         * katie (install): SpecialAcceptedAutoBuild is a boolean.
2739
2740         * katie.py (Katie.dump_vars): don't store "oldfiles", it's
2741         obsoleted by the change to "othercomponents" handling in jennifer
2742         detailed below.
2743         (Katie.cross_suite_version_check): new function; implements
2744         cross-suite version checking rules specified in the conf file
2745         while also enforcing the standard "must be newer than target
2746         suite" rule.
2747         (Katie.check_binary_against_db): renamed, since it's invoked once
2748         per-binary, "binaries" was inaccurate.  Use
2749         cross_suite_version_check() and don't bother with the "oldfiles"
2750         rubbish as jennifer works out "othercomponents" herself now.
2751         (Katie.check_source_against_db): use cross_suite_version_check().
2752
2753         * katie (check): the version and file overwrite checks
2754         (check_{binary,source,dsc}_against_db) are not per-suite.
2755
2756         * jennifer (check_files): less duplication of
2757         'control.Find("Architecture", "")' by putting it in a local
2758         variable.
2759         (check_files): call check_binary_against_db higher up since it's
2760         not a per-suite check.
2761         (check_files): get "othercomponents" directly rather than having
2762         check_binary_against_db do it for us.
2763
2764         * heidi (main): 'if x:', not 'if x != []:'.
2765         * katie.py (Katie.in_override_p): likewise.
2766         (Katie.check_dsc_against_db): likewise.
2767         * natalie (main): likewise.
2768         * rene (main): likewise.
2769         * ziyi (real_arch): likewise.
2770
2771         * alyson (main): Suite::%s::Architectures, Suite::%s::Components
2772         and OverrideType are now value lists, not lists.
2773         * andrea (main): likewise.
2774         * cindy (main): likewise.
2775         * claire.py (find_dislocated_stable): likewise.
2776         * denise (main): likewise.
2777         * jenna (main): likewise.
2778         * jennifer (check_distributions): likewise.
2779         (check_files): likewise.
2780         (check_urgency): likewise (Urgency::Valid).
2781         * jeri (parse_packages): likewise.
2782         * neve (main): likewise (and Location::%s::Suites).
2783         * rene (main): likewise.
2784
2785 2002-05-13  James Troup  <james@nocrew.org>
2786
2787         * katie.py (Katie.check_source_against_db): correct case of reject
2788         message to be consistent with binary checks.
2789
2790         * jennifer (get_status_output): don't leak 2 file descriptors per
2791         invocation.
2792         (check_signature): add missing '\n' to "duplicate status token"
2793         error message.
2794
2795 2002-05-09  James Troup  <james@nocrew.org>
2796
2797         * utils.py (validate_changes_file_arg): new function; validates an
2798         argument which should be a .changes file.
2799         * ashley (main): use it.
2800         * lisa (main): likewise.
2801
2802         * katie.py (Katie.check_dsc_against_db): since there can be more
2803         than one .orig.tar.gz make sure we don't assume the .orig.tar.gz
2804         entry still exists in files.
2805
2806         * jennifer (check_dsc): handle the .orig.tar.gz disappearing from
2807         files, since check_dsc_against_db() deletes the .orig.tar.gz
2808         entry.
2809
2810         * cameron: cleanups.
2811
2812         * utils.py (changes_compare): change sort order so that source
2813         name and source version trump 'have source'; this should fix
2814         UNACCEPT problems in katie where -1 hppa+source & i386, -2
2815         i386&source & hppa lead to -1 i386 unaccept.  Problem worked out
2816         by Ryan.
2817
2818         * lisa (main): allow the arguments to be .katie files too.
2819
2820 2002-05-07  Ryan Murray  <rmurray@debian.org>
2821
2822         * cron.buildd: add s390 to arch list again
2823
2824 2002-05-05  Ryan Murray  <rmurray@debian.org>
2825
2826         * cron.buildd: new script, update w-b database from unstable_accepted
2827         table
2828         * cameron: new script, take list in unstable_accepted and write out
2829         a file list for apt-ftparchive
2830         * apt.conf.buildd: new apt configuration for Packages/Sources for
2831         unstable_accepted
2832         * vars: add s390 to arch list.
2833
2834 2002-05-03  James Troup  <james@nocrew.org>
2835
2836         * neve (main): don't hard code the calling user as that doesn't
2837         work with modern postgres installs.  Fix psql invocation for
2838         init_pool.sql (database name required).  Dont' hard code the
2839         database name.
2840         (process_sources): add support for fingerprint and install_date.
2841         (process_packages): add support for fingerprint.
2842         (do_sources): pass in the directory, fingerprint support needs it.
2843         (get_status_output): borrowed from jennifer.
2844         (reject): likewise.
2845         (check_signature): likewise.
2846
2847         * katie (install): only try to log urgencies if Urgency_Logger is
2848         defined.
2849         (main): only initialize Urgency_Logger is Dir::UrgencyLog is
2850         defined; only close Urgency_Logger if it's defined.
2851
2852         * catherine (poolize): adapt for Dir rationalization.
2853         * claire.py (find_dislocated_stable): likewise.
2854         * denise (main): likewise.
2855         * halle (check_joey): likewise.
2856         * jenna: likewise.
2857         * jennifer: likewise.
2858         * jeri: likewise.
2859         * katie.py: likewise.
2860         * katie: likewise.
2861         * lisa (do_bxa_notification): likewise.
2862         * logging.py (Logger.__init__): likewise
2863         * rene (main): likewise.
2864         * rhona (clean): likewise.
2865         * shania (init): likewise.
2866         * tea: likewise.
2867         * ziyi: likewise.
2868
2869         * lisa (add_overrides): Dinstall::BXANotify is a boolean, use
2870         FindB, not FindI.
2871
2872         * rhona (clean_accepted_autobuild): SpecialAcceptedAutoBuild is a
2873         boolean, use FindB, not get.
2874
2875         * katie.py (Katie.check_dsc_against_db): ignore duplicate
2876         .orig.tar.gz's which are an exact (size/md5sum) match.
2877
2878         * ashley (main): really allow *.katie files as arguments too;
2879         noticed by aj.
2880
2881         * sql-aptvc.cpp: postgres.h moved to a "server" subdirectory.
2882
2883 2002-05-03  Anthony Towns  <ajt@debian.org>
2884
2885         * ziyi: support for security.
2886
2887 2002-05-02  James Troup  <james@nocrew.org>
2888
2889         * jennifer (accept): call Katie.check_override() unconditional as
2890         no-mail check moved into that function.
2891         (do_byhand): likewise.
2892
2893         * katie.py (Katie.check_override): don't do anything if we're a)
2894         not sending mail or b) the override disparity checks have been
2895         disbled via Dinstall::OverrideDisparityCheck.
2896
2897         * jennifer (check_files): don't hard code Unstable as the suite
2898         used to check for architecture validity; use
2899         Dinstall::DefaultSuite instead, if it exists.
2900         (accept): conditionalize
2901
2902         * katie.py (Katie.update_subst): support global maintainer
2903         override with Dinstall::OverrideMaintainer.
2904
2905         * jennifer (check_distributions): new function, Distribution
2906         validation and mapping.  Uses new SuiteMappings variable from
2907         config file to abstract suite mappings.
2908         (check_changes): call it.
2909
2910         * natalie: renamed; nothing imports or likely will for some time.
2911
2912         * denise (main): remove unused natalie import and init().
2913
2914         * natalie.py (init): removed.
2915         (main): initalize here instead and don't hardcode the database
2916         name.
2917
2918 2002-04-30  James Troup  <james@nocrew.org>
2919
2920         * katie.py (Katie.close_bugs): new function, split out from
2921         announce().
2922         (Katie.announce): only call close_bugs() if Dinstall::CloseBugs is
2923         true.
2924         (Katie.close_bugs): new function, split out
2925         (Katie.close_bugs): return immediately if there are no bugs to
2926         close.
2927
2928         * jennifer (acknowledge_new): adapt for new utils.TemplateSubst().
2929         * katie (do_reject): likewise.
2930         (stable_install): likewise.
2931         * katie.py (Katie.announce): likewise.
2932         (Katie.accept): likewise.
2933         (Katie.check_override): likewise.
2934         (Katie.do_reject): likewise.
2935         * lisa (do_bxa_notification): likewise.
2936         * melanie (main): likewise.
2937
2938         * utils.py (TemplateSubst): change second argument to be a
2939         filename rather than a template since every caller opened a file
2940         on the fly which was ugly and leaked file descriptor.
2941
2942 2002-04-29  James Troup  <james@nocrew.org>
2943
2944         * katie.py (Katie.announce): (modified) patch from Raphael Hertzog
2945         <hertzog@debian.org> to send 'accepted' announce mails to the
2946         PTS. [#128140]
2947
2948 2002-04-24  James Troup  <james@nocrew.org>
2949
2950         * init_pool.sql (unstable_accepted): add two new fields to
2951         unstable_accepted; in_accepted is a boolean indicating whether or
2952         not the file is in accepted and last_used is a timestamp used by
2953         rhona to determine when to remove symlinks for installed packages.
2954
2955         * katie.py (Katie.accept): auto-build support take 2.  Create
2956         symlinks for all files into a seperate directory.  Add files to
2957         unstable_accepted as paths to the new directory; mark them as
2958         being in accepted for cameron.  Properly conditionalize it on a
2959         configuration variable.
2960
2961         * katie (install): likewise.  Update symlinks to point into the
2962         pool; mark the files for later deletion by rhona and mark them as
2963         not being in accepted for cameron.
2964
2965         * rhona (clean_accepted_autobuild): new function.
2966
2967 2002-04-22  James Troup  <james@nocrew.org>
2968
2969         * jennifer (check_files): handle db_access.get_location_id()
2970         returning -1 properly/better.
2971
2972         * rhona (clean_fingerprints): new function.
2973
2974 2002-04-21  James Troup  <james@nocrew.org>
2975
2976         * utils.py (touch_file): unused; remove.
2977         (plural): likewise.
2978
2979         * jennifer (check_files): close file descriptor used to get the
2980         control file.
2981         (check_md5sums): likewise.
2982         (callback): likewise.
2983
2984         * katie.py (Katie.do_reject): handle manual rejects much better;
2985         call the editor first and get confirmation from the user before
2986         proceeding.
2987
2988         * jennifer (check_signature): prefix_multi_line_string() moved to
2989         utils.
2990
2991         * utils.py (prefix_multi_line_string): moved here from jennifer.
2992
2993 2002-04-20  James Troup  <james@nocrew.org>
2994
2995         * lisa (main): handle non-existent files.
2996
2997         * ashley (main): allow *.katie files as arguments too.
2998
2999 2002-04-19  James Troup  <james@nocrew.org>
3000
3001         * katie.py (Katie.accept): add stuff to help auto-building from
3002         accepted; if the .orig.tar.gz is not part of the upload (i.e. it's
3003         in the pool), create a symlink to it in the accepted directory and
3004         add the .dsc and .{u,}deb(s) to a new 'unstable_accepted' table.
3005
3006         * katie (install): undo the "auto-building from accepted" stuff
3007         (i.e. remove the .orig.tar.gz symlink and remove the files from
3008         unstable_accepted table).
3009
3010 2002-04-16  James Troup  <james@nocrew.org>
3011
3012         * jennifer (upload_too_new): fix typo which was causing all
3013         timestamp comparisons to be against the .changes file.  Also move
3014         back to the original directory so we do the comparisons against
3015         accurate timestamps.
3016
3017         * tea (check_missing_tar_gz_in_dsc): new function.
3018
3019         * jennifer (check_dsc): add a check to ensure there is a .tar.gz
3020         file mentioned in the .dsc.
3021
3022         * lisa (main): use X-Katie in the mail headers, not X-Lisa; that
3023         way mails reach debian-{devel-,}changes@l.d.o.
3024
3025 2002-04-02  Ryan Murray  <rmurray@debian.org>
3026
3027         * cron.daily: run shania after rhona
3028         * cron.daily-non-US: likewise.
3029
3030 2002-04-01  James Troup  <james@nocrew.org>
3031
3032         * katie: re-add proposed-updates/stable install support.
3033
3034         * katie.py (Katie.dump_vars): add changes["changes"] as an
3035         optional field; should be mandatory later.
3036
3037 2002-03-31  James Troup  <james@nocrew.org>
3038
3039         * katie (install): support a Suite::<foo>::CopyKatie similar to
3040         CopyChanges.  Done seperately because .katie files don't need to
3041         be mirrored and will probably be copied to another directory as a
3042         result.
3043
3044         * halle (main): add missing debug to options.
3045
3046 2002-03-29  James Troup  <james@nocrew.org>
3047
3048         * madison (main): add a -r/--regex option.
3049
3050 2002-03-26  James Troup  <james@nocrew.org>
3051
3052         * lisa: don't trample on changes["distribution"]; make a copy of
3053         it as changes["suite"] instead and use that.
3054
3055 2002-03-16  Anthony Towns  <ajt@debian.org>
3056
3057         * templates/lisa.bxa_notification: Fix some grammatical errors.
3058         Encourage contact via bxa@ftp-master email address.
3059
3060 2002-03-15  James Troup  <james@nocrew.org>
3061
3062         * jennifer (check_timestamps): remove bogus raise in except.
3063
3064 2002-03-15  Anthony Towns  <ajt@debian.org>
3065
3066         * cron.monthly: rotate mail/archive/bxamail as well as
3067         mail/archive/mail. This is for a complete archive of
3068         correspondence with the BXA.
3069
3070 2002-03-14  Anthony Towns  <ajt@debian.org>
3071
3072         * crypto-in-main changes.
3073
3074         * utils.py (move, copy): add an optional perms= parameter to let you
3075         set the resulting permissions of the moved/copied file
3076         * katie.py (force_move): rejected/morgued files should be unreadable
3077         * jennifer (do_byhand, acknowledge_new): pending new and byhand files
3078         should be unreadable.
3079
3080 2002-03-07  Ryan Murray  <rmurray@debian.org>
3081
3082         * katie (install): check for existance of "files id" key as well as
3083         it being set to a valid value.
3084         * katie (install): check for existense and valid value for location
3085         id as well
3086
3087 2002-03-05  Ryan Murray  <rmurray@debian.org>
3088
3089         * katie.py (do_reject): reread the reason file after editing it.
3090
3091 2002-02-25  James Troup  <james@nocrew.org>
3092
3093         * jennifer (check_changes): don't enforce sanity in .changes file
3094         names since it doesn't seem to be possible; pcmica-cs and similar
3095         freak show packages in particular cause real problems.
3096
3097         * katie.py (Katie.check_dsc_against_db): initialize 'found' for
3098         each dsc_file since the .orig.tar.gz checking code now uses it as
3099         a boolean.  Fixes bizarro rejections which bogusly claimed
3100         .diff.gz md5sum/size was incorrect.
3101
3102 2002-02-24  James Troup  <james@nocrew.org>
3103
3104         * katie (process_it): reset reject_message.
3105
3106 2002-02-22  James Troup  <james@nocrew.org>
3107
3108         * db_access.py(set_files_id): disable use of
3109         currval('files_id_seq') because it was taking 3 seconds on auric
3110         which is insane (most calls take < 0.01) and simply call
3111         get_files_id() for the return value instead.
3112
3113         * katie.py (Katie.do_query): convenience function; unused by
3114         default, useful for profiling.
3115         * db_access.py (do_query): likewise.
3116
3117         * katie (install): fix insert SQL call when binary has no source.
3118
3119         * lisa (determine_new): auto-correct non-US/main to non-US.
3120         (determine_new): add a warning when adding things to stable.
3121         (edit_index): use our_raw_input().
3122         (edit_overrides): likewise.
3123         (do_new): likewise.  Use re.search() not re.match() since the
3124         default answer may not be the first one.
3125         (do_byhand): likewise.
3126         (do_new): Default to 'S'kip and never 'A'dd.
3127
3128         * jennifer (action): pass prompt to our_raw_input().
3129         * melanie (game_over): likewise.
3130         * katie (action): likewise.
3131
3132         * utils.py (our_raw_input): add an optional prompt argument to
3133         make the function more usable as a drop in replacement for
3134         raw_input().
3135
3136         * jennifer (check_files): correct reject() to not double prefix
3137         when using katie.py based functions.
3138         (check_dsc): likewise.
3139
3140         * katie.py (Katie.reject): prepend a new line if appropriate
3141         rathen than appending one to avoid double new lines when caller
3142         adds one of his own.
3143
3144         * lisa (determine_new): warn if the package is also in other
3145         components.
3146
3147 2002-02-20  James Troup  <james@nocrew.org>
3148
3149         * jennifer (check_files): if .changes file lists "source" in
3150         Architecture field, there must be a .dsc.
3151
3152 2002-02-15  James Troup  <james@nocrew.org>
3153
3154         * ashley (main): add some missing fields.
3155
3156         * katie.py (Katie.check_dsc_against_db): fix to take into account
3157         the fact that the .orig.tar.gz might be in byhand, accepted or
3158         new.  Also fix calling of reject().
3159         (Katie.check_binaries_against_db): fix calling of reject().
3160         (Katie.check_source_against_db): likewise.
3161         (Katie.dump_vars): add missing variables used for bug closures.
3162
3163         * lisa (changes_compare_by_time): sort by reverse time.
3164
3165         * katie.py (Katie.accept): log.
3166         (Katie.dump_vars): missing has_key test for optional changes fields.
3167
3168         * jennifer (main): print "Accepted blah blah" to stdout, not stderr.
3169         (process_it): traceback goes to stderr, not stdout.
3170         (acknowledge_new): log.
3171         (do_byhand): likewise.
3172
3173         * katie.py (Katie.update_subst): fix typo (Cnf vs. self.Cnf).
3174
3175         * add_constraints.sql: add grants for the new fingerprint table.
3176
3177 2002-02-13  James Troup  <james@nocrew.org>
3178
3179         * katie (do_reject): basename the .changes filename before trying
3180         to use it to construct the .reason filename.
3181         (process_it): call Katie.update_subst() so do_reject() DTRT with
3182         the mail template.
3183         (do_reject): setup the mail template correctly.
3184
3185 2002-02-12  James Troup  <james@nocrew.org>
3186
3187         * tea (process_dir): renamed 'arg' to 'unused' for clarity.
3188         (check_files): don't abuse global dictionaries.
3189         (Ent): use all variables.
3190         (check_timestamps): don't abuse global dictionaries.
3191
3192         * fernanda.py: renamed to .py so lisa can import it.
3193         (check_dsc): remove unused local variables (pychecker).
3194         (display_changes): split off from check_changes.
3195
3196         * katie: rewritten; most of the functionality moves to jennifer;
3197         what's left is the code to install packages once a day from the
3198         'accepted' directory.
3199
3200         * jennifer: new program, processes packages in 'unchecked'
3201         (i.e. most of the non-install functionality of old katie).
3202
3203         * katie.py: common functions shared between the clique of
3204         jennifer, lisa and katie.
3205
3206         * lisa: new program; handles NEW and BYHAND packages.
3207
3208         * jeri (usage): new function.
3209         (main): use it.
3210         (check_package): remove unused local variable (pychecker).
3211
3212         * init_pool.sql: new table fingerprint.  Add fingerprint colums to
3213         binaries and source.  Add install_date to source.
3214
3215         * halle (usage): new function.
3216         (main): use it.  Remove unused options.
3217         (check_changes): remove unused local variable (pychecker).
3218
3219         * add_constraints.sql: add fingerprint references.
3220
3221         * db_access.py (get_or_set_fingerprint_id): new function.
3222
3223         * ashley (main): new program; dumps the contents of a .katie file
3224         to stdout.
3225
3226         * alyson (main): remove option handling since we don't actually
3227         support any.
3228         * cindy (main): likewise.
3229
3230         * remove unnecessary imports and pre-define globals (pychecker).
3231
3232 2002-02-11  Anthony Towns  <ajt@debian.org>
3233
3234         * added installation-report and upgrade-report pseudo-packages
3235
3236 2002-01-28  Martin Michlmayr  <tbm@cyrius.com>
3237
3238         * katie (update_subst): use Dinstall::TrackingServer.
3239         * melanie (main): likewise.
3240
3241 2002-01-27  James Troup  <james@nocrew.org>
3242
3243         * shania (main): it's IntLevel not IntVal; thanks to tbm@ for
3244         noticing, jgg@ for fix.
3245
3246 2002-01-19  James Troup  <james@nocrew.org>
3247
3248         * utils.py (extract_component_from_section): handle non-US
3249         non-main properly.
3250
3251 2002-01-12  James Troup  <james@nocrew.org>
3252
3253         * madison: add support for -S/--source-and-binary which displays
3254         information for the source package and all it's binary children.
3255
3256 2002-01-13  Anthony Towns  <ajt@debian.org>
3257
3258         * katie.conf: Remove Catherine Limit and bump stable to 2.2r5
3259         * katie.conf: Add Dinstall::SigningKeyIds option, set to the 2001
3260           and 2002 key ids.
3261         * katie.conf-non-US: Likewise.
3262         * ziyi: Suppoer Dinstall::SigningKeyIds to sign a Release file with
3263           multiple keys automatically. This is probably only useful for
3264           transitioning from an expired (or revoked?) key.
3265
3266 2002-01-08  Ryan Murray  <rmurray@debian.org>
3267
3268         * debian/python-dep: new file that prints out python:Depends for
3269           substvars
3270         * debian/control: use python:Depends, build-depend on python
3271           lower Depends: on postgresql to Suggests:
3272         * debian/rules: determine python version, install to the correct
3273           versioned dir
3274
3275 2001-12-18  Anthony Towns  <ajt@debian.org>
3276
3277         * ziyi: unlink Release files before overwriting them (in case they've
3278           been merged)
3279         * ziyi: always include checksums/sizes for the uncompressed versions
3280           of Sources and Packages, even if they're not present on disk
3281
3282 2001-11-26  Ryan Murray  <rmurray@debian.org>
3283
3284         * ziyi (main): add SigningPubKey config option
3285         * katie.conf: use SigningPubKey config option
3286         * katie.conf-non-US: likewise
3287
3288 2001-11-24  James Troup  <james@nocrew.org>
3289
3290         * katie (acknowledge_new): log newness.
3291
3292 2001-11-24  Anthony Towns  <ajt@debian.org>
3293
3294         * ziyi (real_arch): bail out if some moron forgot to reset
3295         untouchable on stable.
3296         (real_arch): source Release files.
3297
3298 2001-11-19  James Troup  <james@nocrew.org>
3299
3300         * claire.py (main): don't use apt_pkg.ReadConfigFileISC and
3301         utils.get_conf().
3302         * shania (main): likewise.
3303
3304         * rhona (main): add default options.
3305
3306         * db_access.py (get_archive_id): case independent.
3307
3308         * katie (action): sort files so that ordering is consistent
3309         between mails; noticed/requested by Joey.
3310
3311 2001-11-17  Ryan Murray  <rmurray@debian.org>
3312
3313         * utils.py: add get_conf function, change startup code to read all
3314           config files to the Cnf that get_conf returns
3315           use the component list from the katie conf rather than the hardcoded
3316           list.
3317         * all scripts: use new get_conf function
3318         * shania: fix try/except around changes files
3319         * jenna: only do debian-installer if it is a section in Cnf
3320
3321 2001-11-16  Ryan Murray  <rmurray@debian.org>
3322
3323         * shania (main): Initialize days to a string of a number.
3324                  (main): Initialize Cnf vars before reading in Cnf
3325
3326 2001-11-14  Ryan Murray  <rmurray@debian.org>
3327
3328         * shania (main): Initialize days to a number.
3329
3330 2001-11-04  James Troup  <james@nocrew.org>
3331
3332         * docs/Makefile: use docbook-utils' docbook2man binary.
3333
3334         * Change all "if foo == []" constructs into "if not foo".
3335
3336         * katie (check_changes): when installing into stable from
3337         proposed-updates, remove all non-stable target distributions.
3338         (check_override): don't check for override disparities on stable
3339         installs.
3340         (stable_install): update install_bytes appropriately.
3341         (reject): stable rejection support; i.e. don't remove files when
3342         rejecting files in the pool, rather remove them from the
3343         proposed-update suite instead, rhona will do the rest.
3344         (manual_reject): support for a stable specific template.
3345         (main): setup up stable rejector in subst.
3346
3347 2001-11-04  Martin Michlmayr  <tbm@cyrius.com>
3348
3349         * debian/control (Build-Depends): docbook2man has been superseded
3350         by docbook-utils.
3351
3352         * neve (main): exit with a more useful error message.
3353         (update_suites): Suite::<suite>::Version, Origin and Description
3354         are not required, so don't fail if they don't exist.
3355
3356         * db_access.py (get_archive_id): return -1 on error rather than
3357         raise an exception.
3358         (get_location_id): likewise.
3359
3360         * madison (main): don't exit on the first not-found package,
3361         rather exit with an appropriate return code after processing all
3362         packages.
3363
3364 2001-11-03  James Troup  <james@nocrew.org>
3365
3366         * claire.py (find_dislocated_stable): add per-architecture
3367         symlinks for dislocated architecture: all debs.
3368
3369 2001-10-19  Anthony Towns  <ajt@debian.org>
3370
3371         * apt.conf*, katie.conf*: add mips, mipsel, s390 to testing.
3372
3373 2001-10-10  Anthony Towns  <ajt@debian.org>
3374
3375         * claire.py (fix_component_section): do _not_ assign to None under
3376         any circumstances
3377
3378 2001-10-07  Martin Michlmayr  <tbm@cyrius.com>
3379
3380         * melanie (main): don't duplicate architectures when removing from
3381         more than one suite.
3382
3383         * heidi (main, process_file, get_list): report suite name not ID.
3384
3385         * naima (nmu_p): be case insensitive.
3386
3387         * naima (action): more list handling clean ups.
3388
3389         * melanie (main): clean up lists handling to use string.join and
3390         IN's.
3391
3392         * madison (main): clean up suite and architecture argument parsing
3393         to use slices less and string.join more.
3394
3395         * utils.py (parse_changes): Use string.find() instead of slices for
3396         string comparisons thereby avoid hardcoding the length of strings.
3397         * ziyi (main): likewise.
3398
3399 2001-10-07  James Troup  <james@nocrew.org>
3400
3401         * Remove mode argument from utils.open_files() calls if it's the
3402         default, i.e. 'r'.
3403
3404 2001-09-27  James Troup  <james@nocrew.org>
3405
3406         * katie (init): new function; options clean up.
3407         (usage): add missing options, remove obsolete ones.
3408         (main): adapt for the two changes above.  If the lock file or
3409         new-ack log file don't exist, create them.  Don't try to open the
3410         new-ack log file except running in new-ack mode.
3411
3412         * alyson (main): initialize all the tables that are based on the
3413         conf file.
3414
3415         * utils.py (touch_file): like touch(1).
3416         (where_am_i): typo.
3417
3418         * catherine (usage): new.
3419         (main): use it.  options cleanup.
3420         * claire.py: likewise.
3421         * fernanda: likewise.
3422         * heidi: likewise.
3423         * jenna: likewise.
3424         * shania: likewise.
3425         * ziyi: likewise.
3426
3427         * andrea: options cleanup.
3428         * charisma: likewise.
3429         * julia: likewise.
3430         * madison: likewise.
3431         * melanie: likewise.
3432         * natalie: likewise.
3433         * rhona: likewise.
3434         * tea: likewise.
3435
3436 2001-09-26  James Troup  <james@nocrew.org>
3437
3438         * utils.py: default to sane config file locations
3439         (/etc/katie/{apt,katie}.conf.  They can be the actual config files
3440         or they can point to the real ones through use of a new Config
3441         section.  Based on an old patch by Adam Heath.
3442         (where_am_i): use the new default config stuff.
3443         (which_conf_file): likewise.
3444         (which_apt_conf_file): likewise.
3445
3446         * charisma (main): output defaults to
3447         `Package~Version\tMaintainer'; input can be of either form.  When
3448         parsing the new format do version comparisons, when parsing the
3449         old format assume anything in the extra file wins.  This fixes the
3450         problem of newer non-US packages being overwhelmed by older
3451         versions still in stable on main.
3452
3453 2001-09-17  James Troup  <james@nocrew.org>
3454
3455         * natalie.py (list): use result_join().
3456
3457         * denise (main): result_join() moved to utils.
3458
3459         * utils.py (result_join): move to utils; add an optional seperator
3460         argument.
3461
3462 2001-09-14  James Troup  <james@nocrew.org>
3463
3464         * heidi (set_suite): new function; does --set like natalie does,
3465         i.e. turns it into a sequence of --add's and --remove's
3466         internally.  This is a major win (~20 minute run time > ~20
3467         seconds) in the common, everday (i.e. testing) case.
3468         (get_id): common code used by set_suite() and process_file().
3469         (process_file): call set_suite() and get_id().
3470         (main): add logging support.
3471
3472         * julia: new script; syncs PostgeSQL with (LDAP-generated) passwd
3473         files.
3474
3475         * utils.py (parse_changes): use slices or simple string comparison
3476         in favour of regexes where possible.
3477
3478         * sql-aptvc.cpp (versioncmp): rewritten to take into account the
3479         fact that the string VARDATA() points to are not null terminated.
3480
3481         * denise (result_join): new function; like string.join() but
3482         handles None's.
3483         (list): use it.
3484         (main): likewise.
3485
3486         * charisma (main): python-pygresql 7.1 returns None not "".
3487
3488 2001-09-14  Ryan Murray  <rmurray@debian.org>
3489
3490         * natalie.py (list): handle python-pygresql 7.1 returning None.
3491
3492 2001-09-10  Martin Michlmayr  <tbm@cyrius.com>
3493
3494         * madison (main): return 1 if no package is found.
3495
3496 2001-09-08  Martin Michlmayr  <tbm@cyrius.com>
3497
3498         * madison (main): better error handling for incorrect
3499         -a/--architecture or -s/--suite arguments.
3500         (usage): new.
3501         (main): use it.
3502
3503 2001-09-05  Ryan Murray  <rmurray@debian.org>
3504
3505         * charisma, madison, katie: remove use of ROUser
3506         * katie.conf,katie.conf-non-US: remove defintion of ROUser
3507
3508 2001-08-26  James Troup  <james@nocrew.org>
3509
3510         * katie (nmu_p.is_an_nmu): use maintaineremail to check for group
3511         maintained packages at cjwatson@'s request.
3512
3513 2001-08-21  James Troup  <james@nocrew.org>
3514
3515         * madison (main): add -a/--architecture support.
3516
3517         * jenna: use logging instead of being overly verbose on stdout.
3518
3519 2001-08-11  Ryan Murray  <rmurray@debian.org>
3520
3521         * melanie: add functional help option
3522
3523 2001-08-07  Anthony Towns  <ajt@debian.org>
3524
3525         * apt.conf, katie.conf: Add ia64 and hppa to testing.
3526
3527 2001-07-28  James Troup  <james@nocrew.org>
3528
3529         * katie (check_dsc): ensure source version is >> than existing
3530         source in target suite.
3531
3532 2001-07-25  James Troup  <james@nocrew.org>
3533
3534         * natalie.py: add logging support.
3535
3536         * utils.py (open_file): make the second argument optional and
3537         default to read-only.
3538
3539         * rene (main): work around broken source packages that duplicate
3540         arch: all packages with arch: !all packages (no longer allowed
3541         into the archive by katie).
3542
3543 2001-07-13  James Troup  <james@nocrew.org>
3544
3545         * katie (action): don't assume distribution is a dictionary.
3546         (update_subst): don't assume architecture is a dictionary and that
3547         maintainer822 is defined.
3548         (check_changes): recognise nk_format exceptions.
3549         (check_changes): reject on 'testing' only uploads.
3550         (check_files): when checking to ensure all packages are newer
3551         versions check against arch-all packages too.
3552         (check_dsc): enforce the existent of a sane set of mandatory
3553         fields.  Ensure the version number in the .dsc (modulo epoch)
3554         matches the version number in the .changes file.
3555
3556         * utils.py (changes_compare): ignore all exceptions when parsing
3557         the changes files.
3558         (build_file_list): don't UNDEF on a changes file with no format
3559         field.
3560
3561 2001-07-07  James Troup  <james@nocrew.org>
3562
3563         * katie (nmu_p.is_an_nmu): check 'changedby822' for emptiness
3564         rather than 'changedbyname' to avoid false negatives on uploads
3565         with an email-address-only Changed-By field.
3566         (check_dsc): don't overwrite reject_message; append to it.
3567         (check_signature): likewise.
3568         (check_changes): likewise.
3569         (announce): condition logging on 'action'.
3570
3571         * logging.py: new logging module.
3572
3573         * katie: Cleaned up code by putting Cnf["Dinstall::Options"]
3574         sub-tree into a separate (global) variable.
3575         (check_dsc): ensure format is 1.0 to retain backwards
3576         compatability with dpkg-source in potato.
3577         (main): only try to obtain the lock when not running in no-action
3578         mode.
3579         Use the new logging module.
3580
3581         * christina: initial version; only partially usable.
3582
3583 2001-06-28  Anthony Towns  <ajt@debian.org>
3584
3585         * apt.conf: Add ExtraOverrides to auric.
3586
3587 2001-06-25  James Troup  <james@nocrew.org>
3588
3589         * katie (nmu_p.is_an_nmu): the wonderful dpkg developers decided
3590         they preferred the name 'Uploaders'.
3591
3592 2001-06-23  James Troup  <james@nocrew.org>
3593
3594         * katie (check_files): fix typo in uncommon rejection message,
3595         s/sourceversion/source version/.
3596
3597         * denise (main): we can't use print because stdout has been
3598         redirected.
3599
3600         * katie (source_exists): new function; moved out of check_files()
3601         and added support for binary-only NMUs of earlier sourceful NMUs.
3602
3603         * rhona (clean): find_next_free has moved.
3604
3605         * utils.py (find_next_free): new function; moved here from rhona.
3606         Change too_many to be an argument with a default value, rather
3607         than a hardcoded variable.
3608
3609         * shania: rewritten to work better; REJECTion reminder mail
3610         handling got lost though.
3611
3612 2001-06-22  James Troup  <james@nocrew.org>
3613
3614         * rhona (main): remove unused override code.
3615
3616         * fernanda (main): remove extraneous \n's from utils.warn calls.
3617         * natalie.py (list): likewise.
3618
3619         * catherine, cindy, denise, heidi, jenna, katie, neve, rhona, tea:
3620         use utils.{warn,fubar} where appropriate.
3621
3622 2001-06-21  James Troup  <james@nocrew.org>
3623
3624         * katie (nmu_p): new class that encapsulates the "is a nmu?"
3625         functionality.
3626         (nmu_p.is_an_nmu): add support for multiple maintainers specified
3627         by the "Maintainers" field in the .dsc file and maintainer groups.
3628         (nmu_p.__init__): read in the list of group maintainer names.
3629         (announce): use nmu_p.
3630
3631 2001-06-20  James Troup  <james@nocrew.org>
3632
3633         * rene (main): hardcode the suite experimental is compared to by
3634         name rather than number.
3635
3636         * katie (check_files): differentiate between doesn't-exist and
3637         permission-denied in "can not read" rejections; requested by edd@.
3638         (check_dsc): use os.path.exists rather than os.access to allow the
3639         above check to kick in.
3640
3641         * heidi (process_file): read all input before doing anything and
3642         use transactions.
3643
3644 2001-06-15  James Troup  <james@nocrew.org>
3645
3646         * fernanda: new script; replaces old 'check' shell script
3647         nastiness.
3648
3649 2001-06-14  James Troup  <james@nocrew.org>
3650
3651         * katie: actually import traceback module to avoid amusing
3652         infinite loop.
3653
3654 2001-06-10  James Troup  <james@nocrew.org>
3655
3656         * utils.py (extract_component_from_section): fix to handle just
3657         'non-free' and 'contrib'.  Also fix to handle non-US in a
3658         completely case insensitive manner as a component.
3659
3660 2001-06-08  James Troup  <james@nocrew.org>
3661
3662         * madison (arch_compare): sort function that sorts 'source' first
3663         then alphabetically.
3664         (main): use it.
3665
3666 2001-06-05  Jeff Licquia  <jlicquia@progeny.com>
3667
3668         * catherine (poolize): explicitly make poolized_size a long so it
3669         doesn't overflow when poolizing e.g. entire archives.
3670
3671 2001-06-01  James Troup  <james@nocrew.org>
3672
3673         * utils.py (send_mail): throw exceptions rather than exiting.
3674
3675         * katie (process_it): catch exceptions and ignore them.
3676
3677 2001-06-01  Michael Beattie  <mjb@debian.org>
3678
3679         * added update-mailingliststxt and update-readmenonus to update
3680         those files, respectively. modified cron.daily{,-non-US} to
3681         use them.
3682
3683 2001-05-31  Anthony Towns  <ajt@debian.org>
3684
3685         * rhona: make StayOfExecution work.
3686
3687 2001-05-31  James Troup  <james@nocrew.org>
3688
3689         * rhona (find_next_free): fixes to not overwrite files but rename
3690         them by appending .<n> instead.
3691         (clean): use find_next_free and use dated sub-directories in the
3692         morgue.
3693
3694         * utils.py (move): don't overwrite files unless forced to.
3695         (copy): likewise.
3696
3697 2001-05-24  James Troup  <james@nocrew.org>
3698
3699         * katie (check_files): determine the source version here instead
3700         of during install().
3701         (check_files): check for existent source with bin-only NMU
3702         support.
3703         (main): sort the list of changes so that the source-must-exist
3704         check Does The Right Thing(tm).
3705
3706         * utils.py (changes_compare): new function; sorts a list of
3707         changes files by 'have-source', source, version.
3708         (cc_fix_changes): helper function.
3709         (parse_changes): use compiled regexes.
3710         (fix_maintainer): likewise.
3711
3712         * rene (main): warn about packages in experimental that are
3713         superseded by newer versions in unstable.
3714
3715 2001-05-21  James Troup  <james@nocrew.org>
3716
3717         * rene (main): add support for checking for ANAIS (Architecture
3718         Not Allowed In Source) packages.
3719
3720 2001-05-17  James Troup  <james@nocrew.org>
3721
3722         * katie (check_changes): initalize `architecture' dictionary in
3723         changes global so that if we can't parse the changes file for
3724         whatever reason we don't undef later on.
3725
3726         * utils.py (parse_changes): fix handling of multi-line fields
3727         where the first line did have data.
3728
3729 2001-05-05  Anthony Towns  <ajt@debian.org>
3730
3731         * ziyi: Add "NotAutomatic: yes" to experimental Release files.
3732         (It should always have been there. Ooopsy.)
3733
3734 2001-05-03  Anthony Towns  <ajt@debian.org>
3735
3736         * jenna: Cleanup packages that move from arch:any to arch:all or
3737         vice-versa.
3738
3739 2001-04-24  Anthony Towns  <ajt@debian.org>
3740
3741         * ziyi: add ``SHA1:'' info to Release files. Also hack them up to
3742         cope with debian-installer and boot-floppies' md5sum.txt.
3743
3744 2001-04-16  James Troup  <james@nocrew.org>
3745
3746         * katie (check_changes): add missing %s format string argument.
3747         (stable_install): temporary work around for morgue location to
3748         move installed changes files into.
3749         (stable_install): helps if you actually read in the template.
3750         (manual_reject): fix for editing of reject messages which was
3751         using the wrong variable name.
3752
3753         * jenna (generate_src_list): typo; s/package/source/; fixes undef crash.
3754
3755 2001-04-13  James Troup  <james@nocrew.org>
3756
3757         * katie (manual_reject): Cc the installer.
3758         (reject): don't.
3759         (check_changes): remove unused maintainer-determination code.
3760         (update_subst): add support for Changed-By when setting the
3761         *MAINTAINER* variables.
3762
3763         * rene (bar): new function to check for packages on architectures
3764         when they shouldn't be.
3765
3766         * natalie.py (main): use fubar() and warn() from utils.
3767
3768         * utils.py (whoami): new mini-function().
3769         * melanie (main): use it.
3770         * katie (manual_reject): likewise.
3771
3772 2001-04-03  James Troup  <james@nocrew.org>
3773
3774         * katie (action): ignore exceptions from os.path.getmtime() so we
3775         don't crash on non-existent changes files (e.g. when they are
3776         moved between the start of the install run in cron.daily and the
3777         time we get round to processing them).
3778
3779         * madison (main): also list source and accept -s/--suite.
3780
3781         * jenna (generate_src_list): missing \n in error message.
3782
3783         * katie (update_subst): add sane defaults for when changes is
3784         skeletal.
3785
3786 2001-03-29  James Troup  <james@nocrew.org>
3787
3788         * melanie (main): use fubar() and warn() from utils.  Remember who
3789         the maintainer for the removed packages are and display that info
3790         to the user.  Readd support for melanie-specific Bcc-ing that got
3791         lost in the TemplateSubst transition.
3792
3793         * utils.py (fubar): new function.
3794         (warn): like wise.
3795
3796         * db_access.py (get_maintainer): as below.
3797
3798         * charisma (get_maintainer): moved the bulk of this function to
3799         db_access so that melanie can use it too.
3800
3801         * claire.py (find_dislocated_stable): restrict the override join
3802         to those entries where the suite is stable; this avoids problems
3803         with packages which have moved to new sections (e.g. science)
3804         between stable and unstable.
3805
3806 2001-03-24  James Troup  <james@nocrew.org>
3807
3808         * catherine (poolize): new function; not really independent of
3809         main() fully, yet.
3810         (main): use it.
3811
3812         * katie (stable_install): __SUITE__ needs to be space prefixed
3813         because buildd's check for 'INSTALLED$'.
3814
3815 2001-03-22  James Troup  <james@nocrew.org>
3816
3817         * utils.py (regex_safe): also need to escape '.'; noticed by ajt@.
3818
3819         * jenna: rewritten; now does deletions on a per-suite level
3820         instead of a per-suite-component-architecture-type level.  This
3821         allows mutli-component packages to be auto-cleaned (and as a
3822         bonus, reduces the code size and duplication).
3823
3824 2001-03-22  Anthony Towns  <ajt@debian.org>
3825
3826         * ziyi (main): fix ziyi to overwrite existing Release.gpg files
3827         instead of just giving a gpg error.
3828
3829 2001-03-21  James Troup  <james@nocrew.org>
3830
3831         * madison (main): use apt_pkg.VersionCompare to sort versions so
3832         that output is correctly sorted for packages like debhlper.
3833         Noticed by ajt@.
3834
3835         * tea (check_source_in_one_dir): actually find problematic source
3836         packages.
3837
3838         * katie (check_dsc): remember the orig.tar.gz's location ID if
3839         it's not in a legacy suite.
3840         (check_diff): we don't use orig_tar_id.
3841         (install): add code to handle sourceful diff-only upload of
3842         packages which change components by copying the .orig.tar.gz into
3843         the new component, if it doesn't already exist there.
3844         (process_it): reset orig_tar_location (as above).
3845
3846         * melanie (main): use template substiution for the bug closing
3847         emails.
3848         (main): don't hardcode bugs.debian.org or packages.debian.org
3849         either; use configuration items.
3850
3851         * katie: likewise.
3852
3853         * natalie.py (init): use None rather than 'localhost' for the
3854         hostname given to pg.connect.
3855
3856         * utils.py (TemplateSubst): new function; lifted from
3857         userdir-ldap.
3858
3859 2001-03-21  Ryan Murray  <rmurray@debian.org>
3860
3861         * katie (announce): fix the case of non-existent
3862         Suite::$SUITE::Announce.
3863
3864 2001-03-20  Ryan Murray  <rmurray@debian.org>
3865
3866         * debian/rules (binary-indep): install melanie into /usr/bin/ not
3867         /usr/.
3868
3869         * alyson (main): use config variable for database name.
3870         * andrea (main): likewise.
3871         * catherine (main): likewise.
3872         * charisma (main): likewise.
3873         * cindy (main): likewise.
3874         * claire.py (main): likewise.
3875         * denise (main): likewise.
3876         * heidi (main): likewise.
3877         * jenna (main): likewise.
3878         * katie (main): likewise.
3879         * madison (main): likewise.
3880         * melanie (main): likewise.
3881         * neve (main): likewise.
3882         * rhona (main): likewise.
3883         * tea (main): likewise.
3884
3885 2001-03-15  James Troup  <james@nocrew.org>
3886
3887         * rhona (check_sources): fixed evil off by one (letter) error
3888         which was causing only .dsc files to be deleted when cleaning
3889         source packages.
3890
3891         * charisma (get_maintainer_from_source): remove really stupid and
3892         gratuitous IN sub-query and replace with normal inner join.
3893         (main): connect as read-only user nobody.
3894
3895         * rhona (clean_maintainers): rewritten to use SELECT and sub-query
3896         with EXISTS.
3897         (check_files): likewise; still disabled by default though.
3898         (clean_binaries): add ' seconds' to the mysterious number in the
3899         output.
3900         (clean): likewise.
3901
3902         * tea (check_files): add missing global declaration on db_files.
3903
3904 2001-03-14  James Troup  <james@nocrew.org>
3905
3906         * rhona: rewritten large chunks. Removed a lot of the silly
3907         selecting into dictionaries and replaced it with 'where exists'
3908         based sub queries.  Added support for StayOfExecution.  Fix the
3909         problem with deleting dsc_files too early and disable cleaning of
3910         unattached files.
3911
3912 2001-03-14  Anthony Towns  <ajt@debian.org>
3913
3914         * katie (announce): also check Changed-By when trying to detect
3915         NMUs.
3916
3917 2001-03-06  Anthony Towns  <ajt@debian.org>
3918
3919         * ziyi (main): Generate Release.gpg files as well, using the key from
3920         Dinstall::SigningKey in katie.conf, if present. That key has to be
3921         passwordless, and hence kept fairly secretly.
3922
3923 2001-03-02  James Troup  <james@nocrew.org>
3924
3925         * utils.py (str_isnum): new function; checks to see if the string
3926         is a number.
3927
3928         * shania (main): fix _hideous_ bug which was causing all files > 2
3929         weeks old to be deleted from incoming, even if they were part of a
3930         valid upload.
3931
3932 2001-02-27  James Troup  <james@nocrew.org>
3933
3934         * melanie (main): accept new argument -C/--carbon-copy which
3935         allows arbitarty carbon-copying of the bug closure messages.
3936         Cleaned up code by putting Cnf["Melanie::Options"] sub-tree into a
3937         separate variable.
3938
3939 2001-02-27  Anthony Towns  <ajt@debian.org>
3940
3941         * ziyi: new program; generates Release files.
3942
3943 2001-02-25  James Troup  <james@nocrew.org>
3944
3945         * katie (reject): add missing '\n' to error message.
3946         (manual_reject): likewise.
3947         (install): catch exceptions from moving the changes file into DONE
3948         and ignore them.
3949
3950         * tea (check_md5sums): new function.
3951
3952 2001-02-25  Michael Beattie  <mjb@debian.org>
3953
3954         * melanie: use $EDITOR if available.
3955
3956 2001-02-15  James Troup  <james@nocrew.org>
3957
3958         * utils.py (parse_changes): don't crash and burn on empty .changes
3959         files.  Symptoms noticed by mjb@.
3960
3961 2001-02-15  Adam Heath  <doogie@debian.org>
3962
3963         * denise (main): use an absolute path for the output filename.
3964
3965         * sql-aptvc.cpp: don't #include <utils/builtins.h> as it causes
3966         compile errors with postgresql-dev >= 7.0.
3967
3968 2001-02-12  James Troup  <james@nocrew.org>
3969
3970         * rene: initial version.
3971
3972         * andrea: initial version.
3973
3974         * catherine (main): remove obsolete assignment of arguments.
3975
3976 2001-02-09  James Troup  <james@nocrew.org>
3977
3978         * catherine: first working version.
3979
3980 2001-02-06  James Troup  <james@nocrew.org>
3981
3982         * katie (check_files): validate the priority field; i.e. ensure it
3983         doesn't contain a '/' (to catch people prepending the priority
3984         with the component rather than the section).
3985         (check_override): don't warn about source packages; the only check
3986         is on section and we have no GUI tools that would use the Section
3987         field for a Sources file.
3988         (announce): use tags rather than severities for NMUs.  Requested
3989         by Josip Rodin <joy@>. [#78035]
3990
3991 2001-02-04  James Troup  <james@nocrew.org>
3992
3993         * tea (check_override): new function; ensures packages in suites
3994         are also in the override file.  Thanks to bod@ for noticing that
3995         such packages existed.
3996
3997         * katie: move file type compiled regular expressions to utils as
3998         catherine uses them too.
3999         (check_changes): always default maintainer822 to the installer
4000         address so that any bail out won't cause undefs later.
4001         (check_files): update file type re's to match above.
4002         (stable_install): likewise.
4003         (reject): handle any except from moving the changes files.  Fixes
4004         crashes on unreadable changes files.
4005
4006         * melanie (main): add an explanation of why things are not removed
4007         from testing.
4008
4009 2001-01-31  James Troup  <james@nocrew.org>
4010
4011         * melanie (main): ignore a) no message, b) removing from stable or
4012         testing when invoked with -n/--no-action.
4013
4014         * katie (check_override): lower section before checking to see if
4015         we're whining about 'non-US' versus 'non-US/main'.
4016
4017         * sql-aptvc.cpp: new file; wrapper around apt's version comparison
4018         function so that we can use inside of PostgreSQL.
4019
4020 2001-01-28  James Troup  <james@nocrew.org>
4021
4022         * katie: updated to pass new flag to parse_changes() and deal with
4023         the exception raised on invalid .dsc's if appropriate.
4024         * shania (main): likewise.
4025         * melanie (main): likewise.
4026
4027         * tea (check_dscs): new function to validate all .dsc files in
4028         unstable.
4029
4030         * utils.py (parse_changes): if passed an additional flag, validate
4031         the .dsc file to ensure it's extractable by dpkg-source.
4032         Requested by Ben Collins <bcollins@>.
4033
4034 2001-01-27  James Troup  <james@nocrew.org>
4035
4036         * madison (main): connect to the DB as nobody.
4037
4038         * katie (check_files): remove support for -r/--no-version-check
4039         since it makes no sense under katie (jenna will automatically
4040         remove the (new) older version) and was evil in any event.
4041         (check_changes): add missing new line to rejection message.
4042         (check_dsc): likewise.
4043         (process_it): reset reject_message here.
4044         (main): not here.  Also remove support for -r.
4045
4046 2001-01-26  James Troup  <james@nocrew.org>
4047
4048         * katie (check_override): don't whine about 'non-US/main' versus
4049         'non-US'.
4050
4051 2001-01-26  Michael Beattie  <mjb@debian.org>
4052
4053         * natalie.py (usage): new function.
4054         (main): use it.
4055
4056 2001-01-25  Antti-Juhani Kaijanaho  <gaia@iki.fi>
4057
4058         * update-mirrorlists: Update README.non-US too (request from Joy).
4059
4060 2001-01-25  James Troup  <james@nocrew.org>
4061
4062         * katie (reject): catch any exception from utils.move() and just
4063         pass, we previously only caught can't-overwrite errors and not
4064         can't-read ones.
4065
4066         * jenna (generate_src_list): use ORDER BY in selects to avoid
4067         unnecessary changes to Packages files.
4068         (generate_bin_list): likewise.
4069
4070         * utils.py (extract_component_from_section): separated out from
4071         build_file_list() as it's now used by claire too.
4072
4073         * claire.py (find_dislocated_stable): rewrite the query to extract
4074         section information and handle component-less locations properly.
4075         Thanks to ajt@ for the improved queries.
4076         (fix_component_section): new function to fix components and
4077         sections.
4078
4079 2001-01-23  James Troup  <james@nocrew.org>
4080
4081         * katie (check_files): set file type for (u?)debs first thing, so
4082         that if we continue, other functions which rely on file type
4083         existing don't bomb out.  If apt_pkg or apt_inst raise an
4084         exception when parsing the control file, don't try any other
4085         checks, just drop out.
4086         (check_changes): new test to ensure there is actually a target
4087         distribution.
4088
4089 2001-01-22  James Troup  <james@nocrew.org>
4090
4091         * katie (usage): s/dry-run/no-action/.  Noticed by Peter Gervai
4092         <grin@>.
4093         (check_changes): when mapping to unstable, remember to actually
4094         add unstable to the suite list and not just remove the invalid
4095         suite.
4096
4097 2001-01-21  James Troup  <james@nocrew.org>
4098
4099         * katie (check_files): catch exceptions from debExtractControl()
4100         and reject packages which raise any.
4101
4102 2001-01-19  James Troup  <james@nocrew.org>
4103
4104         * katie (check_signature): basename() file name in rejection
4105         message.
4106
4107 2001-01-18  James Troup  <james@nocrew.org>
4108
4109         * katie (in_override_p): remember the section and priority from
4110         the override file so we can check them against the package later.
4111         (check_override): new function; checks section and priority (for
4112         binaries) from the package against the override file and mails the
4113         maintainer about any disparities.
4114         (install): call check_override after announcing the upload.
4115
4116 2001-01-16  James Troup  <james@nocrew.org>
4117
4118         * utils.py (build_file_list): catch ValueError's from splitting up
4119         the files field and translate it into a parse error.
4120
4121         * tea: add support for finding unreferenced files.
4122
4123         * katie (in_override_p): add support for suite-aliasing so that
4124         proposed-updates uploads work again.
4125         (check_changes): catch parses errors from utils.build_file_list().
4126         (check_dsc): likewise.
4127         (check_diff): yet more dpkg breakage so we require even newer a
4128         version.
4129
4130         * jenna (generate_bin_list): don't do nasty path munging that's no
4131         longer needed.
4132
4133         * denise (main): support for non-US; and rename testing's override
4134         files so they're based on testing's codename.
4135
4136 2001-01-16  Martin Michlmayr  <tbm@cyrius.com>
4137
4138         * melanie: add to the bug closing message explaining what happens
4139         (or rather doesn't) with bugs against packages that have been
4140         removed.
4141
4142 2001-01-14  James Troup  <james@nocrew.org>
4143
4144         * charisma (main): fix silly off-by-one error; suite priority
4145         checking was done using "less than" rather than "less than or
4146         equal to" which was causing weird hesienbugs with wrong Maintainer
4147         fields.
4148
4149 2001-01-10  James Troup  <james@nocrew.org>
4150
4151         * katie (in_override_p): adapted to use SQL-based overrides.
4152         read_override_file function disappears.
4153
4154         * db_access.py: add new functions get_section_id, get_priority_id
4155         and get_override_type_id.
4156         (get_architecture_id): return -1 if the architecture is not found.
4157
4158         * heidi: switch %d -> %d in all SQL queries.
4159         (get_list): Use string.join where appropriate.
4160
4161         * rhona (in_override_p): don't die if the override file doesn't
4162         exist.
4163         (main): warn if the override file doesn't exist.
4164
4165         * alyson: new script; will eventually sync the config file and the
4166         SQL database.
4167
4168         * natalie.py: new script; manipulates overrides.
4169
4170         * melanie: new script; removes packages from suites.
4171
4172 2001-01-08  James Troup  <james@nocrew.org>
4173
4174         * katie (re_bad_diff): whee; dpkg 1.8.1.1 didn't actually fix
4175         anything it just changed the symptom.  Recognise the new breakage
4176         and reject them too.
4177
4178 2001-01-07  James Troup  <james@nocrew.org>
4179
4180         * katie (check_dsc): when adding the cwd copy of the .orig.tar.gz
4181         to the .changes file, be sure to set up files[filename]["type"]
4182         too.
4183
4184 2001-01-06  James Troup  <james@nocrew.org>
4185
4186         * katie (check_diff): new function; detects bad diff files
4187         produced by dpkg 1.8.1 and rejects thems.
4188         (process_it): call check_diff().
4189         (check_dsc): gar.  Add support for multiple versions of the
4190         .orig.tar.gz file in the archive from -sa uploads.  Check md5sum
4191         and size against all versions and use one which matches if
4192         possible and exclude any that don't from being poolized to avoid
4193         file overwrites.  Thanks to broonie@ for providing the example.
4194         (install): skip any files marked as excluded as above.
4195
4196 2001-01-05  James Troup  <james@nocrew.org>
4197
4198         * heidi (process_file): add missing argument to error message.
4199
4200 2001-01-04  James Troup  <james@nocrew.org>
4201
4202         * heidi (main): fix handling of multiple files by reading all
4203         files not just the first file n times (where n = the number of
4204         files passed as arguments).
4205
4206 2001-01-04  Anthony Towns  <ajt@debian.org>
4207
4208         * katie (check_dsc): proper fix for the code which locates the
4209         .orig.tar.gz; check for '<filename>$' or '^<filename>$'.
4210
4211 2000-12-20  James Troup  <james@nocrew.org>
4212
4213         * rhona: replace IN's with EXISTS's to make DELETE time for
4214         binaries and source sane on auric.  Add a -n/--no-action flag and
4215         make it stop actions if used.  Fixed a bug in binaries deletion
4216         with no StayOfExecution (s/</<=/).  Add working -h/--help and
4217         -V/--version.  Giving timing info on deletion till I'm sure it's
4218         sane.
4219
4220         * katie (check_changes): map testing to unstable.
4221
4222         * madison: new script; shows versions in different architectures.
4223
4224         * katie (check_dsc): ensure size matches as well as md5sum;
4225         suggested by Ben Collins <bcollins@debian.org> in Debian Bug
4226         #69702.
4227
4228 2000-12-19  James Troup  <james@nocrew.org>
4229
4230         * katie (reject): ignore the "can't overwrite file" exception from
4231         utils.move() and leave the files where they are.
4232         (reject): doh! os.access() test was reversed so we only tried to
4233         move files which didn't exist... replaced with os.path.exists()
4234         test the right way round.
4235
4236         * utils.py (move): raise an exception if we can't overwrite the
4237         destination file.
4238         (copy): likewise.
4239
4240 2000-12-18  James Troup  <james@nocrew.org>
4241
4242         * rhona: first working version.
4243
4244         * db_access.py (get_files_id): force both sizes to be integers.
4245
4246         * katie (main): use size_type().
4247
4248         * utils.py (size_type): new function; pretty prints a file size.
4249
4250 2000-12-17  James Troup  <james@nocrew.org>
4251
4252         * charisma (main): do version compares so that older packages do
4253         not override newer ones and process source first as source wins
4254         over binaries in terms of who we think of as the Maintainer.
4255
4256 2000-12-15  James Troup  <james@nocrew.org>
4257
4258         * katie (install): use the files id for the .orig.tar.gz from
4259         check_dsc().
4260         (install): limit select for legacy source to a) source in legacy
4261         or legacy-mixed type locations and b) distinct on files.id.
4262         (install): rather than the bizarre insert new, delete old method
4263         for moving legacy source into the pool, use a simple update of
4264         files.
4265         (process_it): initalize some globals before each process.
4266
4267 2000-12-14  James Troup  <james@nocrew.org>
4268
4269         * katie (in_override_p): index on binary_type too since .udeb
4270         overrides are in a different file.
4271         (read_override_file): likewise.
4272         (check_files): correct filename passed to get_files_id().
4273         (check_dsc): we _have_ to preprend '/' to the filename to avoid
4274         mismatches like jabber.orig.tar.gz versus libjabber.orig.tar.gz.
4275         (check_dsc): remember the files id of the .orig.tar.gz, not the
4276         location id.
4277
4278 2000-12-13  James Troup  <james@nocrew.org>
4279
4280         * utils.py (poolify): force the component to lower case except for
4281         non-US.
4282
4283         * katie (in_override_p): handle .udeb-specific override files.
4284         (check_files): pass the binary type to in_override_p().
4285         (check_dsc): remember the location id of the old .orig.tar.gz in
4286         case it's not in the pool.
4287         (install): use location id from dsc_files; which is where
4288         check_dsc() puts it for old .orig.tar.gz files.
4289         (install): install files after all DB work is complete.
4290         (reject): basename() the changes filename.
4291         (manual_reject): likewise.
4292
4293         * shania: new progam; replaces incomingcleaner.
4294
4295 2000-12-05  James Troup  <james@nocrew.org>
4296
4297         * katie (check_changes): if inside stable and can't find files
4298         from the .changes; assume it's installed in the pool and chdir()
4299         to there.
4300         (check_files): we are not installing for stable installs, so don't
4301         check for overwriting existing files.
4302         (check_dsc): likewise.
4303         (check_dsc): reorder .orig.tar.gz handling so that we search in
4304         the pool first and only then fall back on any .orig.tar.gz in the
4305         cwd; this avoids false positives on the overwrite check when
4306         people needlessly reupoad the .orig.tar.gz in a non-sa upload.
4307         (install): if this is a stable install, bail out to
4308         stable_install() immediately.
4309         (install): dsc_files handling was horribly broken. a) we need to
4310         add files from the .dsc and not the .changes (duh), b) we need to
4311         add the .dsc file itself to dsc_files (to be consistent with neve
4312         if for no other reason).
4313         (stable_install): new function; handles installs from inside
4314         proposed-updates to stable.
4315         (acknowledge_new): basename changes_filename before doing
4316         anything.
4317         (process_it): absolutize the changes filename to avoid the
4318         requirement of being in the same directory as the .changes file.
4319         (process_it): save and restore the cwd as stable installs can
4320         potentially jump into the pool to find files.
4321
4322         * jenna: dislocated_files support using claire.
4323
4324         * heidi (process_file): select package field from binaries
4325         explicitly.
4326
4327         * db_access.py (get_files_id): fix cache key used.
4328
4329         * utils.py (build_file_list): fix 'non-US/non-free' case in
4330         section/component splitting.
4331         (move): use os.path.isdir() rather than stat.
4332         (copy): likewise.
4333
4334         * claire.py: new file; stable in non-stable munger.
4335
4336         * tea: new file; simply ensures all files in the DB exist.
4337
4338 2000-12-01  James Troup  <james@nocrew.org>
4339
4340         * katie (check_dsc): use regex_safe().
4341         (check_changes): typo in changes{} key:
4342         s/distributions/distribution/.
4343         (install): use changes["source"], not files[file]["source"] as the
4344         latter may not exist and the former is used elsewhere.  Commit the
4345         SQL transaction earlier.
4346
4347         * utils.py (regex_safe): new function; escapes characters which
4348         have meaning to SQL's regex comparison operator ('~').
4349
4350 2000-11-30  James Troup  <james@nocrew.org>
4351
4352         * katie (install): pool_location is based on source package name,
4353         not binary package.
4354
4355         * utils.py (move): if dest is a directory, append the filename
4356         before chmod-ing.
4357         (copy): ditto.
4358
4359         * katie (check_files): don't allow overwriting of existing .debs.
4360         (check_dsc): don't allow overwriting of existing source files.
4361
4362 2000-11-27  James Troup  <james@nocrew.org>
4363
4364         * katie (check_signature): don't try to load rsaref; it's
4365         obsolete.
4366         (in_override_p): don't try to lookup override entries for packages
4367         with an invalid suite name.
4368         (announce): don't assume the suite name is valid; use Find() to
4369         lookup the mailing list name for announcements.
4370
4371         * utils.py (where_am_i): typo; hostname is in the first element,
4372         not second.
4373
4374         * db_access.py (get_suite_id): return -1 on an unknown suite.
4375
4376 2000-11-26  James Troup  <james@nocrew.org>
4377
4378         * katie (install): fix CopyChanges handling; typo in in checking
4379         Cnf for CopyChanges flag and was calling non-existent function
4380         copy_file.
4381
4382         * utils.py (copy): new function; clone of move without the
4383         unlink().
4384
4385 2000-11-25  James Troup  <james@nocrew.org>
4386
4387         * utils.py (build_file_list): handle non-US prefixes properly
4388         (i.e. 'non-US' -> 'non-US/main' and 'non-US/libs' -> 'non-US/main'
4389         + 'libs' not 'non-US/libs').
4390         (send_mail): add '-odq' to sendmail invocation to avoid DNS lookup
4391         delays.  This is possibly(/probably) exim speicifc and (like other
4392         sendmail options) needs to be in the config file.
4393
4394 2000-11-24  James Troup  <james@nocrew.org>
4395
4396         * rhona (check_sources): we need file id from dsc_files; not id.
4397         Handle non .dsc source files being re-referenced in dsc_files.
4398
4399         * katie (in_override_p): strip out any 'non-US' prefix.
4400         (check_files): use utils.where_am_i() rather than hardcoding.
4401         (check_files): validate the component.
4402         (install): use utils.where_am_i() rather than hardcoding.
4403         (install): fix mail to go to actual recepient.
4404         (reject): likewise.
4405         (manual_reject): likewise.
4406         (acknowledge_new): likewise.
4407         (announce): likewise.
4408
4409         * db_access.py (get_component_id): ignore case when searching for
4410         the component and don't crash if the component can't be found, but
4411         return -1.
4412         (get_location_id): handle -1 from get_component_id().
4413
4414         * jenna (generate_src_list): don't bring 'suite' into our big
4415         multi-table-joining select as we already know the 'suite_id'.
4416         (generate_bin_list): likewise.
4417
4418         * neve (main): don't quit if not on ftp-master.
4419         (process_packages): remove unused variable 'suite_codename'.
4420
4421         * utils.py (move): actually move the file.
4422         (build_file_list): handle non-US prefixes in the section.
4423
4424         * catherine (main): use which_conf_file().
4425         * charisma (main): likewise.
4426         * heidi (main): likewise.
4427         * jenna (main): likewise.
4428         * katie (main): likewise.
4429         * neve (main): likewise.
4430         * rhona (main): likewise.
4431
4432         * utils.py (where_am_i): new routine; determines the archive as
4433         understood by other 'dak' programs.
4434         (which_conf_file): new routine; determines the conf file to read.
4435
4436 2000-11-17  James Troup  <james@nocrew.org>
4437
4438         * katie (install): fix where .changes files for proposed-updates
4439         go.
4440
4441 2000-11-04  James Troup  <james@nocrew.org>
4442
4443         * jenna (main): handle architecture properly if no
4444         -a/--architecture argument is given, i.e. reset architecture with
4445         the values for the suite for each suite.
4446
4447         * Add apt_pkg.init() to the start of all scripts as it's now
4448         required by python-apt.
4449
4450 2000-10-29  James Troup  <james@nocrew.org>
4451
4452         * jenna (generate_bin_list): take an additional argument 'type'
4453         and use it in the SELECT.
4454         (main): if processing component 'main', process udebs and debs.
4455
4456         * neve (process_packages): set up 'type' in 'binaries' (by
4457         assuming .deb).
4458
4459         * katie (re_isadeb): accept ".udeb" or ".deb" as a file ending.
4460         (check_files): set up files[file]["dbtype"].
4461         (install): use files[file]["dbtype"] to set up the 'type' field in
4462         the 'binaries' table.
4463
4464         * init_pool.sql: add a 'type' field to the 'binaries' table to
4465         distinguisgh between ".udeb" and ".deb" files.
4466
4467         * utils.py (move): scrap basename() usage; use a "dir_p(dest) :
4468         dest ? dirname(dest)" type check instead.
4469
4470         * katie (check_dsc): handle the case of an .orig.tar.gz not found
4471         in the pool without crashing.  Also handle the case of being asked
4472         to look for something other than an .orig.tar.gz in the pool.
4473
4474 2000-10-26  James Troup  <james@nocrew.org>
4475
4476         * katie (install): fix filenames put into files table during
4477         poolification of legacy source.
4478
4479         * utils.py (move): work around a bug in os.path.basename() which
4480         cunningly returns '' if there is a trailing slash on the path
4481         passed to it.
4482
4483         * katie (check_dsc): Remove more cruft.  If we find the
4484         .orig.tar.gz in the pool and it's in a legacy (or legacy-mixed)
4485         location, make a note of that so we can fix things in install().
4486         (install): as above.  Move any old source out of legacy locations
4487         so that 'apt-get source' will work.
4488         (process_it): reset the flag that indicates to install that the
4489         source needs moved.
4490
4491         * cron.daily: more.  Nowhere near complete yet though.
4492
4493         * katie (install): don't run os.makedirs, a) utils.move() does
4494         this now, b) we weren't removing the user's umask and were
4495         creating dirs with SNAFU permissions.
4496         (check_dsc): rewrite the .orig.tar.gz handling to take into
4497         account, err, package pools.  i.e. look anywhere in the pool
4498         rather than faffing around with two simple paths.
4499
4500         * neve (process_sources): add the .dsc to dsc_files too.
4501
4502 2000-10-25  James Troup  <james@nocrew.org>
4503
4504         * neve (process_sources): don't duplicate .orig.tar.gz's.
4505
4506 2000-10-23  James Troup  <james@nocrew.org>
4507
4508         * utils.py (re_extract_src_version): moved here.
4509
4510         * neve: move re_extract_src_version to utils.
4511         (process_packages): reflect change.
4512
4513         * katie (install): reflect change.
4514
4515 2000-10-19  James Troup  <james@nocrew.org>
4516
4517         * jenna (generate_src_list): handle locations with null
4518         components.
4519         (generate_bin_list): likewise.
4520