Skip to main content

Project to generate recipes for conda packages

Project description

Grayskull


Tests Deployment (PyPI)

codecov Code style: black PyPI version Conda Version Gitter




"Skeletonr's main goal is to conquer the mysterious fortress of Castle Grayskull, from which He-Man draws his powers. If he succeeds, Skeletor would be able to conquer not only Eternia, but the whole universe."
Adapted from Wikipedia. Image credits: https://he-man.fandom.com

Introduction

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.

Installation

It is possible to install this project using pip:

pip install grayskull

or conda, using the conda-forge channel:

conda install -c conda-forge grayskull

It 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 .

Usage

It is pretty simple to use grayskull. Just call it, pass the repository (pypi or cran) and the package name.

  • Example:
grayskull pypi pytest

After 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):

Grayskull CLI

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-python

You can also generate a recipe from a local sdist archive:

grayskull pypi ./pytest-5.3.5.tar.gz

Note 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.

Use Grayskull with an internal package index

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 pytest

The 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 pytest

Note: --pypi-metadata-url is a replacement for --pypi-url; --pypi-url is deprecated and will be removed in a future release.

Checking package availability against custom indexes

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 pytest

This 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 pytest

Both 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 pytest

This allows you to specify exactly how your internal package index API works, rather than using the default /pkg_name/files path structure.

Online Grayskull

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.

License

Copyright Marcelo Duarte Trevisani and contributors, 2020-2026.

Distributed under the terms of the Apache 2.0 license, grayskull is free and open source software.

Project details


Release history Release notifications | RSS feed

This version

3.1.1

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

grayskull-3.1.1.tar.gz (2.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

grayskull-3.1.1-py3-none-any.whl (141.9 kB view details)

Uploaded Python 3

File details

Details for the file grayskull-3.1.1.tar.gz.

File metadata

  • Download URL: grayskull-3.1.1.tar.gz
  • Upload date:
  • Size: 2.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for grayskull-3.1.1.tar.gz
Algorithm Hash digest
SHA256 46ea09c3322f200c35c807dc34dfaf0fc203352fc39d6c222e31a5b065f2f690
MD5 01e96b56aa6470a10b0a45064c7d8f22
BLAKE2b-256 7a51b7d181b55fd65f4ba0c0414b5f779f342f8296f991a52af2de2399b501bf

See more details on using hashes here.

File details

Details for the file grayskull-3.1.1-py3-none-any.whl.

File metadata

  • Download URL: grayskull-3.1.1-py3-none-any.whl
  • Upload date:
  • Size: 141.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for grayskull-3.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7ad7d1d2bcb06ef0af297c7d5956844699931e34ea21aa6cb2a61f09eac60108
MD5 582bc018672105bfbb092c9cbb4bae88
BLAKE2b-256 55d24c5a4cf2b69d5d38b04aec3e595c4faf4e398af357023b0d554104ce6e63

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page