如果主版本为0,则没有预发布标记

2024-05-16 01:59:18 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在使用bump2version进行语义版本控制。如果主要verison为0(即快速开发),是否有办法防止标签的预发布组件出现。目前,我的.bumpversion.cfg

[bumpversion]
current_version = 0.0.0
tag = False
tag_name = {new_version}
commit = True
parse =
    (?P<major>\d+)
    \.
    (?P<minor>\d+)
    \.
    (?P<patch>\d+)
    (\-(?P<pre>[a-z]+)\.(?P<prenum>\d+))?
serialize =
    {major}.{minor}.{patch}-{pre}.{prenum}
    {major}.{minor}.{patch}

[bumpversion:part:pre]
optional_value = placeholder
first_value = alpha
values =
    alpha
    beta
    rc
    placeholder

[bumpversion:part:prenum]
first_value = 1

[bumpversion:file:pyproject.toml]

当我碰撞零件minor时,它会添加预释放值

>>> bumpversion minor
Bumpversion: 0.0.0 -> 0.1.0-alpha.1

我不希望标签的-alpha.N-beta.N等部分在我处于主版本0时出现(即快速开发;在主版本1及更高版本之前,不会对我进行发布前测试)

我确实希望在从主要版本{}到{}或{}到{}的所有{}中使用预发布部分(因为预发布测试将在这些阶段进行),而不是快速开发。我不喜欢在快速开发时为每个bump手动键入--new-version(特别是因为在1.0.0之前我会有很多版本)

有人有解决办法吗


Tags: 版本alphanewvalueversiontag标签pre
1条回答
网友
1楼 · 发布于 2024-05-16 01:59:18

作为一个“猴子补丁”/解决方法,在bumpversion.version_part中,我从

def _choose_serialize_format(self, version, context):

        chosen = None

        logger.debug(
            "Available serialization formats: '%s'", "', '".join(self.serialize_formats)
        )

        for serialize_format in self.serialize_formats:
            try:
                self._serialize(
                    version, serialize_format, context, raise_if_incomplete=True
                )
                chosen = serialize_format
                logger.debug("Found '%s' to be a usable serialization format", chosen)
            except IncompleteVersionRepresentationException as e:
                if not chosen:
                    chosen = serialize_format
            except MissingValueForSerializationException as e:
                logger.info(e.message)
                raise e

        if not chosen:
            raise KeyError("Did not find suitable serialization format")

        logger.debug("Selected serialization format '%s'", chosen)

        return chosen

def _choose_serialize_format(self, version, context):

        chosen = None

        logger.debug(
            "Available serialization formats: '%s'", "', '".join(self.serialize_formats)
        )

        if version._values["major"].value == "0":
            _serialize_formats = [
                self.serialize_formats[-1],
            ]
        else:
            _serialize_formats = self.serialize_formats

        for serialize_format in _serialize_formats:
            try:
                self._serialize(
                    version, serialize_format, context, raise_if_incomplete=True
                )
                chosen = serialize_format
                logger.debug("Found '%s' to be a usable serialization format", chosen)
            except IncompleteVersionRepresentationException as e:
                if not chosen:
                    chosen = serialize_format
            except MissingValueForSerializationException as e:
                logger.info(e.message)
                raise e

        if not chosen:
            raise KeyError("Did not find suitable serialization format")

        logger.debug("Selected serialization format '%s'", chosen)

        return chosen

添加的行是

if version._values["major"].value == "0":
    _serialize_formats = [
        self.serialize_formats[-1],
    ]
else:
    _serialize_formats = self.serialize_formats

线路也变了

for serialize_format in self.serialize_formats:

for serialize_format in _serialize_formats:

相关问题 更多 >