beets/beetsplug/substitute.py
2024-10-12 15:34:05 +02:00

79 lines
2.5 KiB
Python

# This file is part of beets.
# Copyright 2023, Daniele Ferone.
#
# Permission is hereby granted, free of charge, to any person obtaining
# a copy of this software and associated documentation files (the
# "Software"), to deal in the Software without restriction, including
# without limitation the rights to use, copy, modify, merge, publish,
# distribute, sublicense, and/or sell copies of the Software, and to
# permit persons to whom the Software is furnished to do so, subject to
# the following conditions:
#
# The above copyright notice and this permission notice shall be
# included in all copies or substantial portions of the Software.
"""The substitute plugin module.
Uses user-specified substitution rules to canonicalize names for path formats.
"""
import re
import textwrap
from beets.plugins import BeetsPlugin
class Substitute(BeetsPlugin):
"""The substitute plugin class.
Create a template field function that substitute the given field with the
given substitution rules. ``rules`` must be a list of (pattern,
replacement) pairs.
"""
def tmpl_substitute(self, text):
"""Do the actual replacing."""
if text:
for pattern, replacement in self.substitute_rules:
new_text, subs_made = pattern.subn(replacement, text)
if subs_made > 0:
return new_text
return text
else:
return ""
def __init__(self):
"""Initialize the substitute plugin.
Get the configuration, register template function and create list of
substitute rules.
"""
super().__init__()
self.substitute_rules = []
self.template_funcs["substitute"] = self.tmpl_substitute
if isinstance(self.config.get(), dict):
self._log.warning(
"Unordered configuration is deprecated, as it leads to"
+ " unpredictable behaviour on overlapping rules.\n"
+ textwrap.dedent(
"""
Old syntax:
substitute:
a: b
c: d
New syntax:
substitute:
- a: b
- c: d
"""
)
)
pairs = self.config.flatten().items()
else:
pairs = self.config.as_pairs()
for key, value in pairs:
pattern = re.compile(key, flags=re.IGNORECASE)
self.substitute_rules.append((pattern, value))