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