################################################################################
+import os
import sys
import traceback
import daklib.utils
+import warnings
from daklib.daklog import Logger
from daklib.config import Config
+from daklib.dak_exceptions import CantOpenError
################################################################################
("process-new",
"Process NEW and BYHAND packages"),
- ("process-unchecked",
+ ("process-upload",
"Process packages in queue/unchecked"),
- ("process-accepted",
- "Install packages into the pool"),
+ ("process-policy",
+ "Process packages in policy queues from COMMENTS files"),
- ("make-suite-file-list",
- "Generate lists of packages per suite for apt-ftparchive"),
+ ("dominate",
+ "Remove obsolete source and binary associations from suites"),
("make-pkg-file-mapping",
"Generate package <-> file mapping"),
+ ("generate-filelist",
+ "Generate file lists for apt-ftparchive"),
("generate-releases",
"Generate Release files"),
+ ("generate-packages-sources",
+ "Generate Packages/Sources files"),
("contents",
"Generate content files"),
("generate-index-diffs",
"Generate .diff/Index files"),
("clean-suites",
"Clean unused/superseded packages from the archive"),
+ ("manage-build-queues",
+ "Clean and update metadata for build queues"),
("clean-queues",
"Clean cruft from incoming"),
("clean-proposed-updates",
"Manipulate suites in bulk"),
("cruft-report",
"Check for obsolete or duplicated packages"),
- ("decode-dot-dak",
- "Display contents of a .dak file"),
("examine-package",
"Show information useful for NEW processing"),
("find-null-maintainers",
"Sync PostgreSQL users with passwd file"),
("admin",
"Perform administration on the dak database"),
- ("init-db",
- "Update the database to match the conf file"),
("update-db",
"Updates databae schema to latest revision"),
("init-dirs",
"Generate statistics"),
("bts-categorize",
"Categorize uncategorized bugs filed against ftp.debian.org"),
+ ("import-known-changes",
+ "import old changes files into known_changes table"),
("add-user",
"Add a user to the archive"),
+ ("make-changelog",
+ "Generate changelog between two suites"),
]
return functionality
def main():
"""Launch dak functionality."""
- logger = Logger(Config(), 'dak top-level', print_starting=False)
+
+ try:
+ logger = Logger(Config(), 'dak top-level', print_starting=False)
+ except CantOpenError:
+ logger = None
functionality = init()
modules = [ command for (command, _) in functionality ]
daklib.utils.warn("unknown command '%s'" % (cmdname))
usage(functionality, 1)
+ # We do not care. No idea wth sqlalchemy warns about them, makes no sense,
+ # so we ignore it.
+ warnings.filterwarnings("ignore", 'Predicate of partial index')
+
# Invoke the module
module = __import__(cmdname.replace("-","_"))
except KeyboardInterrupt:
msg = 'KeyboardInterrupt caught; exiting'
print msg
- logger.log([msg])
+ if logger:
+ logger.log([msg])
sys.exit(1)
except SystemExit:
pass
except:
- for line in traceback.format_exc().split('\n')[:-1]:
- logger.log(['exception', line])
+ if logger:
+ for line in traceback.format_exc().split('\n')[:-1]:
+ logger.log(['exception', line])
raise
################################################################################
if __name__ == "__main__":
+ os.environ['LANG'] = 'C'
+ os.environ['LC_ALL'] = 'C'
main()