mirror of
https://github.com/TECHNOFAB11/bumpver.git
synced 2025-12-12 14:30:09 +01:00
better error reporting for individal pattern errors
This commit is contained in:
parent
1cec511f95
commit
e0fc6f7d75
3 changed files with 38 additions and 21 deletions
|
|
@ -15,6 +15,7 @@ import pathlib2 as pl
|
||||||
from . import parse
|
from . import parse
|
||||||
from . import config
|
from . import config
|
||||||
from . import version
|
from . import version
|
||||||
|
from . import patterns
|
||||||
|
|
||||||
|
|
||||||
log = logging.getLogger("pycalver.rewrite")
|
log = logging.getLogger("pycalver.rewrite")
|
||||||
|
|
@ -41,28 +42,38 @@ def detect_line_sep(content: str) -> str:
|
||||||
|
|
||||||
|
|
||||||
def rewrite_lines(
|
def rewrite_lines(
|
||||||
patterns: typ.List[str], new_version: str, old_lines: typ.List[str]
|
pattern_strs: typ.List[str], new_version: str, old_lines: typ.List[str]
|
||||||
) -> typ.List[str]:
|
) -> typ.List[str]:
|
||||||
"""Replace occurances of patterns in old_lines with new_version.
|
"""Replace occurances of pattern_strs in old_lines with new_version.
|
||||||
|
|
||||||
>>> patterns = ['__version__ = "{pycalver}"']
|
>>> pattern_strs = ['__version__ = "{pycalver}"']
|
||||||
>>> rewrite_lines(patterns, "v201811.0123-beta", ['__version__ = "v201809.0002-beta"'])
|
>>> rewrite_lines(pattern_strs, "v201811.0123-beta", ['__version__ = "v201809.0002-beta"'])
|
||||||
['__version__ = "v201811.0123-beta"']
|
['__version__ = "v201811.0123-beta"']
|
||||||
|
|
||||||
>>> patterns = ['__version__ = "{pep440_version}"']
|
>>> pattern_strs = ['__version__ = "{pep440_version}"']
|
||||||
>>> rewrite_lines(patterns, "v201811.0123-beta", ['__version__ = "201809.2b0"'])
|
>>> rewrite_lines(pattern_strs, "v201811.0123-beta", ['__version__ = "201809.2b0"'])
|
||||||
['__version__ = "201811.123b0"']
|
['__version__ = "201811.123b0"']
|
||||||
"""
|
"""
|
||||||
new_version_nfo = version.parse_version_info(new_version)
|
new_version_nfo = version.parse_version_info(new_version)
|
||||||
|
|
||||||
new_lines = old_lines[:]
|
new_lines = old_lines[:]
|
||||||
|
found_patterns = set()
|
||||||
|
|
||||||
for m in parse.iter_matches(old_lines, patterns):
|
for m in parse.iter_matches(old_lines, pattern_strs):
|
||||||
|
found_patterns.add(m.pattern)
|
||||||
replacement = version.format_version(new_version_nfo, m.pattern)
|
replacement = version.format_version(new_version_nfo, m.pattern)
|
||||||
span_l, span_r = m.span
|
span_l, span_r = m.span
|
||||||
new_line = m.line[:span_l] + replacement + m.line[span_r:]
|
new_line = m.line[:span_l] + replacement + m.line[span_r:]
|
||||||
new_lines[m.lineno] = new_line
|
new_lines[m.lineno] = new_line
|
||||||
|
|
||||||
|
non_matched_patterns = set(pattern_strs) - found_patterns
|
||||||
|
if non_matched_patterns:
|
||||||
|
for non_matched_pattern in non_matched_patterns:
|
||||||
|
log.error(f"No match for pattern '{non_matched_pattern}'")
|
||||||
|
compiled_pattern = patterns._compile_pattern(non_matched_pattern)
|
||||||
|
log.error(f"Pattern compiles to regex '{compiled_pattern}'")
|
||||||
|
raise ValueError("Invalid pattern(s)", list(non_matched_patterns))
|
||||||
|
else:
|
||||||
return new_lines
|
return new_lines
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -75,32 +86,34 @@ class RewrittenFileData(typ.NamedTuple):
|
||||||
new_lines: typ.List[str]
|
new_lines: typ.List[str]
|
||||||
|
|
||||||
|
|
||||||
def rfd_from_content(patterns: typ.List[str], new_version: str, content: str) -> RewrittenFileData:
|
def rfd_from_content(
|
||||||
|
pattern_strs: typ.List[str], new_version: str, content: str
|
||||||
|
) -> RewrittenFileData:
|
||||||
r"""Rewrite pattern occurrences with version string.
|
r"""Rewrite pattern occurrences with version string.
|
||||||
|
|
||||||
>>> patterns = ['__version__ = "{pycalver}"']
|
>>> pattern_strs = ['__version__ = "{pycalver}"']
|
||||||
>>> content = '__version__ = "v201809.0001-alpha"'
|
>>> content = '__version__ = "v201809.0001-alpha"'
|
||||||
>>> rfd = rfd_from_content(patterns, "v201809.0123", content)
|
>>> rfd = rfd_from_content(pattern_strs, "v201809.0123", content)
|
||||||
>>> rfd.new_lines
|
>>> rfd.new_lines
|
||||||
['__version__ = "v201809.0123"']
|
['__version__ = "v201809.0123"']
|
||||||
"""
|
"""
|
||||||
line_sep = detect_line_sep(content)
|
line_sep = detect_line_sep(content)
|
||||||
old_lines = content.split(line_sep)
|
old_lines = content.split(line_sep)
|
||||||
new_lines = rewrite_lines(patterns, new_version, old_lines)
|
new_lines = rewrite_lines(pattern_strs, new_version, old_lines)
|
||||||
return RewrittenFileData("<path>", line_sep, old_lines, new_lines)
|
return RewrittenFileData("<path>", line_sep, old_lines, new_lines)
|
||||||
|
|
||||||
|
|
||||||
def _iter_file_paths(
|
def _iter_file_paths(
|
||||||
file_patterns: config.PatternsByGlob
|
file_patterns: config.PatternsByGlob
|
||||||
) -> typ.Iterable[typ.Tuple[pl.Path, config.Patterns]]:
|
) -> typ.Iterable[typ.Tuple[pl.Path, config.Patterns]]:
|
||||||
for globstr, patterns in file_patterns.items():
|
for globstr, pattern_strs in file_patterns.items():
|
||||||
file_paths = glob.glob(globstr)
|
file_paths = glob.glob(globstr)
|
||||||
if not any(file_paths):
|
if not any(file_paths):
|
||||||
errmsg = f"No files found for path/glob '{globstr}'"
|
errmsg = f"No files found for path/glob '{globstr}'"
|
||||||
raise ValueError(errmsg)
|
raise ValueError(errmsg)
|
||||||
for file_path_str in file_paths:
|
for file_path_str in file_paths:
|
||||||
file_path = pl.Path(file_path_str)
|
file_path = pl.Path(file_path_str)
|
||||||
yield (file_path, patterns)
|
yield (file_path, pattern_strs)
|
||||||
|
|
||||||
|
|
||||||
def iter_rewritten(
|
def iter_rewritten(
|
||||||
|
|
@ -126,11 +139,11 @@ def iter_rewritten(
|
||||||
'''
|
'''
|
||||||
fh: typ.IO[str]
|
fh: typ.IO[str]
|
||||||
|
|
||||||
for file_path, patterns in _iter_file_paths(file_patterns):
|
for file_path, pattern_strs in _iter_file_paths(file_patterns):
|
||||||
with file_path.open(mode="rt", encoding="utf-8") as fh:
|
with file_path.open(mode="rt", encoding="utf-8") as fh:
|
||||||
content = fh.read()
|
content = fh.read()
|
||||||
|
|
||||||
rfd = rfd_from_content(patterns, new_version, content)
|
rfd = rfd_from_content(pattern_strs, new_version, content)
|
||||||
yield rfd._replace(path=str(file_path))
|
yield rfd._replace(path=str(file_path))
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -169,11 +182,11 @@ def diff(new_version: str, file_patterns: config.PatternsByGlob) -> str:
|
||||||
full_diff = ""
|
full_diff = ""
|
||||||
fh: typ.IO[str]
|
fh: typ.IO[str]
|
||||||
|
|
||||||
for file_path, patterns in sorted(_iter_file_paths(file_patterns)):
|
for file_path, pattern_strs in sorted(_iter_file_paths(file_patterns)):
|
||||||
with file_path.open(mode="rt", encoding="utf-8") as fh:
|
with file_path.open(mode="rt", encoding="utf-8") as fh:
|
||||||
content = fh.read()
|
content = fh.read()
|
||||||
|
|
||||||
rfd = rfd_from_content(patterns, new_version, content)
|
rfd = rfd_from_content(pattern_strs, new_version, content)
|
||||||
rfd = rfd._replace(path=str(file_path))
|
rfd = rfd._replace(path=str(file_path))
|
||||||
lines = diff_lines(rfd)
|
lines = diff_lines(rfd)
|
||||||
if len(lines) == 0:
|
if len(lines) == 0:
|
||||||
|
|
|
||||||
4
test/fixtures/project_b/README.rst
vendored
4
test/fixtures/project_b/README.rst
vendored
|
|
@ -1,3 +1,5 @@
|
||||||
|
[PyCalVer v201307.0456]
|
||||||
|
|
||||||
.. |badge| image:: https://img.shields.io/badge/PyCalVer-v201307.0456--beta-blue.svg
|
.. |badge| image:: https://img.shields.io/badge/PyCalVer-v201307.0456--beta-blue.svg
|
||||||
:target: https://shields.io/
|
|
||||||
|
.. |badge| image:: https://img.shields.io/static/v1.svg?label=PyCalVer&message=v201307.0456-beta&color=blue
|
||||||
|
|
|
||||||
2
test/fixtures/project_b/setup.cfg
vendored
2
test/fixtures/project_b/setup.cfg
vendored
|
|
@ -10,6 +10,8 @@ setup.cfg =
|
||||||
setup.py =
|
setup.py =
|
||||||
version="{pep440_version}"
|
version="{pep440_version}"
|
||||||
README.rst =
|
README.rst =
|
||||||
|
[PyCalVer {version}]
|
||||||
img.shields.io/badge/PyCalVer-{calver}{build}-{release}-blue
|
img.shields.io/badge/PyCalVer-{calver}{build}-{release}-blue
|
||||||
|
img.shields.io/static/v1.svg?label=PyCalVer&message={version}&color=blue
|
||||||
src/module_v*/__init__.py =
|
src/module_v*/__init__.py =
|
||||||
__version__ = "{version}"
|
__version__ = "{version}"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue