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