"Skeleto
Adapted from Wikipedia. Image credits: https://he-man.fandom.com
Grayskull is an automatic conda recipe generator.
The main goal of this project is to generate concise recipes
for conda-forge.
The Grayskull project was created with the intention to eventually replace conda skeleton.
Presently Grayskull can generate recipes for Python packages available on PyPI and also those not published on PyPI but available as GitHub repositories.
Grayskull can also generate recipes for R packages published on CRAN.
Future versions of Grayskull will support recipe generation for packages of other repositories such as Conan and CPAN etc..
It is possible to install this project using pip:
pip install grayskullor conda, using the conda-forge channel:
conda install -c conda-forge grayskullIt is also possible to clone this repo and install it using pip:
git clone https://github.com/conda/grayskull.git
cd grayskull
pip install -e .It is pretty simple to use grayskull. Just call it, pass the repository
(pypi or cran) and the package name.
- Example:
grayskull pypi pytestAfter that grayskull will create a folder with the same name as the package
and inside this folder the generated recipe will be present (meta.yaml).
- Example with
pytest(grayskull pypi pytest):
If your package is a GitHub repository just replace the package name with the GitHub repository URL.
For example:
grayskull pypi https://github.com/confluentinc/confluent-kafka-pythonYou can also generate a recipe from a local sdist archive:
grayskull pypi ./pytest-5.3.5.tar.gzNote that such a recipe isn't really portable as it will depend on the local path of the sdist file. It can be useful if you want to automatically generate a conda package.
Grayskull can create recipes that point to any Python Package Index. Supply the --pypi-mirror-url keyword.
- Example:
grayskull pypi --pypi-mirror-url https://pypi.example.com pytestThe above will source packages from https://pypi.example.com/packages/source/...
This assumes that the mirror follows the same API as pypi including hosting metadata at the /pypi/{package_name}/json endpoint.
To specify an alternate metadata location use the --pypi-metadata-url option.
- Example:
grayskull pypi --pypi-mirror-url https://pypi.example.com --pypi-metadata-url https://pypi_meta.example.com pytestNote:
--pypi-metadata-urlis a replacement for--pypi-url;--pypi-urlis deprecated and will be removed in a future release.
By default, Grayskull checks if packages are available on conda-forge and highlights missing dependencies. You can specify custom package indexes to check against using the --package-indexes argument:
grayskull pypi --package-indexes my-channel company-channel conda-forge pytestThis will check if packages exist in my-channel, company-channel, or conda-forge (in that order) and mark them accordingly in the output.
You can also specify full URLs for internal package indexes that don't use anaconda.org:
grayskull pypi --package-indexes https://internal-conda.example.com http://another-conda.example.com conda-forge pytestBoth HTTP and HTTPS protocols are supported for custom package indexes. This is particularly useful for internal networks that don't have access to anaconda.org.
For internal package indexes with custom API structures, you can use the {pkg_name} placeholder in your URL:
grayskull pypi --package-indexes "https://internal-conda.example.com/api/{pkg_name}/available" conda-forge pytestThis allows you to specify exactly how your internal package index API works, rather than using the default /pkg_name/files path structure.
It is also possible to use Grayskull without any installation. You can go to this website marcelotrevisani.com/grayskull and inform the name and the version (optional) of the package and it will create the recipe for you.
Copyright Marcelo Duarte Trevisani and contributors, 2020-2023.
Distributed under the terms of the Apache 2.0 license, grayskull is free and open source software.