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