kopia lustrzana https://github.com/jupyterhub/repo2docker
Run pre-commit
rodzic
2eac520042
commit
fa8394b09b
|
@ -3,7 +3,7 @@ from ._version import get_versions
|
|||
__version__ = get_versions()["version"]
|
||||
del get_versions
|
||||
|
||||
from . import _version
|
||||
from .app import Repo2Docker
|
||||
|
||||
from . import _version
|
||||
__version__ = _version.get_versions()['version']
|
||||
__version__ = _version.get_versions()["version"]
|
||||
|
|
|
@ -1,4 +1,3 @@
|
|||
|
||||
# This file helps to compute a version number in source trees obtained from
|
||||
# git-archive tarball (such as those provided by githubs download-from-tag
|
||||
# feature). Distribution tarballs (built by setup.py sdist) and build
|
||||
|
@ -12,12 +11,12 @@
|
|||
"""Git implementation of _version.py."""
|
||||
|
||||
import errno
|
||||
import functools
|
||||
import os
|
||||
import re
|
||||
import subprocess
|
||||
import sys
|
||||
from typing import Any, Callable, Dict, List, Optional, Tuple
|
||||
import functools
|
||||
|
||||
|
||||
def get_keywords() -> Dict[str, str]:
|
||||
|
@ -68,12 +67,14 @@ HANDLERS: Dict[str, Dict[str, Callable]] = {}
|
|||
|
||||
def register_vcs_handler(vcs: str, method: str) -> Callable: # decorator
|
||||
"""Create decorator to mark a method as the handler of a VCS."""
|
||||
|
||||
def decorate(f: Callable) -> Callable:
|
||||
"""Store f in HANDLERS[vcs][method]."""
|
||||
if vcs not in HANDLERS:
|
||||
HANDLERS[vcs] = {}
|
||||
HANDLERS[vcs][method] = f
|
||||
return f
|
||||
|
||||
return decorate
|
||||
|
||||
|
||||
|
@ -100,10 +101,14 @@ def run_command(
|
|||
try:
|
||||
dispcmd = str([command] + args)
|
||||
# remember shell=False, so use git.cmd on windows, not just git
|
||||
process = subprocess.Popen([command] + args, cwd=cwd, env=env,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=(subprocess.PIPE if hide_stderr
|
||||
else None), **popen_kwargs)
|
||||
process = subprocess.Popen(
|
||||
[command] + args,
|
||||
cwd=cwd,
|
||||
env=env,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=(subprocess.PIPE if hide_stderr else None),
|
||||
**popen_kwargs,
|
||||
)
|
||||
break
|
||||
except OSError as e:
|
||||
if e.errno == errno.ENOENT:
|
||||
|
@ -114,7 +119,7 @@ def run_command(
|
|||
return None, None
|
||||
else:
|
||||
if verbose:
|
||||
print("unable to find command, tried %s" % (commands,))
|
||||
print("unable to find command, tried {}".format(commands))
|
||||
return None, None
|
||||
stdout = process.communicate()[0].strip().decode()
|
||||
if process.returncode != 0:
|
||||
|
@ -141,15 +146,21 @@ def versions_from_parentdir(
|
|||
for _ in range(3):
|
||||
dirname = os.path.basename(root)
|
||||
if dirname.startswith(parentdir_prefix):
|
||||
return {"version": dirname[len(parentdir_prefix):],
|
||||
"full-revisionid": None,
|
||||
"dirty": False, "error": None, "date": None}
|
||||
return {
|
||||
"version": dirname[len(parentdir_prefix) :],
|
||||
"full-revisionid": None,
|
||||
"dirty": False,
|
||||
"error": None,
|
||||
"date": None,
|
||||
}
|
||||
rootdirs.append(root)
|
||||
root = os.path.dirname(root) # up a level
|
||||
|
||||
if verbose:
|
||||
print("Tried directories %s but none started with prefix %s" %
|
||||
(str(rootdirs), parentdir_prefix))
|
||||
print(
|
||||
"Tried directories %s but none started with prefix %s"
|
||||
% (str(rootdirs), parentdir_prefix)
|
||||
)
|
||||
raise NotThisMethod("rootdir doesn't start with parentdir_prefix")
|
||||
|
||||
|
||||
|
@ -162,7 +173,7 @@ def git_get_keywords(versionfile_abs: str) -> Dict[str, str]:
|
|||
# _version.py.
|
||||
keywords: Dict[str, str] = {}
|
||||
try:
|
||||
with open(versionfile_abs, "r") as fobj:
|
||||
with open(versionfile_abs) as fobj:
|
||||
for line in fobj:
|
||||
if line.strip().startswith("git_refnames ="):
|
||||
mo = re.search(r'=\s*"(.*)"', line)
|
||||
|
@ -212,7 +223,7 @@ def git_versions_from_keywords(
|
|||
# starting in git-1.8.3, tags are listed as "tag: foo-1.0" instead of
|
||||
# just "foo-1.0". If we see a "tag: " prefix, prefer those.
|
||||
TAG = "tag: "
|
||||
tags = {r[len(TAG):] for r in refs if r.startswith(TAG)}
|
||||
tags = {r[len(TAG) :] for r in refs if r.startswith(TAG)}
|
||||
if not tags:
|
||||
# Either we're using git < 1.8.3, or there really are no tags. We use
|
||||
# a heuristic: assume all version tags have a digit. The old git %d
|
||||
|
@ -221,7 +232,7 @@ def git_versions_from_keywords(
|
|||
# between branches and tags. By ignoring refnames without digits, we
|
||||
# filter out many common branch names like "release" and
|
||||
# "stabilization", as well as "HEAD" and "master".
|
||||
tags = {r for r in refs if re.search(r'\d', r)}
|
||||
tags = {r for r in refs if re.search(r"\d", r)}
|
||||
if verbose:
|
||||
print("discarding '%s', no digits" % ",".join(refs - tags))
|
||||
if verbose:
|
||||
|
@ -229,32 +240,36 @@ def git_versions_from_keywords(
|
|||
for ref in sorted(tags):
|
||||
# sorting will prefer e.g. "2.0" over "2.0rc1"
|
||||
if ref.startswith(tag_prefix):
|
||||
r = ref[len(tag_prefix):]
|
||||
r = ref[len(tag_prefix) :]
|
||||
# Filter out refs that exactly match prefix or that don't start
|
||||
# with a number once the prefix is stripped (mostly a concern
|
||||
# when prefix is '')
|
||||
if not re.match(r'\d', r):
|
||||
if not re.match(r"\d", r):
|
||||
continue
|
||||
if verbose:
|
||||
print("picking %s" % r)
|
||||
return {"version": r,
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False, "error": None,
|
||||
"date": date}
|
||||
return {
|
||||
"version": r,
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False,
|
||||
"error": None,
|
||||
"date": date,
|
||||
}
|
||||
# no suitable tags, so version is "0+unknown", but full hex is still there
|
||||
if verbose:
|
||||
print("no suitable tags, using unknown + full revision id")
|
||||
return {"version": "0+unknown",
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False, "error": "no suitable tags", "date": None}
|
||||
return {
|
||||
"version": "0+unknown",
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False,
|
||||
"error": "no suitable tags",
|
||||
"date": None,
|
||||
}
|
||||
|
||||
|
||||
@register_vcs_handler("git", "pieces_from_vcs")
|
||||
def git_pieces_from_vcs(
|
||||
tag_prefix: str,
|
||||
root: str,
|
||||
verbose: bool,
|
||||
runner: Callable = run_command
|
||||
tag_prefix: str, root: str, verbose: bool, runner: Callable = run_command
|
||||
) -> Dict[str, Any]:
|
||||
"""Get version from 'git describe' in the root of the source tree.
|
||||
|
||||
|
@ -273,8 +288,7 @@ def git_pieces_from_vcs(
|
|||
env.pop("GIT_DIR", None)
|
||||
runner = functools.partial(runner, env=env)
|
||||
|
||||
_, rc = runner(GITS, ["rev-parse", "--git-dir"], cwd=root,
|
||||
hide_stderr=not verbose)
|
||||
_, rc = runner(GITS, ["rev-parse", "--git-dir"], cwd=root, hide_stderr=not verbose)
|
||||
if rc != 0:
|
||||
if verbose:
|
||||
print("Directory %s not under git control" % root)
|
||||
|
@ -282,10 +296,19 @@ def git_pieces_from_vcs(
|
|||
|
||||
# if there is a tag matching tag_prefix, this yields TAG-NUM-gHEX[-dirty]
|
||||
# if there isn't one, this yields HEX[-dirty] (no NUM)
|
||||
describe_out, rc = runner(GITS, [
|
||||
"describe", "--tags", "--dirty", "--always", "--long",
|
||||
"--match", f"{tag_prefix}[[:digit:]]*"
|
||||
], cwd=root)
|
||||
describe_out, rc = runner(
|
||||
GITS,
|
||||
[
|
||||
"describe",
|
||||
"--tags",
|
||||
"--dirty",
|
||||
"--always",
|
||||
"--long",
|
||||
"--match",
|
||||
f"{tag_prefix}[[:digit:]]*",
|
||||
],
|
||||
cwd=root,
|
||||
)
|
||||
# --long was added in git-1.5.5
|
||||
if describe_out is None:
|
||||
raise NotThisMethod("'git describe' failed")
|
||||
|
@ -300,8 +323,7 @@ def git_pieces_from_vcs(
|
|||
pieces["short"] = full_out[:7] # maybe improved later
|
||||
pieces["error"] = None
|
||||
|
||||
branch_name, rc = runner(GITS, ["rev-parse", "--abbrev-ref", "HEAD"],
|
||||
cwd=root)
|
||||
branch_name, rc = runner(GITS, ["rev-parse", "--abbrev-ref", "HEAD"], cwd=root)
|
||||
# --abbrev-ref was added in git-1.6.3
|
||||
if rc != 0 or branch_name is None:
|
||||
raise NotThisMethod("'git rev-parse --abbrev-ref' returned error")
|
||||
|
@ -341,17 +363,16 @@ def git_pieces_from_vcs(
|
|||
dirty = git_describe.endswith("-dirty")
|
||||
pieces["dirty"] = dirty
|
||||
if dirty:
|
||||
git_describe = git_describe[:git_describe.rindex("-dirty")]
|
||||
git_describe = git_describe[: git_describe.rindex("-dirty")]
|
||||
|
||||
# now we have TAG-NUM-gHEX or HEX
|
||||
|
||||
if "-" in git_describe:
|
||||
# TAG-NUM-gHEX
|
||||
mo = re.search(r'^(.+)-(\d+)-g([0-9a-f]+)$', git_describe)
|
||||
mo = re.search(r"^(.+)-(\d+)-g([0-9a-f]+)$", git_describe)
|
||||
if not mo:
|
||||
# unparsable. Maybe git-describe is misbehaving?
|
||||
pieces["error"] = ("unable to parse git-describe output: '%s'"
|
||||
% describe_out)
|
||||
pieces["error"] = "unable to parse git-describe output: '%s'" % describe_out
|
||||
return pieces
|
||||
|
||||
# tag
|
||||
|
@ -360,10 +381,12 @@ def git_pieces_from_vcs(
|
|||
if verbose:
|
||||
fmt = "tag '%s' doesn't start with prefix '%s'"
|
||||
print(fmt % (full_tag, tag_prefix))
|
||||
pieces["error"] = ("tag '%s' doesn't start with prefix '%s'"
|
||||
% (full_tag, tag_prefix))
|
||||
pieces["error"] = "tag '%s' doesn't start with prefix '%s'" % (
|
||||
full_tag,
|
||||
tag_prefix,
|
||||
)
|
||||
return pieces
|
||||
pieces["closest-tag"] = full_tag[len(tag_prefix):]
|
||||
pieces["closest-tag"] = full_tag[len(tag_prefix) :]
|
||||
|
||||
# distance: number of commits since tag
|
||||
pieces["distance"] = int(mo.group(2))
|
||||
|
@ -412,8 +435,7 @@ def render_pep440(pieces: Dict[str, Any]) -> str:
|
|||
rendered += ".dirty"
|
||||
else:
|
||||
# exception #1
|
||||
rendered = "0+untagged.%d.g%s" % (pieces["distance"],
|
||||
pieces["short"])
|
||||
rendered = "0+untagged.%d.g%s" % (pieces["distance"], pieces["short"])
|
||||
if pieces["dirty"]:
|
||||
rendered += ".dirty"
|
||||
return rendered
|
||||
|
@ -442,8 +464,7 @@ def render_pep440_branch(pieces: Dict[str, Any]) -> str:
|
|||
rendered = "0"
|
||||
if pieces["branch"] != "master":
|
||||
rendered += ".dev0"
|
||||
rendered += "+untagged.%d.g%s" % (pieces["distance"],
|
||||
pieces["short"])
|
||||
rendered += "+untagged.%d.g%s" % (pieces["distance"], pieces["short"])
|
||||
if pieces["dirty"]:
|
||||
rendered += ".dirty"
|
||||
return rendered
|
||||
|
@ -604,11 +625,13 @@ def render_git_describe_long(pieces: Dict[str, Any]) -> str:
|
|||
def render(pieces: Dict[str, Any], style: str) -> Dict[str, Any]:
|
||||
"""Render the given version pieces into the requested style."""
|
||||
if pieces["error"]:
|
||||
return {"version": "unknown",
|
||||
"full-revisionid": pieces.get("long"),
|
||||
"dirty": None,
|
||||
"error": pieces["error"],
|
||||
"date": None}
|
||||
return {
|
||||
"version": "unknown",
|
||||
"full-revisionid": pieces.get("long"),
|
||||
"dirty": None,
|
||||
"error": pieces["error"],
|
||||
"date": None,
|
||||
}
|
||||
|
||||
if not style or style == "default":
|
||||
style = "pep440" # the default
|
||||
|
@ -632,9 +655,13 @@ def render(pieces: Dict[str, Any], style: str) -> Dict[str, Any]:
|
|||
else:
|
||||
raise ValueError("unknown style '%s'" % style)
|
||||
|
||||
return {"version": rendered, "full-revisionid": pieces["long"],
|
||||
"dirty": pieces["dirty"], "error": None,
|
||||
"date": pieces.get("date")}
|
||||
return {
|
||||
"version": rendered,
|
||||
"full-revisionid": pieces["long"],
|
||||
"dirty": pieces["dirty"],
|
||||
"error": None,
|
||||
"date": pieces.get("date"),
|
||||
}
|
||||
|
||||
|
||||
def get_versions() -> Dict[str, Any]:
|
||||
|
@ -648,8 +675,7 @@ def get_versions() -> Dict[str, Any]:
|
|||
verbose = cfg.verbose
|
||||
|
||||
try:
|
||||
return git_versions_from_keywords(get_keywords(), cfg.tag_prefix,
|
||||
verbose)
|
||||
return git_versions_from_keywords(get_keywords(), cfg.tag_prefix, verbose)
|
||||
except NotThisMethod:
|
||||
pass
|
||||
|
||||
|
@ -658,13 +684,16 @@ def get_versions() -> Dict[str, Any]:
|
|||
# versionfile_source is the relative path from the top of the source
|
||||
# tree (where the .git directory might live) to this file. Invert
|
||||
# this to find the root from __file__.
|
||||
for _ in cfg.versionfile_source.split('/'):
|
||||
for _ in cfg.versionfile_source.split("/"):
|
||||
root = os.path.dirname(root)
|
||||
except NameError:
|
||||
return {"version": "0+unknown", "full-revisionid": None,
|
||||
"dirty": None,
|
||||
"error": "unable to find root of source tree",
|
||||
"date": None}
|
||||
return {
|
||||
"version": "0+unknown",
|
||||
"full-revisionid": None,
|
||||
"dirty": None,
|
||||
"error": "unable to find root of source tree",
|
||||
"date": None,
|
||||
}
|
||||
|
||||
try:
|
||||
pieces = git_pieces_from_vcs(cfg.tag_prefix, root, verbose)
|
||||
|
@ -678,6 +707,10 @@ def get_versions() -> Dict[str, Any]:
|
|||
except NotThisMethod:
|
||||
pass
|
||||
|
||||
return {"version": "0+unknown", "full-revisionid": None,
|
||||
"dirty": None,
|
||||
"error": "unable to compute version", "date": None}
|
||||
return {
|
||||
"version": "0+unknown",
|
||||
"full-revisionid": None,
|
||||
"dirty": None,
|
||||
"error": "unable to compute version",
|
||||
"date": None,
|
||||
}
|
||||
|
|
326
versioneer.py
326
versioneer.py
|
@ -1,4 +1,3 @@
|
|||
|
||||
# Version: 0.29
|
||||
|
||||
"""The Versioneer - like a rocketeer, but for versions.
|
||||
|
@ -310,15 +309,14 @@ https://img.shields.io/travis/com/python-versioneer/python-versioneer.svg
|
|||
|
||||
import configparser
|
||||
import errno
|
||||
import functools
|
||||
import json
|
||||
import os
|
||||
import re
|
||||
import subprocess
|
||||
import sys
|
||||
from pathlib import Path
|
||||
from typing import Any, Callable, cast, Dict, List, Optional, Tuple, Union
|
||||
from typing import NoReturn
|
||||
import functools
|
||||
from typing import Any, Callable, Dict, List, NoReturn, Optional, Tuple, Union, cast
|
||||
|
||||
have_tomllib = True
|
||||
if sys.version_info >= (3, 11):
|
||||
|
@ -367,11 +365,13 @@ def get_root() -> str:
|
|||
or os.path.exists(pyproject_toml)
|
||||
or os.path.exists(versioneer_py)
|
||||
):
|
||||
err = ("Versioneer was unable to run the project root directory. "
|
||||
"Versioneer requires setup.py to be executed from "
|
||||
"its immediate directory (like 'python setup.py COMMAND'), "
|
||||
"or in a way that lets it use sys.argv[0] to find the root "
|
||||
"(like 'python path/to/setup.py COMMAND').")
|
||||
err = (
|
||||
"Versioneer was unable to run the project root directory. "
|
||||
"Versioneer requires setup.py to be executed from "
|
||||
"its immediate directory (like 'python setup.py COMMAND'), "
|
||||
"or in a way that lets it use sys.argv[0] to find the root "
|
||||
"(like 'python path/to/setup.py COMMAND')."
|
||||
)
|
||||
raise VersioneerBadRootError(err)
|
||||
try:
|
||||
# Certain runtime workflows (setup.py install/develop in a setuptools
|
||||
|
@ -384,8 +384,10 @@ def get_root() -> str:
|
|||
me_dir = os.path.normcase(os.path.splitext(my_path)[0])
|
||||
vsr_dir = os.path.normcase(os.path.splitext(versioneer_py)[0])
|
||||
if me_dir != vsr_dir and "VERSIONEER_PEP518" not in globals():
|
||||
print("Warning: build in %s is using versioneer.py from %s"
|
||||
% (os.path.dirname(my_path), versioneer_py))
|
||||
print(
|
||||
"Warning: build in %s is using versioneer.py from %s"
|
||||
% (os.path.dirname(my_path), versioneer_py)
|
||||
)
|
||||
except NameError:
|
||||
pass
|
||||
return root
|
||||
|
@ -403,9 +405,9 @@ def get_config_from_root(root: str) -> VersioneerConfig:
|
|||
section: Union[Dict[str, Any], configparser.SectionProxy, None] = None
|
||||
if pyproject_toml.exists() and have_tomllib:
|
||||
try:
|
||||
with open(pyproject_toml, 'rb') as fobj:
|
||||
with open(pyproject_toml, "rb") as fobj:
|
||||
pp = tomllib.load(fobj)
|
||||
section = pp['tool']['versioneer']
|
||||
section = pp["tool"]["versioneer"]
|
||||
except (tomllib.TOMLDecodeError, KeyError) as e:
|
||||
print(f"Failed to load config from {pyproject_toml}: {e}")
|
||||
print("Try to load it from setup.cfg")
|
||||
|
@ -422,7 +424,7 @@ def get_config_from_root(root: str) -> VersioneerConfig:
|
|||
# `None` values elsewhere where it matters
|
||||
|
||||
cfg = VersioneerConfig()
|
||||
cfg.VCS = section['VCS']
|
||||
cfg.VCS = section["VCS"]
|
||||
cfg.style = section.get("style", "")
|
||||
cfg.versionfile_source = cast(str, section.get("versionfile_source"))
|
||||
cfg.versionfile_build = section.get("versionfile_build")
|
||||
|
@ -450,10 +452,12 @@ HANDLERS: Dict[str, Dict[str, Callable]] = {}
|
|||
|
||||
def register_vcs_handler(vcs: str, method: str) -> Callable: # decorator
|
||||
"""Create decorator to mark a method as the handler of a VCS."""
|
||||
|
||||
def decorate(f: Callable) -> Callable:
|
||||
"""Store f in HANDLERS[vcs][method]."""
|
||||
HANDLERS.setdefault(vcs, {})[method] = f
|
||||
return f
|
||||
|
||||
return decorate
|
||||
|
||||
|
||||
|
@ -480,10 +484,14 @@ def run_command(
|
|||
try:
|
||||
dispcmd = str([command] + args)
|
||||
# remember shell=False, so use git.cmd on windows, not just git
|
||||
process = subprocess.Popen([command] + args, cwd=cwd, env=env,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=(subprocess.PIPE if hide_stderr
|
||||
else None), **popen_kwargs)
|
||||
process = subprocess.Popen(
|
||||
[command] + args,
|
||||
cwd=cwd,
|
||||
env=env,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=(subprocess.PIPE if hide_stderr else None),
|
||||
**popen_kwargs,
|
||||
)
|
||||
break
|
||||
except OSError as e:
|
||||
if e.errno == errno.ENOENT:
|
||||
|
@ -494,7 +502,7 @@ def run_command(
|
|||
return None, None
|
||||
else:
|
||||
if verbose:
|
||||
print("unable to find command, tried %s" % (commands,))
|
||||
print("unable to find command, tried {}".format(commands))
|
||||
return None, None
|
||||
stdout = process.communicate()[0].strip().decode()
|
||||
if process.returncode != 0:
|
||||
|
@ -505,7 +513,9 @@ def run_command(
|
|||
return stdout, process.returncode
|
||||
|
||||
|
||||
LONG_VERSION_PY['git'] = r'''
|
||||
LONG_VERSION_PY[
|
||||
"git"
|
||||
] = r'''
|
||||
# This file helps to compute a version number in source trees obtained from
|
||||
# git-archive tarball (such as those provided by githubs download-from-tag
|
||||
# feature). Distribution tarballs (built by setup.py sdist) and build
|
||||
|
@ -1200,7 +1210,7 @@ def git_get_keywords(versionfile_abs: str) -> Dict[str, str]:
|
|||
# _version.py.
|
||||
keywords: Dict[str, str] = {}
|
||||
try:
|
||||
with open(versionfile_abs, "r") as fobj:
|
||||
with open(versionfile_abs) as fobj:
|
||||
for line in fobj:
|
||||
if line.strip().startswith("git_refnames ="):
|
||||
mo = re.search(r'=\s*"(.*)"', line)
|
||||
|
@ -1250,7 +1260,7 @@ def git_versions_from_keywords(
|
|||
# starting in git-1.8.3, tags are listed as "tag: foo-1.0" instead of
|
||||
# just "foo-1.0". If we see a "tag: " prefix, prefer those.
|
||||
TAG = "tag: "
|
||||
tags = {r[len(TAG):] for r in refs if r.startswith(TAG)}
|
||||
tags = {r[len(TAG) :] for r in refs if r.startswith(TAG)}
|
||||
if not tags:
|
||||
# Either we're using git < 1.8.3, or there really are no tags. We use
|
||||
# a heuristic: assume all version tags have a digit. The old git %d
|
||||
|
@ -1259,7 +1269,7 @@ def git_versions_from_keywords(
|
|||
# between branches and tags. By ignoring refnames without digits, we
|
||||
# filter out many common branch names like "release" and
|
||||
# "stabilization", as well as "HEAD" and "master".
|
||||
tags = {r for r in refs if re.search(r'\d', r)}
|
||||
tags = {r for r in refs if re.search(r"\d", r)}
|
||||
if verbose:
|
||||
print("discarding '%s', no digits" % ",".join(refs - tags))
|
||||
if verbose:
|
||||
|
@ -1267,32 +1277,36 @@ def git_versions_from_keywords(
|
|||
for ref in sorted(tags):
|
||||
# sorting will prefer e.g. "2.0" over "2.0rc1"
|
||||
if ref.startswith(tag_prefix):
|
||||
r = ref[len(tag_prefix):]
|
||||
r = ref[len(tag_prefix) :]
|
||||
# Filter out refs that exactly match prefix or that don't start
|
||||
# with a number once the prefix is stripped (mostly a concern
|
||||
# when prefix is '')
|
||||
if not re.match(r'\d', r):
|
||||
if not re.match(r"\d", r):
|
||||
continue
|
||||
if verbose:
|
||||
print("picking %s" % r)
|
||||
return {"version": r,
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False, "error": None,
|
||||
"date": date}
|
||||
return {
|
||||
"version": r,
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False,
|
||||
"error": None,
|
||||
"date": date,
|
||||
}
|
||||
# no suitable tags, so version is "0+unknown", but full hex is still there
|
||||
if verbose:
|
||||
print("no suitable tags, using unknown + full revision id")
|
||||
return {"version": "0+unknown",
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False, "error": "no suitable tags", "date": None}
|
||||
return {
|
||||
"version": "0+unknown",
|
||||
"full-revisionid": keywords["full"].strip(),
|
||||
"dirty": False,
|
||||
"error": "no suitable tags",
|
||||
"date": None,
|
||||
}
|
||||
|
||||
|
||||
@register_vcs_handler("git", "pieces_from_vcs")
|
||||
def git_pieces_from_vcs(
|
||||
tag_prefix: str,
|
||||
root: str,
|
||||
verbose: bool,
|
||||
runner: Callable = run_command
|
||||
tag_prefix: str, root: str, verbose: bool, runner: Callable = run_command
|
||||
) -> Dict[str, Any]:
|
||||
"""Get version from 'git describe' in the root of the source tree.
|
||||
|
||||
|
@ -1311,8 +1325,7 @@ def git_pieces_from_vcs(
|
|||
env.pop("GIT_DIR", None)
|
||||
runner = functools.partial(runner, env=env)
|
||||
|
||||
_, rc = runner(GITS, ["rev-parse", "--git-dir"], cwd=root,
|
||||
hide_stderr=not verbose)
|
||||
_, rc = runner(GITS, ["rev-parse", "--git-dir"], cwd=root, hide_stderr=not verbose)
|
||||
if rc != 0:
|
||||
if verbose:
|
||||
print("Directory %s not under git control" % root)
|
||||
|
@ -1320,10 +1333,19 @@ def git_pieces_from_vcs(
|
|||
|
||||
# if there is a tag matching tag_prefix, this yields TAG-NUM-gHEX[-dirty]
|
||||
# if there isn't one, this yields HEX[-dirty] (no NUM)
|
||||
describe_out, rc = runner(GITS, [
|
||||
"describe", "--tags", "--dirty", "--always", "--long",
|
||||
"--match", f"{tag_prefix}[[:digit:]]*"
|
||||
], cwd=root)
|
||||
describe_out, rc = runner(
|
||||
GITS,
|
||||
[
|
||||
"describe",
|
||||
"--tags",
|
||||
"--dirty",
|
||||
"--always",
|
||||
"--long",
|
||||
"--match",
|
||||
f"{tag_prefix}[[:digit:]]*",
|
||||
],
|
||||
cwd=root,
|
||||
)
|
||||
# --long was added in git-1.5.5
|
||||
if describe_out is None:
|
||||
raise NotThisMethod("'git describe' failed")
|
||||
|
@ -1338,8 +1360,7 @@ def git_pieces_from_vcs(
|
|||
pieces["short"] = full_out[:7] # maybe improved later
|
||||
pieces["error"] = None
|
||||
|
||||
branch_name, rc = runner(GITS, ["rev-parse", "--abbrev-ref", "HEAD"],
|
||||
cwd=root)
|
||||
branch_name, rc = runner(GITS, ["rev-parse", "--abbrev-ref", "HEAD"], cwd=root)
|
||||
# --abbrev-ref was added in git-1.6.3
|
||||
if rc != 0 or branch_name is None:
|
||||
raise NotThisMethod("'git rev-parse --abbrev-ref' returned error")
|
||||
|
@ -1379,17 +1400,16 @@ def git_pieces_from_vcs(
|
|||
dirty = git_describe.endswith("-dirty")
|
||||
pieces["dirty"] = dirty
|
||||
if dirty:
|
||||
git_describe = git_describe[:git_describe.rindex("-dirty")]
|
||||
git_describe = git_describe[: git_describe.rindex("-dirty")]
|
||||
|
||||
# now we have TAG-NUM-gHEX or HEX
|
||||
|
||||
if "-" in git_describe:
|
||||
# TAG-NUM-gHEX
|
||||
mo = re.search(r'^(.+)-(\d+)-g([0-9a-f]+)$', git_describe)
|
||||
mo = re.search(r"^(.+)-(\d+)-g([0-9a-f]+)$", git_describe)
|
||||
if not mo:
|
||||
# unparsable. Maybe git-describe is misbehaving?
|
||||
pieces["error"] = ("unable to parse git-describe output: '%s'"
|
||||
% describe_out)
|
||||
pieces["error"] = "unable to parse git-describe output: '%s'" % describe_out
|
||||
return pieces
|
||||
|
||||
# tag
|
||||
|
@ -1398,10 +1418,12 @@ def git_pieces_from_vcs(
|
|||
if verbose:
|
||||
fmt = "tag '%s' doesn't start with prefix '%s'"
|
||||
print(fmt % (full_tag, tag_prefix))
|
||||
pieces["error"] = ("tag '%s' doesn't start with prefix '%s'"
|
||||
% (full_tag, tag_prefix))
|
||||
pieces["error"] = "tag '%s' doesn't start with prefix '%s'" % (
|
||||
full_tag,
|
||||
tag_prefix,
|
||||
)
|
||||
return pieces
|
||||
pieces["closest-tag"] = full_tag[len(tag_prefix):]
|
||||
pieces["closest-tag"] = full_tag[len(tag_prefix) :]
|
||||
|
||||
# distance: number of commits since tag
|
||||
pieces["distance"] = int(mo.group(2))
|
||||
|
@ -1448,7 +1470,7 @@ def do_vcs_install(versionfile_source: str, ipy: Optional[str]) -> None:
|
|||
files.append(versioneer_file)
|
||||
present = False
|
||||
try:
|
||||
with open(".gitattributes", "r") as fobj:
|
||||
with open(".gitattributes") as fobj:
|
||||
for line in fobj:
|
||||
if line.strip().startswith(versionfile_source):
|
||||
if "export-subst" in line.strip().split()[1:]:
|
||||
|
@ -1479,15 +1501,21 @@ def versions_from_parentdir(
|
|||
for _ in range(3):
|
||||
dirname = os.path.basename(root)
|
||||
if dirname.startswith(parentdir_prefix):
|
||||
return {"version": dirname[len(parentdir_prefix):],
|
||||
"full-revisionid": None,
|
||||
"dirty": False, "error": None, "date": None}
|
||||
return {
|
||||
"version": dirname[len(parentdir_prefix) :],
|
||||
"full-revisionid": None,
|
||||
"dirty": False,
|
||||
"error": None,
|
||||
"date": None,
|
||||
}
|
||||
rootdirs.append(root)
|
||||
root = os.path.dirname(root) # up a level
|
||||
|
||||
if verbose:
|
||||
print("Tried directories %s but none started with prefix %s" %
|
||||
(str(rootdirs), parentdir_prefix))
|
||||
print(
|
||||
"Tried directories %s but none started with prefix %s"
|
||||
% (str(rootdirs), parentdir_prefix)
|
||||
)
|
||||
raise NotThisMethod("rootdir doesn't start with parentdir_prefix")
|
||||
|
||||
|
||||
|
@ -1516,11 +1544,13 @@ def versions_from_file(filename: str) -> Dict[str, Any]:
|
|||
contents = f.read()
|
||||
except OSError:
|
||||
raise NotThisMethod("unable to read _version.py")
|
||||
mo = re.search(r"version_json = '''\n(.*)''' # END VERSION_JSON",
|
||||
contents, re.M | re.S)
|
||||
mo = re.search(
|
||||
r"version_json = '''\n(.*)''' # END VERSION_JSON", contents, re.M | re.S
|
||||
)
|
||||
if not mo:
|
||||
mo = re.search(r"version_json = '''\r\n(.*)''' # END VERSION_JSON",
|
||||
contents, re.M | re.S)
|
||||
mo = re.search(
|
||||
r"version_json = '''\r\n(.*)''' # END VERSION_JSON", contents, re.M | re.S
|
||||
)
|
||||
if not mo:
|
||||
raise NotThisMethod("no version_json in _version.py")
|
||||
return json.loads(mo.group(1))
|
||||
|
@ -1528,12 +1558,11 @@ def versions_from_file(filename: str) -> Dict[str, Any]:
|
|||
|
||||
def write_to_version_file(filename: str, versions: Dict[str, Any]) -> None:
|
||||
"""Write the given version number to the given _version.py file."""
|
||||
contents = json.dumps(versions, sort_keys=True,
|
||||
indent=1, separators=(",", ": "))
|
||||
contents = json.dumps(versions, sort_keys=True, indent=1, separators=(",", ": "))
|
||||
with open(filename, "w") as f:
|
||||
f.write(SHORT_VERSION_PY % contents)
|
||||
|
||||
print("set %s to '%s'" % (filename, versions["version"]))
|
||||
print("set {} to '{}'".format(filename, versions["version"]))
|
||||
|
||||
|
||||
def plus_or_dot(pieces: Dict[str, Any]) -> str:
|
||||
|
@ -1561,8 +1590,7 @@ def render_pep440(pieces: Dict[str, Any]) -> str:
|
|||
rendered += ".dirty"
|
||||
else:
|
||||
# exception #1
|
||||
rendered = "0+untagged.%d.g%s" % (pieces["distance"],
|
||||
pieces["short"])
|
||||
rendered = "0+untagged.%d.g%s" % (pieces["distance"], pieces["short"])
|
||||
if pieces["dirty"]:
|
||||
rendered += ".dirty"
|
||||
return rendered
|
||||
|
@ -1591,8 +1619,7 @@ def render_pep440_branch(pieces: Dict[str, Any]) -> str:
|
|||
rendered = "0"
|
||||
if pieces["branch"] != "master":
|
||||
rendered += ".dev0"
|
||||
rendered += "+untagged.%d.g%s" % (pieces["distance"],
|
||||
pieces["short"])
|
||||
rendered += "+untagged.%d.g%s" % (pieces["distance"], pieces["short"])
|
||||
if pieces["dirty"]:
|
||||
rendered += ".dirty"
|
||||
return rendered
|
||||
|
@ -1753,11 +1780,13 @@ def render_git_describe_long(pieces: Dict[str, Any]) -> str:
|
|||
def render(pieces: Dict[str, Any], style: str) -> Dict[str, Any]:
|
||||
"""Render the given version pieces into the requested style."""
|
||||
if pieces["error"]:
|
||||
return {"version": "unknown",
|
||||
"full-revisionid": pieces.get("long"),
|
||||
"dirty": None,
|
||||
"error": pieces["error"],
|
||||
"date": None}
|
||||
return {
|
||||
"version": "unknown",
|
||||
"full-revisionid": pieces.get("long"),
|
||||
"dirty": None,
|
||||
"error": pieces["error"],
|
||||
"date": None,
|
||||
}
|
||||
|
||||
if not style or style == "default":
|
||||
style = "pep440" # the default
|
||||
|
@ -1781,9 +1810,13 @@ def render(pieces: Dict[str, Any], style: str) -> Dict[str, Any]:
|
|||
else:
|
||||
raise ValueError("unknown style '%s'" % style)
|
||||
|
||||
return {"version": rendered, "full-revisionid": pieces["long"],
|
||||
"dirty": pieces["dirty"], "error": None,
|
||||
"date": pieces.get("date")}
|
||||
return {
|
||||
"version": rendered,
|
||||
"full-revisionid": pieces["long"],
|
||||
"dirty": pieces["dirty"],
|
||||
"error": None,
|
||||
"date": pieces.get("date"),
|
||||
}
|
||||
|
||||
|
||||
class VersioneerBadRootError(Exception):
|
||||
|
@ -1806,8 +1839,9 @@ def get_versions(verbose: bool = False) -> Dict[str, Any]:
|
|||
handlers = HANDLERS.get(cfg.VCS)
|
||||
assert handlers, "unrecognized VCS '%s'" % cfg.VCS
|
||||
verbose = verbose or bool(cfg.verbose) # `bool()` used to avoid `None`
|
||||
assert cfg.versionfile_source is not None, \
|
||||
"please set versioneer.versionfile_source"
|
||||
assert (
|
||||
cfg.versionfile_source is not None
|
||||
), "please set versioneer.versionfile_source"
|
||||
assert cfg.tag_prefix is not None, "please set versioneer.tag_prefix"
|
||||
|
||||
versionfile_abs = os.path.join(root, cfg.versionfile_source)
|
||||
|
@ -1833,7 +1867,7 @@ def get_versions(verbose: bool = False) -> Dict[str, Any]:
|
|||
try:
|
||||
ver = versions_from_file(versionfile_abs)
|
||||
if verbose:
|
||||
print("got version from file %s %s" % (versionfile_abs, ver))
|
||||
print("got version from file {} {}".format(versionfile_abs, ver))
|
||||
return ver
|
||||
except NotThisMethod:
|
||||
pass
|
||||
|
@ -1861,9 +1895,13 @@ def get_versions(verbose: bool = False) -> Dict[str, Any]:
|
|||
if verbose:
|
||||
print("unable to compute version")
|
||||
|
||||
return {"version": "0+unknown", "full-revisionid": None,
|
||||
"dirty": None, "error": "unable to compute version",
|
||||
"date": None}
|
||||
return {
|
||||
"version": "0+unknown",
|
||||
"full-revisionid": None,
|
||||
"dirty": None,
|
||||
"error": "unable to compute version",
|
||||
"date": None,
|
||||
}
|
||||
|
||||
|
||||
def get_version() -> str:
|
||||
|
@ -1916,6 +1954,7 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
print(" date: %s" % vers.get("date"))
|
||||
if vers["error"]:
|
||||
print(" error: %s" % vers["error"])
|
||||
|
||||
cmds["version"] = cmd_version
|
||||
|
||||
# we override "build_py" in setuptools
|
||||
|
@ -1937,8 +1976,8 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
# but the build_py command is not expected to copy any files.
|
||||
|
||||
# we override different "build_py" commands for both environments
|
||||
if 'build_py' in cmds:
|
||||
_build_py: Any = cmds['build_py']
|
||||
if "build_py" in cmds:
|
||||
_build_py: Any = cmds["build_py"]
|
||||
else:
|
||||
from setuptools.command.build_py import build_py as _build_py
|
||||
|
||||
|
@ -1955,14 +1994,14 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
# now locate _version.py in the new build/ directory and replace
|
||||
# it with an updated value
|
||||
if cfg.versionfile_build:
|
||||
target_versionfile = os.path.join(self.build_lib,
|
||||
cfg.versionfile_build)
|
||||
target_versionfile = os.path.join(self.build_lib, cfg.versionfile_build)
|
||||
print("UPDATING %s" % target_versionfile)
|
||||
write_to_version_file(target_versionfile, versions)
|
||||
|
||||
cmds["build_py"] = cmd_build_py
|
||||
|
||||
if 'build_ext' in cmds:
|
||||
_build_ext: Any = cmds['build_ext']
|
||||
if "build_ext" in cmds:
|
||||
_build_ext: Any = cmds["build_ext"]
|
||||
else:
|
||||
from setuptools.command.build_ext import build_ext as _build_ext
|
||||
|
||||
|
@ -1982,19 +2021,22 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
# it with an updated value
|
||||
if not cfg.versionfile_build:
|
||||
return
|
||||
target_versionfile = os.path.join(self.build_lib,
|
||||
cfg.versionfile_build)
|
||||
target_versionfile = os.path.join(self.build_lib, cfg.versionfile_build)
|
||||
if not os.path.exists(target_versionfile):
|
||||
print(f"Warning: {target_versionfile} does not exist, skipping "
|
||||
"version update. This can happen if you are running build_ext "
|
||||
"without first running build_py.")
|
||||
print(
|
||||
f"Warning: {target_versionfile} does not exist, skipping "
|
||||
"version update. This can happen if you are running build_ext "
|
||||
"without first running build_py."
|
||||
)
|
||||
return
|
||||
print("UPDATING %s" % target_versionfile)
|
||||
write_to_version_file(target_versionfile, versions)
|
||||
|
||||
cmds["build_ext"] = cmd_build_ext
|
||||
|
||||
if "cx_Freeze" in sys.modules: # cx_freeze enabled?
|
||||
from cx_Freeze.dist import build_exe as _build_exe # type: ignore
|
||||
|
||||
# nczeczulin reports that py2exe won't like the pep440-style string
|
||||
# as FILEVERSION, but it can be used for PRODUCTVERSION, e.g.
|
||||
# setup(console=[{
|
||||
|
@ -2015,17 +2057,21 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
os.unlink(target_versionfile)
|
||||
with open(cfg.versionfile_source, "w") as f:
|
||||
LONG = LONG_VERSION_PY[cfg.VCS]
|
||||
f.write(LONG %
|
||||
{"DOLLAR": "$",
|
||||
"STYLE": cfg.style,
|
||||
"TAG_PREFIX": cfg.tag_prefix,
|
||||
"PARENTDIR_PREFIX": cfg.parentdir_prefix,
|
||||
"VERSIONFILE_SOURCE": cfg.versionfile_source,
|
||||
})
|
||||
f.write(
|
||||
LONG
|
||||
% {
|
||||
"DOLLAR": "$",
|
||||
"STYLE": cfg.style,
|
||||
"TAG_PREFIX": cfg.tag_prefix,
|
||||
"PARENTDIR_PREFIX": cfg.parentdir_prefix,
|
||||
"VERSIONFILE_SOURCE": cfg.versionfile_source,
|
||||
}
|
||||
)
|
||||
|
||||
cmds["build_exe"] = cmd_build_exe
|
||||
del cmds["build_py"]
|
||||
|
||||
if 'py2exe' in sys.modules: # py2exe enabled?
|
||||
if "py2exe" in sys.modules: # py2exe enabled?
|
||||
try:
|
||||
from py2exe.setuptools_buildexe import py2exe as _py2exe # type: ignore
|
||||
except ImportError:
|
||||
|
@ -2044,18 +2090,22 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
os.unlink(target_versionfile)
|
||||
with open(cfg.versionfile_source, "w") as f:
|
||||
LONG = LONG_VERSION_PY[cfg.VCS]
|
||||
f.write(LONG %
|
||||
{"DOLLAR": "$",
|
||||
"STYLE": cfg.style,
|
||||
"TAG_PREFIX": cfg.tag_prefix,
|
||||
"PARENTDIR_PREFIX": cfg.parentdir_prefix,
|
||||
"VERSIONFILE_SOURCE": cfg.versionfile_source,
|
||||
})
|
||||
f.write(
|
||||
LONG
|
||||
% {
|
||||
"DOLLAR": "$",
|
||||
"STYLE": cfg.style,
|
||||
"TAG_PREFIX": cfg.tag_prefix,
|
||||
"PARENTDIR_PREFIX": cfg.parentdir_prefix,
|
||||
"VERSIONFILE_SOURCE": cfg.versionfile_source,
|
||||
}
|
||||
)
|
||||
|
||||
cmds["py2exe"] = cmd_py2exe
|
||||
|
||||
# sdist farms its file list building out to egg_info
|
||||
if 'egg_info' in cmds:
|
||||
_egg_info: Any = cmds['egg_info']
|
||||
if "egg_info" in cmds:
|
||||
_egg_info: Any = cmds["egg_info"]
|
||||
else:
|
||||
from setuptools.command.egg_info import egg_info as _egg_info
|
||||
|
||||
|
@ -2068,7 +2118,7 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
# Modify the filelist and normalize it
|
||||
root = get_root()
|
||||
cfg = get_config_from_root(root)
|
||||
self.filelist.append('versioneer.py')
|
||||
self.filelist.append("versioneer.py")
|
||||
if cfg.versionfile_source:
|
||||
# There are rare cases where versionfile_source might not be
|
||||
# included by default, so we must be explicit
|
||||
|
@ -2081,18 +2131,21 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
# We will instead replicate their final normalization (to unicode,
|
||||
# and POSIX-style paths)
|
||||
from setuptools import unicode_utils
|
||||
normalized = [unicode_utils.filesys_decode(f).replace(os.sep, '/')
|
||||
for f in self.filelist.files]
|
||||
|
||||
manifest_filename = os.path.join(self.egg_info, 'SOURCES.txt')
|
||||
with open(manifest_filename, 'w') as fobj:
|
||||
fobj.write('\n'.join(normalized))
|
||||
normalized = [
|
||||
unicode_utils.filesys_decode(f).replace(os.sep, "/")
|
||||
for f in self.filelist.files
|
||||
]
|
||||
|
||||
cmds['egg_info'] = cmd_egg_info
|
||||
manifest_filename = os.path.join(self.egg_info, "SOURCES.txt")
|
||||
with open(manifest_filename, "w") as fobj:
|
||||
fobj.write("\n".join(normalized))
|
||||
|
||||
cmds["egg_info"] = cmd_egg_info
|
||||
|
||||
# we override different "sdist" commands for both environments
|
||||
if 'sdist' in cmds:
|
||||
_sdist: Any = cmds['sdist']
|
||||
if "sdist" in cmds:
|
||||
_sdist: Any = cmds["sdist"]
|
||||
else:
|
||||
from setuptools.command.sdist import sdist as _sdist
|
||||
|
||||
|
@ -2114,8 +2167,10 @@ def get_cmdclass(cmdclass: Optional[Dict[str, Any]] = None):
|
|||
# updated value
|
||||
target_versionfile = os.path.join(base_dir, cfg.versionfile_source)
|
||||
print("UPDATING %s" % target_versionfile)
|
||||
write_to_version_file(target_versionfile,
|
||||
self._versioneer_generated_versions)
|
||||
write_to_version_file(
|
||||
target_versionfile, self._versioneer_generated_versions
|
||||
)
|
||||
|
||||
cmds["sdist"] = cmd_sdist
|
||||
|
||||
return cmds
|
||||
|
@ -2175,11 +2230,9 @@ def do_setup() -> int:
|
|||
root = get_root()
|
||||
try:
|
||||
cfg = get_config_from_root(root)
|
||||
except (OSError, configparser.NoSectionError,
|
||||
configparser.NoOptionError) as e:
|
||||
except (OSError, configparser.NoSectionError, configparser.NoOptionError) as e:
|
||||
if isinstance(e, (OSError, configparser.NoSectionError)):
|
||||
print("Adding sample versioneer config to setup.cfg",
|
||||
file=sys.stderr)
|
||||
print("Adding sample versioneer config to setup.cfg", file=sys.stderr)
|
||||
with open(os.path.join(root, "setup.cfg"), "a") as f:
|
||||
f.write(SAMPLE_CONFIG)
|
||||
print(CONFIG_ERROR, file=sys.stderr)
|
||||
|
@ -2188,19 +2241,22 @@ def do_setup() -> int:
|
|||
print(" creating %s" % cfg.versionfile_source)
|
||||
with open(cfg.versionfile_source, "w") as f:
|
||||
LONG = LONG_VERSION_PY[cfg.VCS]
|
||||
f.write(LONG % {"DOLLAR": "$",
|
||||
"STYLE": cfg.style,
|
||||
"TAG_PREFIX": cfg.tag_prefix,
|
||||
"PARENTDIR_PREFIX": cfg.parentdir_prefix,
|
||||
"VERSIONFILE_SOURCE": cfg.versionfile_source,
|
||||
})
|
||||
f.write(
|
||||
LONG
|
||||
% {
|
||||
"DOLLAR": "$",
|
||||
"STYLE": cfg.style,
|
||||
"TAG_PREFIX": cfg.tag_prefix,
|
||||
"PARENTDIR_PREFIX": cfg.parentdir_prefix,
|
||||
"VERSIONFILE_SOURCE": cfg.versionfile_source,
|
||||
}
|
||||
)
|
||||
|
||||
ipy = os.path.join(os.path.dirname(cfg.versionfile_source),
|
||||
"__init__.py")
|
||||
ipy = os.path.join(os.path.dirname(cfg.versionfile_source), "__init__.py")
|
||||
maybe_ipy: Optional[str] = ipy
|
||||
if os.path.exists(ipy):
|
||||
try:
|
||||
with open(ipy, "r") as f:
|
||||
with open(ipy) as f:
|
||||
old = f.read()
|
||||
except OSError:
|
||||
old = ""
|
||||
|
@ -2232,7 +2288,7 @@ def scan_setup_py() -> int:
|
|||
found = set()
|
||||
setters = False
|
||||
errors = 0
|
||||
with open("setup.py", "r") as f:
|
||||
with open("setup.py") as f:
|
||||
for line in f.readlines():
|
||||
if "import versioneer" in line:
|
||||
found.add("import")
|
||||
|
|
Ładowanie…
Reference in New Issue