From 763cbf30d54a0504c43a17e2604d536ce190c024 Mon Sep 17 00:00:00 2001 From: nichmor Date: Wed, 7 Aug 2024 11:16:25 +0300 Subject: [PATCH 1/8] misc: disable meta.yaml for cross_compile.py --- conda_forge_tick/migrators/cross_compile.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/conda_forge_tick/migrators/cross_compile.py b/conda_forge_tick/migrators/cross_compile.py index d6179db2f..9eb866686 100644 --- a/conda_forge_tick/migrators/cross_compile.py +++ b/conda_forge_tick/migrators/cross_compile.py @@ -40,6 +40,9 @@ def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> No return try: with provide_source_code(recipe_dir) as cb_work_dir: + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return if cb_work_dir is None: return directories = set() @@ -155,6 +158,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: host_reqs = attrs.get("requirements", {}).get("host", set()) with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as f: lines = f.readlines() in_reqs = False @@ -259,6 +265,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: meta_yaml = fp.readlines() @@ -288,6 +297,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: meta_yaml = fp.readlines() @@ -321,6 +333,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: meta_yaml = fp.readlines() From fdc44482ec1e279bd9e7b525bc720c6973e9bd66 Mon Sep 17 00:00:00 2001 From: nichmor Date: Wed, 7 Aug 2024 12:02:26 +0300 Subject: [PATCH 2/8] misc: apply for other migrators --- conda_forge_tick/migrators/duplicate_lines.py | 8 ++++++++ conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py | 6 ++++++ conda_forge_tick/migrators/jinja2_vars_cleanup.py | 8 ++++++++ conda_forge_tick/migrators/license.py | 6 ++++++ conda_forge_tick/migrators/pip_check.py | 7 +++++++ conda_forge_tick/migrators/pip_wheel_dep.py | 3 +++ conda_forge_tick/migrators/r_ucrt.py | 7 +++++++ conda_forge_tick/migrators/replacement.py | 3 +++ conda_forge_tick/migrators/use_pip.py | 7 +++++++ conda_forge_tick/migrators/version.py | 4 ++++ conda_forge_tick/utils.py | 1 + 11 files changed, 60 insertions(+) diff --git a/conda_forge_tick/migrators/duplicate_lines.py b/conda_forge_tick/migrators/duplicate_lines.py index 2aeea8a7c..4ca94b8be 100644 --- a/conda_forge_tick/migrators/duplicate_lines.py +++ b/conda_forge_tick/migrators/duplicate_lines.py @@ -1,5 +1,7 @@ +import os import re import typing +import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator @@ -9,6 +11,8 @@ from ..migrators_types import AttrsTypedDict +logger = logging.getLogger(__name__) + class DuplicateLinesCleanup(MiniMigrator): regex_to_check = { "noarch: generic": re.compile(r"^\s*noarch:\s*generic\s*$"), @@ -29,6 +33,10 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return + with open("meta.yaml") as fp: raw_yaml = fp.read() diff --git a/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py b/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py index 6e3e469a1..d229c92e1 100644 --- a/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py +++ b/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py @@ -1,5 +1,7 @@ +import os import re import typing +import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator @@ -8,6 +10,7 @@ if typing.TYPE_CHECKING: from ..migrators_types import AttrsTypedDict +logger = logging.getLogger(__name__) class ExtraJinja2KeysCleanup(MiniMigrator): """Remove extra Jinja2 keys that make things hard for the version migrator. @@ -58,6 +61,9 @@ def _replace_jinja_key(self, key_name, lines): def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: lines = fp.readlines() diff --git a/conda_forge_tick/migrators/jinja2_vars_cleanup.py b/conda_forge_tick/migrators/jinja2_vars_cleanup.py index d7f8a289b..85086d834 100644 --- a/conda_forge_tick/migrators/jinja2_vars_cleanup.py +++ b/conda_forge_tick/migrators/jinja2_vars_cleanup.py @@ -1,5 +1,7 @@ +import os import re import typing +import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator @@ -8,6 +10,9 @@ if typing.TYPE_CHECKING: from ..migrators_types import AttrsTypedDict + +logger = logging.getLogger(__name__) + JINJA2_VAR_RE = re.compile(r"{{\s*(.*?)\s*}}") @@ -38,6 +43,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: raw_yaml = fp.read() diff --git a/conda_forge_tick/migrators/license.py b/conda_forge_tick/migrators/license.py index 2e30dfcb2..0fc0e25dd 100644 --- a/conda_forge_tick/migrators/license.py +++ b/conda_forge_tick/migrators/license.py @@ -198,6 +198,9 @@ def _scrape_license_string(pkg): ], check=True, ) + if not os.path.exists("r-%s/meta.yaml" % pkg) and os.path.exists("r-%s/recipe.yaml" % pkg): + logger.info("Skipping _scrape_license_string for recipe.yaml") + return with open("r-%s/meta.yaml" % pkg) as fp: in_about = False meta_yaml = [] @@ -334,6 +337,9 @@ def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> No Copyright (c) 2017, Anthony Scopatz Copyright (c) 2018, The Regro Developers All rights reserved.""" + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info("Skipping _scrape_license_string for recipe.yaml") + return with open("meta.yaml") as f: raw = f.read() lines = raw.splitlines() diff --git a/conda_forge_tick/migrators/pip_check.py b/conda_forge_tick/migrators/pip_check.py index 05e787440..d04283e78 100644 --- a/conda_forge_tick/migrators/pip_check.py +++ b/conda_forge_tick/migrators/pip_check.py @@ -1,6 +1,8 @@ import io +import os import re import typing +import logging from typing import Any import ruamel.yaml @@ -12,6 +14,8 @@ if typing.TYPE_CHECKING: from ..migrators_types import AttrsTypedDict +logger = logging.getLogger(__name__) + # matches lines like 'key: val # [blah or blad]' # giving back key, val, "blah or blad" in the groups SELECTOR_RE = re.compile(r"^(\s*)(\S*):\s*(\S*)\s*#\s*\[(.*)\]") @@ -159,6 +163,9 @@ def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> No with pushd(recipe_dir): mapping = {} groups = {} + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: lines = [] for line in fp.readlines(): diff --git a/conda_forge_tick/migrators/pip_wheel_dep.py b/conda_forge_tick/migrators/pip_wheel_dep.py index 152b8031e..e7539970d 100644 --- a/conda_forge_tick/migrators/pip_wheel_dep.py +++ b/conda_forge_tick/migrators/pip_wheel_dep.py @@ -129,6 +129,9 @@ def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> No handled_packages = set() with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as f: lines = f.readlines() in_reqs = False diff --git a/conda_forge_tick/migrators/r_ucrt.py b/conda_forge_tick/migrators/r_ucrt.py index f4fb9b8e5..0c266ef56 100644 --- a/conda_forge_tick/migrators/r_ucrt.py +++ b/conda_forge_tick/migrators/r_ucrt.py @@ -1,5 +1,7 @@ +import os import re import typing +import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator @@ -8,6 +10,8 @@ if typing.TYPE_CHECKING: from ..migrators_types import AttrsTypedDict +logger = logging.getLogger(__name__) + def _cleanup_raw_yaml(raw_yaml): lines = [] @@ -47,6 +51,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: raw_yaml = fp.read() diff --git a/conda_forge_tick/migrators/replacement.py b/conda_forge_tick/migrators/replacement.py index 7df2be3f5..edc353f1b 100644 --- a/conda_forge_tick/migrators/replacement.py +++ b/conda_forge_tick/migrators/replacement.py @@ -110,6 +110,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate( self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any ) -> "MigrationUidTypedDict": + if not os.path.exists(os.path.join(recipe_dir, "meta.yaml")) and os.path.exists(os.path.join(recipe_dir, "recipe.yaml")): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open(os.path.join(recipe_dir, "meta.yaml")) as f: raw = f.read() lines = raw.splitlines() diff --git a/conda_forge_tick/migrators/use_pip.py b/conda_forge_tick/migrators/use_pip.py index a4959b675..fe6486507 100644 --- a/conda_forge_tick/migrators/use_pip.py +++ b/conda_forge_tick/migrators/use_pip.py @@ -1,4 +1,6 @@ +import os import typing +import logging from typing import Any from conda_forge_tick.os_utils import pushd @@ -9,6 +11,8 @@ if typing.TYPE_CHECKING: from ..migrators_types import AttrsTypedDict +logger = logging.getLogger(__name__) + class PipMigrator(MiniMigrator): bad_install = ( @@ -24,6 +28,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> None: with pushd(recipe_dir): + if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return with open("meta.yaml") as fp: lines = fp.readlines() diff --git a/conda_forge_tick/migrators/version.py b/conda_forge_tick/migrators/version.py index 9cf8b8186..a59e93f34 100644 --- a/conda_forge_tick/migrators/version.py +++ b/conda_forge_tick/migrators/version.py @@ -195,6 +195,10 @@ def migrate( ) -> "MigrationUidTypedDict": version = attrs["new_version"] + if not os.path.exists(os.path.join(recipe_dir, "meta.yaml")) and os.path.exists(os.path.join(recipe_dir, "recipe.yaml")): + logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") + return + with open(os.path.join(recipe_dir, "meta.yaml")) as fp: raw_meta_yaml = fp.read() diff --git a/conda_forge_tick/utils.py b/conda_forge_tick/utils.py index 0dfc79a25..83f42cd7e 100644 --- a/conda_forge_tick/utils.py +++ b/conda_forge_tick/utils.py @@ -6,6 +6,7 @@ import json import logging import os +from pathlib import Path import pprint import subprocess import sys From f270377103f936955aaa557bdfd171d9211eb255 Mon Sep 17 00:00:00 2001 From: nichmor Date: Wed, 7 Aug 2024 12:52:36 +0300 Subject: [PATCH 3/8] misc: remove import --- conda_forge_tick/utils.py | 1 - 1 file changed, 1 deletion(-) diff --git a/conda_forge_tick/utils.py b/conda_forge_tick/utils.py index 83f42cd7e..0dfc79a25 100644 --- a/conda_forge_tick/utils.py +++ b/conda_forge_tick/utils.py @@ -6,7 +6,6 @@ import json import logging import os -from pathlib import Path import pprint import subprocess import sys From e9da25425e3e835f10894081c187b9f0298648b4 Mon Sep 17 00:00:00 2001 From: Wolf Vollprecht Date: Sat, 10 Aug 2024 07:40:01 +0200 Subject: [PATCH 4/8] run pre-commit and disable dep update --- conda_forge_tick/migrators/duplicate_lines.py | 5 +++-- .../migrators/extra_jinj2a_keys_cleanup.py | 3 ++- conda_forge_tick/migrators/jinja2_vars_cleanup.py | 2 +- conda_forge_tick/migrators/license.py | 12 +++++++++--- conda_forge_tick/migrators/pip_check.py | 2 +- conda_forge_tick/migrators/r_ucrt.py | 2 +- conda_forge_tick/migrators/replacement.py | 4 +++- conda_forge_tick/migrators/use_pip.py | 2 +- conda_forge_tick/migrators/version.py | 4 +++- conda_forge_tick/update_deps.py | 4 ++++ 10 files changed, 28 insertions(+), 12 deletions(-) diff --git a/conda_forge_tick/migrators/duplicate_lines.py b/conda_forge_tick/migrators/duplicate_lines.py index 4ca94b8be..e3fc39a63 100644 --- a/conda_forge_tick/migrators/duplicate_lines.py +++ b/conda_forge_tick/migrators/duplicate_lines.py @@ -1,7 +1,7 @@ +import logging import os import re import typing -import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator @@ -13,6 +13,7 @@ logger = logging.getLogger(__name__) + class DuplicateLinesCleanup(MiniMigrator): regex_to_check = { "noarch: generic": re.compile(r"^\s*noarch:\s*generic\s*$"), @@ -36,7 +37,7 @@ def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> No if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") return - + with open("meta.yaml") as fp: raw_yaml = fp.read() diff --git a/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py b/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py index d229c92e1..29f2ad63a 100644 --- a/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py +++ b/conda_forge_tick/migrators/extra_jinj2a_keys_cleanup.py @@ -1,7 +1,7 @@ +import logging import os import re import typing -import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator @@ -12,6 +12,7 @@ logger = logging.getLogger(__name__) + class ExtraJinja2KeysCleanup(MiniMigrator): """Remove extra Jinja2 keys that make things hard for the version migrator. diff --git a/conda_forge_tick/migrators/jinja2_vars_cleanup.py b/conda_forge_tick/migrators/jinja2_vars_cleanup.py index 85086d834..762b661f0 100644 --- a/conda_forge_tick/migrators/jinja2_vars_cleanup.py +++ b/conda_forge_tick/migrators/jinja2_vars_cleanup.py @@ -1,7 +1,7 @@ +import logging import os import re import typing -import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator diff --git a/conda_forge_tick/migrators/license.py b/conda_forge_tick/migrators/license.py index 0fc0e25dd..40c7824af 100644 --- a/conda_forge_tick/migrators/license.py +++ b/conda_forge_tick/migrators/license.py @@ -198,7 +198,9 @@ def _scrape_license_string(pkg): ], check=True, ) - if not os.path.exists("r-%s/meta.yaml" % pkg) and os.path.exists("r-%s/recipe.yaml" % pkg): + if not os.path.exists("r-%s/meta.yaml" % pkg) and os.path.exists( + "r-%s/recipe.yaml" % pkg + ): logger.info("Skipping _scrape_license_string for recipe.yaml") return with open("r-%s/meta.yaml" % pkg) as fp: @@ -337,8 +339,12 @@ def migrate(self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any) -> No Copyright (c) 2017, Anthony Scopatz Copyright (c) 2018, The Regro Developers All rights reserved.""" - if not os.path.exists("meta.yaml") and os.path.exists("recipe.yaml"): - logger.info("Skipping _scrape_license_string for recipe.yaml") + if not os.path.exists("meta.yaml") and os.path.exists( + "recipe.yaml" + ): + logger.info( + "Skipping _scrape_license_string for recipe.yaml" + ) return with open("meta.yaml") as f: raw = f.read() diff --git a/conda_forge_tick/migrators/pip_check.py b/conda_forge_tick/migrators/pip_check.py index d04283e78..1fa709bd5 100644 --- a/conda_forge_tick/migrators/pip_check.py +++ b/conda_forge_tick/migrators/pip_check.py @@ -1,8 +1,8 @@ import io +import logging import os import re import typing -import logging from typing import Any import ruamel.yaml diff --git a/conda_forge_tick/migrators/r_ucrt.py b/conda_forge_tick/migrators/r_ucrt.py index 0c266ef56..cd85a97e7 100644 --- a/conda_forge_tick/migrators/r_ucrt.py +++ b/conda_forge_tick/migrators/r_ucrt.py @@ -1,7 +1,7 @@ +import logging import os import re import typing -import logging from typing import Any from conda_forge_tick.migrators.core import MiniMigrator diff --git a/conda_forge_tick/migrators/replacement.py b/conda_forge_tick/migrators/replacement.py index edc353f1b..d24de2bc7 100644 --- a/conda_forge_tick/migrators/replacement.py +++ b/conda_forge_tick/migrators/replacement.py @@ -110,7 +110,9 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate( self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any ) -> "MigrationUidTypedDict": - if not os.path.exists(os.path.join(recipe_dir, "meta.yaml")) and os.path.exists(os.path.join(recipe_dir, "recipe.yaml")): + if not os.path.exists(os.path.join(recipe_dir, "meta.yaml")) and os.path.exists( + os.path.join(recipe_dir, "recipe.yaml") + ): logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") return with open(os.path.join(recipe_dir, "meta.yaml")) as f: diff --git a/conda_forge_tick/migrators/use_pip.py b/conda_forge_tick/migrators/use_pip.py index fe6486507..eefd5b5c0 100644 --- a/conda_forge_tick/migrators/use_pip.py +++ b/conda_forge_tick/migrators/use_pip.py @@ -1,6 +1,6 @@ +import logging import os import typing -import logging from typing import Any from conda_forge_tick.os_utils import pushd diff --git a/conda_forge_tick/migrators/version.py b/conda_forge_tick/migrators/version.py index a59e93f34..5b499b589 100644 --- a/conda_forge_tick/migrators/version.py +++ b/conda_forge_tick/migrators/version.py @@ -195,7 +195,9 @@ def migrate( ) -> "MigrationUidTypedDict": version = attrs["new_version"] - if not os.path.exists(os.path.join(recipe_dir, "meta.yaml")) and os.path.exists(os.path.join(recipe_dir, "recipe.yaml")): + if not os.path.exists(os.path.join(recipe_dir, "meta.yaml")) and os.path.exists( + os.path.join(recipe_dir, "recipe.yaml") + ): logger.info(f"Skipping {self.__class__.__name__} for recipe.yaml") return diff --git a/conda_forge_tick/update_deps.py b/conda_forge_tick/update_deps.py index f99ccd43a..7af2a2ad5 100644 --- a/conda_forge_tick/update_deps.py +++ b/conda_forge_tick/update_deps.py @@ -203,6 +203,10 @@ def get_dep_updates_and_hints( # no dependency updates or hinting return {}, "" + if not (Path(recipe_dir) / "meta.yaml").exists(): + logger.info("no meta.yaml found, skipping dep updates") + return {}, "" + if update_deps in ["hint", "hint-source", "update-source"]: dep_comparison = get_depfinder_comparison( recipe_dir, From 65ae41f6099896e31df94dff307f2c21fcd8f0c9 Mon Sep 17 00:00:00 2001 From: Wolf Vollprecht Date: Sat, 10 Aug 2024 07:57:06 +0200 Subject: [PATCH 5/8] implement support for recipe.yaml in arch migrations --- conda_forge_tick/migrators/arch.py | 67 +++++++++++++++++------------- conda_forge_tick/migrators/core.py | 11 +++++ 2 files changed, 49 insertions(+), 29 deletions(-) diff --git a/conda_forge_tick/migrators/arch.py b/conda_forge_tick/migrators/arch.py index bfe81dd6f..2b010bc6c 100644 --- a/conda_forge_tick/migrators/arch.py +++ b/conda_forge_tick/migrators/arch.py @@ -10,7 +10,6 @@ make_outputs_lut_from_graph, ) from conda_forge_tick.migrators.core import GraphMigrator, _sanitized_muids -from conda_forge_tick.os_utils import pushd from conda_forge_tick.utils import ( as_iterable, frozen_to_json_friendly, @@ -195,18 +194,25 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate( self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any ) -> "MigrationUidTypedDict": - with pushd(recipe_dir + "/.."): - self.set_build_number("recipe/meta.yaml") - with open("conda-forge.yml") as f: - y = yaml_safe_load(f) - if "provider" not in y: - y["provider"] = {} - for k, v in self.arches.items(): - if k not in y["provider"]: - y["provider"][k] = v - - with open("conda-forge.yml", "w") as f: - yaml_safe_dump(y, f) + recipe_file = self.find_recipe(recipe_dir) + self.set_build_number(recipe_file) + + conda_forge_yml = recipe_dir / "conda-forge.yml" + with conda_forge_yml.open() as f: + y = yaml_safe_load(f) + + # we should do this recursively but the cf yaml is usually + # one key deep so this is fine + for k, v in self.additional_keys.items(): + if isinstance(v, dict): + if k not in y: + y[k] = {} + for _k, _v in v.items(): + y[k][_k] = _v + else: + y[k] = v + with conda_forge_yml.open("w") as f: + yaml_safe_dump(y, f) return super().migrate(recipe_dir, attrs, **kwargs) @@ -362,22 +368,25 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate( self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any ) -> "MigrationUidTypedDict": - with pushd(recipe_dir + "/.."): - self.set_build_number("recipe/meta.yaml") - with open("conda-forge.yml") as f: - y = yaml_safe_load(f) - # we should do this recursively but the cf yaml is usually - # one key deep so this is fine - for k, v in self.additional_keys.items(): - if isinstance(v, dict): - if k not in y: - y[k] = {} - for _k, _v in v.items(): - y[k][_k] = _v - else: - y[k] = v - with open("conda-forge.yml", "w") as f: - yaml_safe_dump(y, f) + recipe_file = self.find_recipe(recipe_dir) + self.set_build_number(recipe_file) + + conda_forge_yml = recipe_dir / "conda-forge.yml" + with conda_forge_yml.open() as f: + y = yaml_safe_load(f) + + # we should do this recursively but the cf yaml is usually + # one key deep so this is fine + for k, v in self.additional_keys.items(): + if isinstance(v, dict): + if k not in y: + y[k] = {} + for _k, _v in v.items(): + y[k][_k] = _v + else: + y[k] = v + with conda_forge_yml.open("w") as f: + yaml_safe_dump(y, f) return super().migrate(recipe_dir, attrs, **kwargs) diff --git a/conda_forge_tick/migrators/core.py b/conda_forge_tick/migrators/core.py index 48f0c014b..217b11388 100644 --- a/conda_forge_tick/migrators/core.py +++ b/conda_forge_tick/migrators/core.py @@ -5,6 +5,7 @@ import logging import re import typing +from pathlib import Path from typing import Any, List, Sequence, Set import dateutil.parser @@ -560,6 +561,16 @@ def order( } return cyclic_topological_sort(graph, top_level) + def find_recipe(self, recipe_dir: str) -> Path: + """Find the recipe, either meta.yaml or recipe.yaml""" + recipe_dir = Path(recipe_dir) + if recipe_dir.joinpath("meta.yaml").exists(): + return recipe_dir.joinpath("meta.yaml") + elif recipe_dir.joinpath("recipe.yaml").exists(): + return recipe_dir.joinpath("recipe.yaml") + else: + raise FileNotFoundError("No recipe found in %s" % recipe_dir) + def set_build_number(self, filename: str) -> None: """Bump the build number of the specified recipe. From 9d00f37955b25fefc4765a0dccc5aafb380361f9 Mon Sep 17 00:00:00 2001 From: Wolf Vollprecht Date: Sat, 10 Aug 2024 08:02:05 +0200 Subject: [PATCH 6/8] fix up path/str usage --- conda_forge_tick/migrators/arch.py | 11 +++++++---- conda_forge_tick/migrators/core.py | 21 +++++++++++++++++++-- 2 files changed, 26 insertions(+), 6 deletions(-) diff --git a/conda_forge_tick/migrators/arch.py b/conda_forge_tick/migrators/arch.py index 2b010bc6c..70bc92527 100644 --- a/conda_forge_tick/migrators/arch.py +++ b/conda_forge_tick/migrators/arch.py @@ -1,4 +1,5 @@ import typing +from pathlib import Path from textwrap import dedent from typing import Any, Optional, Sequence @@ -194,10 +195,11 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate( self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any ) -> "MigrationUidTypedDict": - recipe_file = self.find_recipe(recipe_dir) + recipe_dir_p = Path(recipe_dir) + recipe_file = self.find_recipe(recipe_dir_p) self.set_build_number(recipe_file) - conda_forge_yml = recipe_dir / "conda-forge.yml" + conda_forge_yml = recipe_dir_p / "conda-forge.yml" with conda_forge_yml.open() as f: y = yaml_safe_load(f) @@ -368,10 +370,11 @@ def filter(self, attrs: "AttrsTypedDict", not_bad_str_start: str = "") -> bool: def migrate( self, recipe_dir: str, attrs: "AttrsTypedDict", **kwargs: Any ) -> "MigrationUidTypedDict": - recipe_file = self.find_recipe(recipe_dir) + recipe_dir_p = Path(recipe_dir) + recipe_file = self.find_recipe(recipe_dir_p) self.set_build_number(recipe_file) - conda_forge_yml = recipe_dir / "conda-forge.yml" + conda_forge_yml = recipe_dir_p / "conda-forge.yml" with conda_forge_yml.open() as f: y = yaml_safe_load(f) diff --git a/conda_forge_tick/migrators/core.py b/conda_forge_tick/migrators/core.py index 217b11388..e78520665 100644 --- a/conda_forge_tick/migrators/core.py +++ b/conda_forge_tick/migrators/core.py @@ -561,8 +561,25 @@ def order( } return cyclic_topological_sort(graph, top_level) - def find_recipe(self, recipe_dir: str) -> Path: - """Find the recipe, either meta.yaml or recipe.yaml""" + def find_recipe(self, recipe_dir: str | Path) -> Path: + """ + Find the recipe, either meta.yaml or recipe.yaml in the recipe_dir + + Parameters + ---------- + recipe_dir : str or Path + Path to the recipe directory + + Returns + ------- + recipe_path : Path + Path to the recipe file + + Raises + ------ + FileNotFoundError + If no recipe is found in the recipe_dir + """ recipe_dir = Path(recipe_dir) if recipe_dir.joinpath("meta.yaml").exists(): return recipe_dir.joinpath("meta.yaml") From 809566ed2b43ae6b0fba589742327ad5d3d9cbba Mon Sep 17 00:00:00 2001 From: Wolf Vollprecht Date: Sat, 10 Aug 2024 08:11:25 +0200 Subject: [PATCH 7/8] extend typing for update build number --- conda_forge_tick/migrators/core.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/conda_forge_tick/migrators/core.py b/conda_forge_tick/migrators/core.py index e78520665..f49ccf5de 100644 --- a/conda_forge_tick/migrators/core.py +++ b/conda_forge_tick/migrators/core.py @@ -588,12 +588,12 @@ def find_recipe(self, recipe_dir: str | Path) -> Path: else: raise FileNotFoundError("No recipe found in %s" % recipe_dir) - def set_build_number(self, filename: str) -> None: + def set_build_number(self, filename: str | Path) -> None: """Bump the build number of the specified recipe. Parameters ---------- - filename : str + filename : str or Path Path the the meta.yaml """ with open(filename) as f: From 3188eee013aafd71cf33acebc2eb5d691dcfae75 Mon Sep 17 00:00:00 2001 From: Wolf Vollprecht Date: Sat, 10 Aug 2024 08:18:18 +0200 Subject: [PATCH 8/8] enable jpeg turbo for new recipes --- conda_forge_tick/migrators/jpegturbo.py | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/conda_forge_tick/migrators/jpegturbo.py b/conda_forge_tick/migrators/jpegturbo.py index 9b4cc11b8..370911366 100644 --- a/conda_forge_tick/migrators/jpegturbo.py +++ b/conda_forge_tick/migrators/jpegturbo.py @@ -18,11 +18,8 @@ def filter(self, attrs, not_bad_str_start=""): return "jpeg" not in host_req def migrate(self, recipe_dir, attrs, **kwargs): - fname = os.path.join(recipe_dir, "meta.yaml") - if os.path.exists(fname): - with open(fname) as fp: - lines = fp.readlines() + recipe_file = self.find_recipe(recipe_dir) - new_lines = _parse_jpeg(lines) - with open(fname, "w") as fp: - fp.write("".join(new_lines)) + lines = recipe_file.read_text().splitlines(keepends=True) + new_lines = _parse_jpeg(lines) + recipe_file.write_text("".join(new_lines))