File support-python314.patch of Package python-pip-api

Index: pip_api-0.0.34/pip_api/_parse_requirements.py
===================================================================
--- pip_api-0.0.34.orig/pip_api/_parse_requirements.py
+++ pip_api-0.0.34/pip_api/_parse_requirements.py
@@ -276,7 +276,7 @@ def _parse_local_package_name(path):
             and expr.value.func.id == "setup"
         ][0]
         value = [kw.value for kw in setup_kwargs if kw.arg == "name"][0]
-        return value.s
+        return getattr(value, 's', None) if hasattr(value, 's') else value.value
     except (IndexError, AttributeError, IOError, OSError):
         raise PipError(
             "Directory %r is not installable. "
Index: pip_api-0.0.34/tests/test_parse_requirements.py
===================================================================
--- pip_api-0.0.34.orig/tests/test_parse_requirements.py
+++ pip_api-0.0.34/tests/test_parse_requirements.py
@@ -62,14 +62,14 @@ PEP508_PIP_EXAMPLE_WHEEL_FILE = "file://
             "pip @ {url}\n".format(url=PEP508_PIP_EXAMPLE_URL),
             {"pip"},
             PEP508_PIP_EXAMPLE_URL,
-            "pip@ " + PEP508_PIP_EXAMPLE_URL,
+            "pip @ " + PEP508_PIP_EXAMPLE_URL,
             "",
         ),
         (
             "pip@{url}\n".format(url=PEP508_PIP_EXAMPLE_URL),
             {"pip"},
             PEP508_PIP_EXAMPLE_URL,
-            "pip@ " + PEP508_PIP_EXAMPLE_URL,  # Note extra space after @
+            "pip @ " + PEP508_PIP_EXAMPLE_URL,  # Note extra space after @
             "",
         ),
         (
@@ -77,7 +77,7 @@ PEP508_PIP_EXAMPLE_WHEEL_FILE = "file://
             "git+" + PEP508_PIP_EXAMPLE_EGG,
             {"pip"},
             PEP508_PIP_EXAMPLE_EGG,
-            "pip@ " + PEP508_PIP_EXAMPLE_EGG,
+            "pip @ " + PEP508_PIP_EXAMPLE_EGG,
             "",
         ),
         (
@@ -91,7 +91,7 @@ PEP508_PIP_EXAMPLE_WHEEL_FILE = "file://
             PEP508_PIP_EXAMPLE_EGG_FILE,
             {"pip"},
             PEP508_PIP_EXAMPLE_EGG_FILE,
-            "pip@ " + PEP508_PIP_EXAMPLE_EGG_FILE,
+            "pip @ " + PEP508_PIP_EXAMPLE_EGG_FILE,
             "",
         ),
         (PEP508_PIP_EXAMPLE_WHEEL_FILE, {"pip"}, None, "pip==1.3.1", "==1.3.1"),
@@ -181,7 +181,7 @@ def test_parse_requirements_editable(mon
     assert set(result) == {"django", "deal"}
     assert str(result["django"]) == "Django==1.11"
     assert not result["django"].editable
-    assert str(result["deal"]) == "deal@ git+https://github.com/foo/deal.git#egg=deal"
+    assert str(result["deal"]) == "deal @ git+https://github.com/foo/deal.git#egg=deal"
     assert result["deal"].editable
 
 
@@ -193,7 +193,7 @@ def test_parse_requirements_editable_fil
 
     assert set(result) == {"django", "pip-api"}
     assert str(result["django"]) == "Django==1.11"
-    assert str(result["pip-api"]).startswith("pip-api@ file:///")
+    assert str(result["pip-api"]).startswith("pip-api @ file:/")
 
 
 def test_parse_requirements_editable_pyprojecttoml(monkeypatch, data):
@@ -206,7 +206,7 @@ def test_parse_requirements_editable_pyp
 
     assert set(result) == {"dummyproject_pyproject"}
     assert str(result["dummyproject_pyproject"]).startswith(
-        "dummyproject_pyproject@ file:///"
+        "dummyproject_pyproject @ file:/"
     )
 
 
@@ -220,7 +220,7 @@ def test_parse_requirements_editable_esc
 
     assert set(result) == {"dummyproject_pyproject"}
     assert str(result["dummyproject_pyproject"]).startswith(
-        "dummyproject_pyproject@ file:///"
+        "dummyproject_pyproject @ file:/"
     )
     # The @ in `escapable@path` should be URL-encoded
     assert "escapable%40path" in str(result["dummyproject_pyproject"])
openSUSE Build Service is sponsored by