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