Mike Fährmann ece73b5b2a
make 'path' and 'keywords' available in logging messages
Wrap all loggers used by job, extractor, downloader, and postprocessor
objects into a (custom) LoggerAdapter that provides access to the
underlying job, extractor, pathfmt, and kwdict objects and their
properties.

__init__() signatures for all downloader and postprocessor classes have
been changed to take the current Job object as their first argument,
instead of the current extractor or pathfmt.

(#574, #575)
2020-05-18 19:04:51 +02:00

47 lines
954 B
Python

# -*- coding: utf-8 -*-
# Copyright 2018-2020 Mike Fährmann
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation.
"""Post-processing modules"""
import importlib
modules = [
"classify",
"compare",
"exec",
"metadata",
"mtime",
"ugoira",
"zip",
]
def find(name):
"""Return a postprocessor class with the given name"""
try:
return _cache[name]
except KeyError:
pass
klass = None
if name in modules: # prevent unwanted imports
try:
module = importlib.import_module("." + name, __package__)
except ImportError:
pass
else:
klass = module.__postprocessor__
_cache[name] = klass
return klass
# --------------------------------------------------------------------
# internals
_cache = {}