Make the following directories:
clean sources-old sources dirty
and optionally:
test build done

Choose version number: 
 * remember that RPM is stupid and considers 5.0beta1 newer than
   5.0, so always use "code versions" for the packages. Also
   stuff like "-" etc is not working, so omit it

Checkout branch:
 fix the paths in versions script
 use the checkout script
 clean up the cache/ directory from previous builds

Update version number
 * */*.lsm
 * arts/configure.in.in
 * tdewebdev/quanta/src/quanta.h
 * tdevelop/configure.in.in
 * tdebase/konqueror/version.h
 * tdebase/startkde 
 * kde-common/admin/cvs.sh has VERSION="3.x.x"
 * tdelibs/tdecore/tdeversion.h
 * tdelibs/tdecore/ksycoca.h --> ksycoca version number
 * tdelibs/README
 * tdenetwork/kopete/libkopete/kopeteversion.h
 * bugs/template/wizard/report.html.tmpl
 * bugs/bugz/wizard_config.pl
 * www/areas/enterprise/bizcase/form.inc (major KDE versions only)
 * for koffice: configure.in.in, lib/kofficecore/kofficeversion.h, etc.
 * common and versions scripts

Update kdepackages in tdelibs/tdeui
Run "fixuifiles"
Make sure the meinproc in path is a version of the correct branch
Use tag_all to get clean sources into "clean" directory (e.g. <releasedir>/clean/koffice)
Make tarballs using "pack <module>". Start with tde-i18n. Do tdelibs/tdebase last.
If you have to redo a tarball because of a code change and don't want to wait for meinproc to complete,
 extract the old tarball inside cache/<module> before calling "pack". The docu script will
 then use the version from the cache instead of regenerating it, saving a lot of time.
Upload tarballs to their final location, as 'ftprelease' user under a src/ directory.
chmod o-rwx any new dir (so that they're not yet public)
chmod g+w the new directory where packagers will put their files
create contrib/ directory and make it g+w for group "packager"
Test tarballs
md5sum *.tar.bz2 tde-i18n/*.tar.bz2 > MD5SUMS
gpg --detach-sign -a MD5SUMS (if you're bored, do it for all files)
(Note: for KOffice, MD5SUMS should be signed with --clearsign instead of --detach-sign.)
Prepare a Changelog
Inform the packagers (kde-packager at kde dot org)
Ask for/write announcement (on the kde-promo mailing-list)

When everything is ready:

- Make directory on the FTP site readable, so that mirrors can start getting it
  Update latest and/or {koffice,tdevelop}-latest symlinks on the FTP site

- clean up the older releases. Make sure that kdestableftp and kdeunstableftp
  remain in their advertised size limits (~20 GB). Sort out older binary packages, 
  add compatibility links.

- Enable syncing during the night, so that the uplink can be saturated and
  does not affect interactive server load and network traffic. 

- Pre-notify sysadm@trolltech.com and sysadmin@kde.org about an upcoming release
  so that they can be ready for fixing bandwidth problems, server outages or similiar.
  Its not uncommon that slashdotting affects our server structure, and the right
  people have to know about the release date and time to be able to react in time. 

When most of the mirrors behind http://download.kde.org have updated:
Commit announcement (after adding PHP header/footer)
Add an entry to www/index.php, www/announcements/index.php, www/info/releases.php,
www/download/index.php and www/whatiskde/project.php

Post announcement in text to kde-announce@kde.org
Post news bit to
  * dot.kde.org (editors@kdenews.org)
  * freshmeat.net
  * newsgroups, optionally