From 7b436ac627951e18ad10a392a63efb909cc03214 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Filipe=20La=C3=ADns?= Date: Tue, 8 Nov 2022 23:02:01 +0000 Subject: [PATCH] tags: add interpreter_abi MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Filipe LaĆ­ns --- packaging/tags.py | 6 ++++++ tests/test_tags.py | 13 +++++++++++++ 2 files changed, 19 insertions(+) diff --git a/packaging/tags.py b/packaging/tags.py index a0e1ea23..99aba79c 100644 --- a/packaging/tags.py +++ b/packaging/tags.py @@ -484,6 +484,12 @@ def _version_nodot(version: PythonVersion) -> str: return "".join(map(str, version)) +def interpreter_abi() -> str: + if interpreter_name() == "cp": + return _cpython_abis(sys.version_info[:2])[0] + return next(_generic_abi()) + + def sys_tags(*, warn: bool = False) -> Iterator[Tag]: """ Returns the sequence of tag triples for the running interpreter. diff --git a/tests/test_tags.py b/tests/test_tags.py index 39515e8d..03092d1e 100644 --- a/tests/test_tags.py +++ b/tests/test_tags.py @@ -1239,3 +1239,16 @@ def test_cpython_first_none_any_tag(self, monkeypatch): interpreter = f"cp{tags.interpreter_version()}" assert tag == tags.Tag(interpreter, "none", "any") + + +def test_interpreter_abi(monkeypatch): + monkeypatch.setattr(tags, "interpreter_name", lambda: "pp") + monkeypatch.setattr( + sysconfig, "get_config_var", {"SOABI": "pypy39-pp73"}.__getitem__ + ) + assert tags.interpreter_abi() == "pypy39_pp73" + + config = {"Py_DEBUG": 0, "WITH_PYMALLOC": 0, "Py_UNICODE_SIZE": 2} + monkeypatch.setattr(sysconfig, "get_config_var", config.__getitem__) + monkeypatch.setattr(tags, "interpreter_name", lambda: "cp") + assert tags.interpreter_abi() == "cp310"