implement 'extension-map' option (#318)

This commit is contained in:
Mike Fährmann 2020-10-31 22:42:42 +01:00
parent 98a4d86a01
commit e3480bc8de
No known key found for this signature in database
GPG Key ID: 5680CA389D365A88
2 changed files with 29 additions and 1 deletions

View File

@ -183,6 +183,25 @@ Description
escaped with backslashes, e.g. ``"\\[\\]"``
extractor.*.extension-map
-------------------------
Type
``object``
Default
``null``
Example
.. code:: json
{
"jpeg": "jpg",
"jpe" : "jpg",
"jfif": "jpg",
"jif" : "jpg",
"jfi" : "jpg"
}
Description
A JSON ``object`` mapping filename extensions to alternatives.
extractor.*.skip
----------------
Type

View File

@ -723,6 +723,12 @@ class PathFormat():
directory_fmt = extractor.config("directory", extractor.directory_fmt)
kwdefault = extractor.config("keywords-default")
extension_map = extractor.config("extension-map")
if extension_map is None:
# TODO: better default value in 1.16.0
extension_map = {}
self.extension_map = extension_map.get
try:
self.filename_formatter = Formatter(
filename_fmt, kwdefault).format_map
@ -850,7 +856,9 @@ class PathFormat():
"""Set general filename data"""
self.kwdict = kwdict
self.temppath = self.prefix = ""
self.extension = kwdict["extension"]
ext = kwdict["extension"]
kwdict["extension"] = self.extension = self.extension_map(ext, ext)
if self.extension:
self.build_path()
@ -859,6 +867,7 @@ class PathFormat():
def set_extension(self, extension, real=True):
"""Set filename extension"""
extension = self.extension_map(extension, extension)
if real:
self.extension = extension
self.kwdict["extension"] = self.prefix + extension