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