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