def first_license_classifier_from_list( classifiers: List[str]) -> Optional[str]: for classifier in classifiers: if classifier in all_classifiers: escaped_classifier: str = escape_string(classifier) return '"' + escaped_classifier + '"' return None
def _get_license(self) -> None: license_string = str_from_message(self.pkg_info, "license") if license_string is None: license_string = "" classifiers = list_from_message(self.pkg_info, "Classifier") if classifiers is None: classifiers = [] self.license = find_license(classifiers=classifiers, license_string=license_string) if self.license is None: self.license = '"' + escape_string(license_string) + '"' self.logger.warning( f"Couldn't recognize license `{license_string}` for `{self.name}`" )
def render_expression( packages_metadata: Iterable[Wheel], sources: Sources, requirements_name: str, requirements_frozen: str, extra_build_inputs: Iterable[str], enable_tests: bool, python_version: PythonVersion, target_directory: str, logger: Logger, common_overrides: Iterable[Overrides] = [], ) -> None: """Create Nix expressions. """ default_file = os.path.join(target_directory, f"{requirements_name}.nix") overrides_file = os.path.join(target_directory, f"{requirements_name}_override.nix") frozen_file = os.path.join(target_directory, f"{requirements_name}_frozen.txt") metadata_by_name: Dict[str, Wheel] = {x.name: x for x in packages_metadata} generated_packages_metadata = [] for item in sorted(packages_metadata, key=lambda x: x.name): if item.build_dependencies: buildInputs = "\n".join( sorted( [ ' self."{}"'.format(dependency.name()) for dependency in item.build_dependencies ] ) ) buildInputs = "[\n" + buildInputs + "\n ]" else: buildInputs = "[ ]" propagatedBuildInputs = "[ ]" dependencies = item.dependencies(extras=[]) if dependencies: deps = [ x.name() for x in dependencies if x.name() in metadata_by_name.keys() ] if deps: propagatedBuildInputs = "[\n%s\n ]" % ( "\n".join( sorted( [ ' self."%s"' % (metadata_by_name[x].name) for x in deps if x != item.name ] ) ) ) source = sources[item.name] fetch_expression = source.nix_expression() package_format = item.package_format generated_packages_metadata.append( dict( name=item.name, version=item.version, fetch_expression=fetch_expression, buildInputs=buildInputs, propagatedBuildInputs=propagatedBuildInputs, homepage=item.homepage, license=item.license, description=escape_string(item.description), package_format=package_format, ) ) templates = jinja2.Environment(loader=jinja2.FileSystemLoader(HERE + "/templates")) generated_template = templates.get_template("generated.nix.j2") generated = "\n\n".join( generated_template.render(**x) for x in generated_packages_metadata ) overrides = templates.get_template("overrides.nix.j2").render() common_overrides_expressions = [ " (" + override.nix_expression(logger) + ")" for override in common_overrides ] default_template = templates.get_template("requirements.nix.j2") overrides_file_nix_path = os.path.join(".", os.path.split(overrides_file)[1]) default = default_template.render( version=pypi2nix_version, command_arguments=" ".join(map(shlex.quote, sys.argv[1:])), python_version=python_version.derivation_name(), extra_build_inputs=( extra_build_inputs and "with pkgs; [ %s ]" % (" ".join(extra_build_inputs)) or "[]" ), overrides_file=overrides_file_nix_path, enable_tests=str(enable_tests).lower(), generated_package_nix=generated, common_overrides="\n".join(common_overrides_expressions), python_major_version=python_version.major_version(), ) if not os.path.exists(overrides_file): with open(overrides_file, "w+") as f: f.write(overrides.strip()) logger.info("|-> writing %s" % overrides_file) with open(default_file, "w+") as f: f.write(default.strip()) with open(frozen_file, "w+") as f: f.write(requirements_frozen)