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