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