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